@charset "UTF-8";
/*! normalize.css v1.0.1 | MIT License | git.io/normalize */
article, aside, details, figcaption, figure, footer, header, hgroup, nav, section, summary {
  display: block; }

audio, canvas, video {
  display: inline-block;
  *display: inline;
  *zoom: 1; }

audio:not([controls]) {
  display: none;
  height: 0; }

[hidden] {
  display: none; }

html {
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%; }

html, button, input, select, textarea {
  font-family: sans-serif; }

body {
  margin: 0; }

a:focus {
  outline: thin dotted; }

a:active, a:hover {
  outline: 0; }

h1 {
  font-size: 2em;
  margin: .67em 0; }

h2 {
  font-size: 1.5em;
  margin: .83em 0; }

h3 {
  font-size: 1.17em;
  margin: 1em 0; }

h4 {
  font-size: 1em;
  margin: 1.33em 0; }

h5 {
  font-size: .83em;
  margin: 1.67em 0; }

h6 {
  font-size: .75em;
  margin: 2.33em 0; }

abbr[title] {
  border-bottom: 1px dotted; }

b, strong {
  font-weight: bold; }

blockquote {
  margin: 1em 40px; }

dfn {
  font-style: italic; }

mark {
  background: #ff0;
  color: #000; }

p, pre {
  margin: 1em 0; }

code, kbd, pre, samp {
  font-family: monospace,serif;
  _font-family: 'courier new',monospace;
  font-size: 1em; }

pre {
  white-space: pre;
  white-space: pre-wrap;
  word-wrap: break-word; }

q {
  quotes: none; }

q:before, q:after {
  content: '';
  content: none; }

small {
  font-size: 80%; }

sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sup {
  top: -0.5em; }

sub {
  bottom: -0.25em; }

dl, menu, ol, ul {
  margin: 1em 0; }

dd {
  margin: 0 0 0 40px; }

menu, ol, ul {
  padding: 0 0 0 40px; }

nav ul, nav ol {
  list-style: none;
  list-style-image: none; }

img {
  border: 0;
  -ms-interpolation-mode: bicubic; }

svg:not(:root) {
  overflow: hidden; }

figure {
  margin: 0; }

form {
  margin: 0; }

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: .35em .625em .75em; }

legend {
  border: 0;
  padding: 0;
  white-space: normal;
  *margin-left: -7px; }

button, input, select, textarea {
  font-size: 100%;
  margin: 0;
  vertical-align: baseline;
  *vertical-align: middle; }

button, input {
  line-height: normal; }

button, html input[type="button"], input[type="reset"], input[type="submit"] {
  -webkit-appearance: button;
  cursor: pointer;
  *overflow: visible; }

button[disabled], input[disabled] {
  cursor: default; }

input[type="checkbox"], input[type="radio"] {
  box-sizing: border-box;
  padding: 0;
  *height: 13px;
  *width: 13px; }

input[type="search"] {
  -webkit-appearance: textfield;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  box-sizing: content-box; }

input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0; }

textarea {
  overflow: auto;
  vertical-align: top; }

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

/* ----------------------------------------------------------------------
VARIABLES
------------------------------------------------------------------------- */
@font-face {
  font-family: 'PrimaryFont';
  src: url("../fonts/Heebo/Heebo-Regular.ttf") format("truetype"); }
@font-face {
  font-family: 'PrimaryFontLight';
  src: url("../fonts/Heebo/Heebo-Light.ttf") format("truetype"); }
@font-face {
  font-family: 'PrimaryFontBold';
  src: url("../fonts/Heebo/Heebo-Bold.ttf") format("truetype"); }
@font-face {
  font-family: 'SecondaryFont';
  src: url("../fonts/Heebo/Heebo-Regular.ttf") format("truetype"); }
/*  -------------------------------------------
FONTS & COLORS
-----------------------------------------------*/
.ab-prj-txt-primary {
  font-family: "PrimaryFont", sans-serif; }

.ab-prj-txt-secondary {
  font-family: "SecondaryFont", sans-serif; }

.ab-prj-txt-colored {
  color: #C10230; }

.ab-prj-txt-big {
  font-size: 1.0em;
  font-weight: normal; }

.ab-prj-txt-highlight {
  font-size: 1.15em; }

@media (min-width: 768px) {
  .ab-prj-txt-big {
    font-size: 1.10em; }

  .ab-prj-txt-highlight {
    font-size: 1.25em; } }
@media (min-width: 1024px) {
  .ab-prj-txt-big {
    font-size: 1.15em; } }
@media (min-width: 1280px) {
  .ab-prj-txt-big {
    font-size: 1.25em; } }
/* Mobile first layout SmartMenus Core CSS (it's not recommended editing these rules)
   You need this once per page no matter how many menu trees or different themes you use.
-------------------------------------------------------------------------------------------*/
.sm, .sm ul, .sm li {
  display: block;
  list-style: none;
  margin: 0;
  padding: 0;
  line-height: normal;
  direction: ltr;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }

.sm-rtl, .sm-rtl ul, .sm-rtl li {
  direction: rtl;
  text-align: right; }

.sm > li > h1, .sm > li > h2, .sm > li > h3, .sm > li > h4, .sm > li > h5, .sm > li > h6 {
  margin: 0;
  padding: 0; }

.sm ul {
  display: none; }

.sm li, .sm a {
  position: relative; }

.sm a {
  display: block; }

.sm a.disabled {
  cursor: not-allowed; }

.sm:after {
  content: "\00a0";
  display: block;
  height: 0;
  font: 0px/0 serif;
  clear: both;
  visibility: hidden;
  overflow: hidden; }

.sm, .sm *, .sm *:before, .sm *:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

.sm-clean {
  background: #eeeeee;
  /*
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  -ms-border-radius: 5px;
  -o-border-radius: 5px;
  border-radius: 5px;
  */ }

.sm-clean a, .sm-clean a:hover, .sm-clean a:focus, .sm-clean a:active {
  padding: 13px 20px;
  /* make room for the toggle button (sub indicator) */
  padding-right: 58px;
  color: #555555;
  font-family: "Lucida Sans Unicode", "Lucida Sans", "Lucida Grande", Arial, sans-serif;
  font-size: 14px;
  font-weight: normal;
  line-height: 17px;
  text-decoration: none; }

.sm-clean a.current {
  color: #d23600; }

.sm-clean a.disabled {
  color: #bbbbbb; }

.sm-clean a span.sub-arrow {
  position: absolute;
  top: 50%;
  margin-top: -17px;
  left: auto;
  right: 4px;
  width: 34px;
  height: 34px;
  overflow: hidden;
  font: bold 16px/34px monospace !important;
  text-align: center;
  text-shadow: none;
  background: rgba(255, 255, 255, 0.5);
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  -ms-border-radius: 5px;
  -o-border-radius: 5px;
  border-radius: 5px; }

.sm-clean a.highlighted span.sub-arrow:before {
  display: block;
  content: '-'; }

.sm-clean > li:first-child > a, .sm-clean > li:first-child > :not(ul) a {
  -webkit-border-radius: 5px 5px 0 0;
  -moz-border-radius: 5px 5px 0 0;
  -ms-border-radius: 5px 5px 0 0;
  -o-border-radius: 5px 5px 0 0;
  border-radius: 5px 5px 0 0; }

.sm-clean > li:last-child > a, .sm-clean > li:last-child > *:not(ul) a, .sm-clean > li:last-child > ul,
.sm-clean > li:last-child > ul > li:last-child > a, .sm-clean > li:last-child > ul > li:last-child > *:not(ul) a, .sm-clean > li:last-child > ul > li:last-child > ul,
.sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > a, .sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > *:not(ul) a, .sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > ul,
.sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > a, .sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > *:not(ul) a, .sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > ul,
.sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > a, .sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > *:not(ul) a, .sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > ul {
  -webkit-border-radius: 0 0 5px 5px;
  -moz-border-radius: 0 0 5px 5px;
  -ms-border-radius: 0 0 5px 5px;
  -o-border-radius: 0 0 5px 5px;
  border-radius: 0 0 5px 5px; }

.sm-clean > li:last-child > a.highlighted, .sm-clean > li:last-child > *:not(ul) a.highlighted,
.sm-clean > li:last-child > ul > li:last-child > a.highlighted, .sm-clean > li:last-child > ul > li:last-child > *:not(ul) a.highlighted,
.sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > a.highlighted, .sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > *:not(ul) a.highlighted,
.sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > a.highlighted, .sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > *:not(ul) a.highlighted,
.sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > a.highlighted, .sm-clean > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > ul > li:last-child > *:not(ul) a.highlighted {
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  -ms-border-radius: 0;
  -o-border-radius: 0;
  border-radius: 0; }

.sm-clean li {
  border-top: 1px solid rgba(0, 0, 0, 0.05); }

.sm-clean > li:first-child {
  border-top: 0; }

.sm-clean ul {
  background: rgba(162, 162, 162, 0.1); }

.sm-clean ul a, .sm-clean ul a:hover, .sm-clean ul a:focus, .sm-clean ul a:active {
  font-size: 16px;
  border-left: 8px solid transparent; }

.sm-clean ul ul a,
.sm-clean ul ul a:hover,
.sm-clean ul ul a:focus,
.sm-clean ul ul a:active {
  border-left: 16px solid transparent; }

.sm-clean ul ul ul a,
.sm-clean ul ul ul a:hover,
.sm-clean ul ul ul a:focus,
.sm-clean ul ul ul a:active {
  border-left: 24px solid transparent; }

.sm-clean ul ul ul ul a,
.sm-clean ul ul ul ul a:hover,
.sm-clean ul ul ul ul a:focus,
.sm-clean ul ul ul ul a:active {
  border-left: 32px solid transparent; }

.sm-clean ul ul ul ul ul a,
.sm-clean ul ul ul ul ul a:hover,
.sm-clean ul ul ul ul ul a:focus,
.sm-clean ul ul ul ul ul a:active {
  border-left: 40px solid transparent; }

@media (min-width: 768px) {
  /* Switch to desktop layout
  -----------------------------------------------
     These transform the menu tree from
     collapsible to desktop (navbar + dropdowns)
  -----------------------------------------------*/
  /* start... (it's not recommended editing these rules) */
  .sm-clean ul {
    position: absolute; }

  .sm-clean li {
    float: left; }

  .sm-clean.sm-rtl li {
    float: right; }

  .sm-clean ul li, .sm-clean.sm-rtl ul li, .sm-clean.sm-vertical li {
    float: none; }

  .sm-clean a {
    white-space: nowrap; }

  .sm-clean ul a, .sm-clean.sm-vertical a {
    white-space: normal; }

  .sm-clean .sm-nowrap > li > a, .sm-clean .sm-nowrap > li > :not(ul) a {
    white-space: nowrap; }

  /* ...end */
  .sm-clean {
    padding: 0px;
    background: #eeeeee;
    /*
    -webkit-border-radius: 100px;
    -moz-border-radius: 100px;
    -ms-border-radius: 100px;
    -o-border-radius: 100px;
    border-radius: 100px;
    */ }

  .sm-clean a, .sm-clean a:hover, .sm-clean a:focus, .sm-clean a:active, .sm-clean a.highlighted {
    padding: 12px 12px;
    color: #555555;
    -webkit-border-radius: 0 !important;
    -moz-border-radius: 0 !important;
    -ms-border-radius: 0 !important;
    -o-border-radius: 0 !important;
    border-radius: 0 !important; }

  .sm-clean a:hover, .sm-clean a:focus, .sm-clean a:active, .sm-clean a.highlighted {
    color: #d23600; }

  .sm-clean a.current {
    color: #d23600; }

  .sm-clean a.disabled {
    color: #bbbbbb; }

  .sm-clean a.has-submenu {
    padding-right: 24px; }

  .sm-clean a span.sub-arrow {
    top: 50%;
    margin-top: -2px;
    right: 12px;
    width: 0;
    height: 0;
    border-width: 4px;
    border-style: solid dashed dashed dashed;
    border-color: #fff transparent transparent transparent;
    background: transparent;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    -ms-border-radius: 0;
    -o-border-radius: 0;
    border-radius: 0; }

  .sm-clean a.highlighted span.sub-arrow:before {
    display: none; }

  .sm-clean li {
    border-top: 0; }

  .sm-clean > li > ul:before,
  .sm-clean > li > ul:after {
    content: '';
    position: absolute;
    top: -18px;
    left: 30px;
    width: 0;
    height: 0;
    overflow: hidden;
    border-width: 9px;
    border-style: dashed dashed solid dashed;
    border-color: transparent transparent #bbbbbb transparent; }

  .sm-clean > li > ul:after {
    top: -16px;
    left: 31px;
    border-width: 8px;
    border-color: transparent transparent white transparent; }

  .sm-clean ul {
    border: 1px solid #bbbbbb;
    padding: 5px 0;
    background: white;
    -webkit-border-radius: 5px !important;
    -moz-border-radius: 5px !important;
    -ms-border-radius: 5px !important;
    -o-border-radius: 5px !important;
    border-radius: 5px !important;
    -webkit-box-shadow: 0 5px 9px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 0 5px 9px rgba(0, 0, 0, 0.2);
    box-shadow: 0 5px 9px rgba(0, 0, 0, 0.2); }

  .sm-clean ul a, .sm-clean ul a:hover, .sm-clean ul a:focus, .sm-clean ul a:active, .sm-clean ul a.highlighted {
    border: 0 !important;
    padding: 10px 20px;
    color: #555555; }

  .sm-clean ul a:hover, .sm-clean ul a:focus, .sm-clean ul a:active, .sm-clean ul a.highlighted {
    background: #eeeeee;
    color: #d23600; }

  .sm-clean ul a.current {
    color: #d23600; }

  .sm-clean ul a.disabled {
    background: white;
    color: #cccccc; }

  .sm-clean ul a.has-submenu {
    padding-right: 20px; }

  .sm-clean ul a span.sub-arrow {
    right: 8px;
    top: 50%;
    margin-top: -5px;
    border-width: 5px;
    border-style: dashed dashed dashed solid;
    border-color: transparent transparent transparent #555555; }

  .sm-clean span.scroll-up,
  .sm-clean span.scroll-down {
    position: absolute;
    display: none;
    visibility: hidden;
    overflow: hidden;
    background: white;
    height: 20px; }

  .sm-clean span.scroll-up:hover,
  .sm-clean span.scroll-down:hover {
    background: #eeeeee; }

  .sm-clean span.scroll-up:hover span.scroll-up-arrow, .sm-clean span.scroll-up:hover span.scroll-down-arrow {
    border-color: transparent transparent #d23600 transparent; }

  .sm-clean span.scroll-down:hover span.scroll-down-arrow {
    border-color: #d23600 transparent transparent transparent; }

  .sm-clean span.scroll-up-arrow, .sm-clean span.scroll-down-arrow {
    position: absolute;
    top: 0;
    left: 50%;
    margin-left: -6px;
    width: 0;
    height: 0;
    overflow: hidden;
    border-width: 6px;
    border-style: dashed dashed solid dashed;
    border-color: transparent transparent #555555 transparent; }

  .sm-clean span.scroll-down-arrow {
    top: 8px;
    border-style: solid dashed dashed dashed;
    border-color: #555555 transparent transparent transparent; }

  .sm-clean.sm-rtl a.has-submenu {
    padding-right: 12px;
    padding-left: 24px; }

  .sm-clean.sm-rtl a span.sub-arrow {
    right: auto;
    left: 12px; }

  .sm-clean.sm-rtl.sm-vertical a.has-submenu {
    padding: 10px 20px; }

  .sm-clean.sm-rtl.sm-vertical a span.sub-arrow {
    right: auto;
    left: 8px;
    border-style: dashed solid dashed dashed;
    border-color: transparent #555555 transparent transparent; }

  .sm-clean.sm-rtl > li > ul:before {
    left: auto;
    right: 30px; }

  .sm-clean.sm-rtl > li > ul:after {
    left: auto;
    right: 31px; }

  .sm-clean.sm-rtl ul a.has-submenu {
    padding: 10px 20px !important; }

  .sm-clean.sm-rtl ul a span.sub-arrow {
    right: auto;
    left: 8px;
    border-style: dashed solid dashed dashed;
    border-color: transparent #555555 transparent transparent; }

  .sm-clean.sm-vertical {
    padding: 10px 0;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    -ms-border-radius: 5px;
    -o-border-radius: 5px;
    border-radius: 5px; }

  .sm-clean.sm-vertical a {
    padding: 10px 20px; }

  .sm-clean.sm-vertical a:hover, .sm-clean.sm-vertical a:focus, .sm-clean.sm-vertical a:active, .sm-clean.sm-vertical a.highlighted {
    background: white; }

  .sm-clean.sm-vertical a.disabled {
    background: #eeeeee; }

  .sm-clean.sm-vertical a span.sub-arrow {
    right: 8px;
    top: 50%;
    margin-top: -5px;
    border-width: 5px;
    border-style: dashed dashed dashed solid;
    border-color: transparent transparent transparent #555555; }

  .sm-clean.sm-vertical > li > ul:before,
  .sm-clean.sm-vertical > li > ul:after {
    display: none; }

  .sm-clean.sm-vertical ul a {
    padding: 10px 20px; }

  .sm-clean.sm-vertical ul a:hover, .sm-clean.sm-vertical ul a:focus, .sm-clean.sm-vertical ul a:active, .sm-clean.sm-vertical ul a.highlighted {
    background: #eeeeee; }

  .sm-clean.sm-vertical ul a.disabled {
    background: white; } }
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent; }

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0; }
  .slick-list:focus {
    outline: none; }
  .slick-list.dragging {
    cursor: pointer;
    cursor: hand; }

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto; }
  .slick-track:before, .slick-track:after {
    content: "";
    display: table; }
  .slick-track:after {
    clear: both; }
  .slick-loading .slick-track {
    visibility: hidden; }

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none; }
  [dir="rtl"] .slick-slide {
    float: right; }
  .slick-slide img {
    display: block; }
  .slick-slide.slick-loading img {
    display: none; }
  .slick-slide.dragging img {
    pointer-events: none; }
  .slick-initialized .slick-slide {
    display: block; }
  .slick-loading .slick-slide {
    visibility: hidden; }
  .slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent; }

.slick-arrow.slick-hidden {
  display: none; }

/* Slider */
.slick-loading .slick-list {
  background: #fff url("../slick/ajax-loader.gif") center center no-repeat; }

/* Icons */
@font-face {
  font-family: "slick";
  src: url("../slick/fonts/slick.eot");
  src: url("../slick/fonts/slick.eot?#iefix") format("embedded-opentype"), url("../slick/fonts/slick.woff") format("woff"), url("../slick/fonts/slick.ttf") format("truetype"), url("../slick/fonts/slick.svg#slick") format("svg");
  font-weight: normal;
  font-style: normal; }
/* Arrows */
.slick-prev,
.slick-next {
  position: absolute;
  display: block;
  height: 20px;
  width: 20px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  background: transparent;
  color: transparent;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  padding: 0;
  border: none;
  outline: none; }
  .slick-prev:hover, .slick-prev:focus,
  .slick-next:hover,
  .slick-next:focus {
    outline: none;
    background: transparent;
    color: transparent; }
    .slick-prev:hover:before, .slick-prev:focus:before,
    .slick-next:hover:before,
    .slick-next:focus:before {
      opacity: 1; }
  .slick-prev.slick-disabled:before,
  .slick-next.slick-disabled:before {
    opacity: 0.25; }
  .slick-prev:before,
  .slick-next:before {
    font-family: "slick";
    font-size: 20px;
    line-height: 1;
    color: white;
    opacity: 0.75;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale; }

.slick-prev {
  left: -25px; }
  [dir="rtl"] .slick-prev {
    left: auto;
    right: -25px; }
  .slick-prev:before {
    content: "←"; }
    [dir="rtl"] .slick-prev:before {
      content: "→"; }

.slick-next {
  right: -25px; }
  [dir="rtl"] .slick-next {
    left: -25px;
    right: auto; }
  .slick-next:before {
    content: "→"; }
    [dir="rtl"] .slick-next:before {
      content: "←"; }

/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 30px; }

.slick-dots {
  position: absolute;
  bottom: -25px;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%; }
  .slick-dots li {
    position: relative;
    display: inline-block;
    height: 20px;
    width: 20px;
    margin: 0 5px;
    padding: 0;
    cursor: pointer; }
    .slick-dots li button {
      border: 0;
      background: transparent;
      display: block;
      height: 20px;
      width: 20px;
      outline: none;
      line-height: 0px;
      font-size: 0px;
      color: transparent;
      padding: 5px;
      cursor: pointer; }
      .slick-dots li button:hover, .slick-dots li button:focus {
        outline: none; }
        .slick-dots li button:hover:before, .slick-dots li button:focus:before {
          opacity: 1; }
      .slick-dots li button:before {
        position: absolute;
        top: 0;
        left: 0;
        content: "•";
        width: 20px;
        height: 20px;
        font-family: "slick";
        font-size: 6px;
        line-height: 20px;
        text-align: center;
        color: black;
        opacity: 0.25;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale; }
    .slick-dots li.slick-active button:before {
      color: black;
      opacity: 0.75; }

.mfp-bg {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1042;
  overflow: hidden;
  position: fixed;
  background: #0b0b0b;
  opacity: 0.8; }

.mfp-wrap {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1043;
  position: fixed;
  outline: none !important;
  -webkit-backface-visibility: hidden; }

.mfp-container {
  text-align: center;
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  padding: 0 8px;
  box-sizing: border-box; }

.mfp-container:before {
  content: '';
  display: inline-block;
  height: 100%;
  vertical-align: middle; }

.mfp-align-top .mfp-container:before {
  display: none; }

.mfp-content {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  margin: 0 auto;
  text-align: left;
  z-index: 1045; }

.mfp-inline-holder .mfp-content,
.mfp-ajax-holder .mfp-content {
  width: 100%;
  cursor: auto; }

.mfp-ajax-cur {
  cursor: progress; }

.mfp-zoom-out-cur, .mfp-zoom-out-cur .mfp-image-holder .mfp-close {
  cursor: -moz-zoom-out;
  cursor: -webkit-zoom-out;
  cursor: zoom-out; }

.mfp-zoom {
  cursor: pointer;
  cursor: -webkit-zoom-in;
  cursor: -moz-zoom-in;
  cursor: zoom-in; }

.mfp-auto-cursor .mfp-content {
  cursor: auto; }

.mfp-close,
.mfp-arrow,
.mfp-preloader,
.mfp-counter {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none; }

.mfp-loading.mfp-figure {
  display: none; }

.mfp-hide {
  display: none !important; }

.mfp-preloader {
  color: #CCC;
  position: absolute;
  top: 50%;
  width: auto;
  text-align: center;
  margin-top: -0.8em;
  left: 8px;
  right: 8px;
  z-index: 1044; }
  .mfp-preloader a {
    color: #CCC; }
    .mfp-preloader a:hover {
      color: #FFF; }

.mfp-s-ready .mfp-preloader {
  display: none; }

.mfp-s-error .mfp-content {
  display: none; }

button.mfp-close, button.mfp-arrow {
  overflow: visible;
  cursor: pointer;
  background: transparent;
  border: 0;
  -webkit-appearance: none;
  display: block;
  outline: none;
  padding: 0;
  z-index: 1046;
  box-shadow: none;
  touch-action: manipulation; }
button::-moz-focus-inner {
  padding: 0;
  border: 0; }

.mfp-close {
  width: 44px;
  height: 44px;
  line-height: 44px;
  position: absolute;
  right: 0;
  top: 0;
  text-decoration: none;
  text-align: center;
  opacity: 0.65;
  padding: 0 0 18px 10px;
  color: #FFF;
  font-style: normal;
  font-size: 28px;
  font-family: Arial, Baskerville, monospace; }
  .mfp-close:hover, .mfp-close:focus {
    opacity: 1; }
  .mfp-close:active {
    top: 1px; }

.mfp-close-btn-in .mfp-close {
  color: #333; }

.mfp-image-holder .mfp-close,
.mfp-iframe-holder .mfp-close {
  color: #FFF;
  right: -6px;
  text-align: right;
  padding-right: 6px;
  width: 100%; }

.mfp-counter {
  position: absolute;
  top: 0;
  right: 0;
  color: #CCC;
  font-size: 12px;
  line-height: 18px;
  white-space: nowrap; }

.mfp-arrow {
  position: absolute;
  opacity: 0.65;
  margin: 0;
  top: 50%;
  margin-top: -55px;
  padding: 0;
  width: 90px;
  height: 110px;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }
  .mfp-arrow:active {
    margin-top: -54px; }
  .mfp-arrow:hover, .mfp-arrow:focus {
    opacity: 1; }
  .mfp-arrow:before, .mfp-arrow:after {
    content: '';
    display: block;
    width: 0;
    height: 0;
    position: absolute;
    left: 0;
    top: 0;
    margin-top: 35px;
    margin-left: 35px;
    border: medium inset transparent; }
  .mfp-arrow:after {
    border-top-width: 13px;
    border-bottom-width: 13px;
    top: 8px; }
  .mfp-arrow:before {
    border-top-width: 21px;
    border-bottom-width: 21px;
    opacity: 0.7; }

.mfp-arrow-left {
  left: 0; }
  .mfp-arrow-left:after {
    border-right: 17px solid #FFF;
    margin-left: 31px; }
  .mfp-arrow-left:before {
    margin-left: 25px;
    border-right: 27px solid #3F3F3F; }

.mfp-arrow-right {
  right: 0; }
  .mfp-arrow-right:after {
    border-left: 17px solid #FFF;
    margin-left: 39px; }
  .mfp-arrow-right:before {
    border-left: 27px solid #3F3F3F; }

.mfp-iframe-holder {
  padding-top: 40px;
  padding-bottom: 40px; }
  .mfp-iframe-holder .mfp-content {
    line-height: 0;
    width: 100%;
    max-width: 900px; }
  .mfp-iframe-holder .mfp-close {
    top: -40px; }

.mfp-iframe-scaler {
  width: 100%;
  height: 0;
  overflow: hidden;
  padding-top: 56.25%; }
  .mfp-iframe-scaler iframe {
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    background: #000; }

/* Main image in popup */
img.mfp-img {
  width: auto;
  max-width: 100%;
  height: auto;
  display: block;
  line-height: 0;
  box-sizing: border-box;
  padding: 40px 0 40px;
  margin: 0 auto; }

/* The shadow behind the image */
.mfp-figure {
  line-height: 0; }
  .mfp-figure:after {
    content: '';
    position: absolute;
    left: 0;
    top: 40px;
    bottom: 40px;
    display: block;
    right: 0;
    width: auto;
    height: auto;
    z-index: -1;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
    background: #444; }
  .mfp-figure small {
    color: #BDBDBD;
    display: block;
    font-size: 12px;
    line-height: 14px; }
  .mfp-figure figure {
    margin: 0; }

.mfp-bottom-bar {
  margin-top: -36px;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  cursor: auto; }

.mfp-title {
  text-align: left;
  line-height: 18px;
  color: #F3F3F3;
  word-wrap: break-word;
  padding-right: 36px; }

.mfp-image-holder .mfp-content {
  max-width: 100%; }

.mfp-gallery .mfp-image-holder .mfp-figure {
  cursor: pointer; }

@media screen and (max-width: 800px) and (orientation: landscape), screen and (max-height: 300px) {
  /**
   * Remove all paddings around the image on small screen
   */
  .mfp-img-mobile .mfp-image-holder {
    padding-left: 0;
    padding-right: 0; }
  .mfp-img-mobile img.mfp-img {
    padding: 0; }
  .mfp-img-mobile .mfp-figure:after {
    top: 0;
    bottom: 0; }
  .mfp-img-mobile .mfp-figure small {
    display: inline;
    margin-left: 5px; }
  .mfp-img-mobile .mfp-bottom-bar {
    background: rgba(0, 0, 0, 0.6);
    bottom: 0;
    margin: 0;
    top: auto;
    padding: 3px 5px;
    position: fixed;
    box-sizing: border-box; }
    .mfp-img-mobile .mfp-bottom-bar:empty {
      padding: 0; }
  .mfp-img-mobile .mfp-counter {
    right: 5px;
    top: 3px; }
  .mfp-img-mobile .mfp-close {
    top: 0;
    right: 0;
    width: 35px;
    height: 35px;
    line-height: 35px;
    background: rgba(0, 0, 0, 0.6);
    position: fixed;
    text-align: center;
    padding: 0; } }
@media all and (max-width: 900px) {
  .mfp-arrow {
    -webkit-transform: scale(0.75);
    transform: scale(0.75); }

  .mfp-arrow-left {
    -webkit-transform-origin: 0;
    transform-origin: 0; }

  .mfp-arrow-right {
    -webkit-transform-origin: 100%;
    transform-origin: 100%; }

  .mfp-container {
    padding-left: 6px;
    padding-right: 6px; } }
/*  -------------------------------------------
    SMARTMENUS
-----------------------------------------------*/
#ab-menu-button {
  display: block;
  float: right;
  width: 48px;
  height: 48px;
  background: transparent url("../graphics/menu-open-colored.png") center center no-repeat;
  background-size: 30px 30px;
  text-indent: -9999px;
  outline: none; }

#ab-menu-button:before {
  content: ''; }

#ab-menu-button.collapsed:before {
  content: ''; }

/*  -- SMARTMENUS ------------------------- */
#ab-main-menu.collapsed {
  display: none; }

.sm-clean ul a, .sm-clean ul a:hover, .sm-clean ul a:focus, .sm-clean ul a:active {
  font-size: 0.85em;
  border-left: 8px solid transparent; }

@media (min-width: 768px) {
  #ab-menu-button {
    display: none; }

  #ab-main-menu {
    position: relative;
    z-index: 9999; }

  #ab-main-menu.collapsed {
    display: block; }

  /*  -- MOBILE ONLY ------------------------- */
  .sm-clean li.ab-mobile-only {
    display: none; }

  /*  -- SMARTMENUS ------------------------- */
  .sm-clean {
    background: transparent; }

  .sm-clean a, .sm-clean a:hover, .sm-clean a:focus, .sm-clean a:active, .sm-clean a.highlighted {
    padding: 5px 0 3px 0;
    color: #C10230;
    font-family: "SecondaryFont", sans-serif;
    font-weight: normal;
    line-height: 17px;
    text-decoration: none; }

  .sm-clean a.current {
    color: #fff; }

  .sm-clean ul a:hover, .sm-clean ul a:focus, .sm-clean ul a:active, .sm-clean ul a.highlighted {
    background: transparent;
    color: #C10230; }

  .sm-clean ul a.current {
    color: #C10230; }

  .sm-clean > li:first-child > a {
    padding-left: 0px; }

  .sm-clean > li:last-child {
    padding-right: 0px; }

  .sm-clean a.has-submenu {
    padding-right: 0; }

  .sm-clean a, .sm-clean a:hover, .sm-clean a:focus, .sm-clean a:active, .sm-clean a.highlighted {
    padding: 5px 0 3px 0;
    color: #383838;
    border-bottom: 3px transparent solid;
    font-size: 1.0em;
    font-family: "SecondaryFont", sans-serif; }

  .sm-clean a:hover, .sm-clean a:focus, .sm-clean a:active, .sm-clean a.highlighted {
    color: #C10230;
    border-bottom: 3px #fff solid;
    -webkit-transition: all 0.5s ease;
    transition: all 0.5s ease; }

  .sm-clean a.ab-search-form-link:hover, .sm-clean a.ab-search-form-link-not-home:hover {
    color: #C10230;
    border-bottom: none; }

  .sm-clean > li > a {
    padding: 5px 0 3px 0;
    margin: 0 10px;
    font-size: 0.815em; }

  .sm-clean a span.sub-arrow {
    border-width: 0px; }

  .sm-clean > li > ul:before,
  .sm-clean > li > ul:after {
    content: '';
    position: absolute;
    top: -18px;
    left: 30px;
    width: 0;
    height: 0;
    overflow: hidden;
    border-width: 0px;
    border-style: dashed dashed solid dashed;
    border-color: transparent transparent #C10230 transparent; }

  .sm-clean > li > ul:after {
    top: -16px;
    left: 31px;
    border-width: 0px;
    border-color: transparent transparent #C10230 transparent; }

  .sm-clean ul {
    margin: 0;
    padding: 0;
    border: 0;
    -webkit-border-radius: 0px !important;
    -moz-border-radius: 0px !important;
    -ms-border-radius: 0px !important;
    -o-border-radius: 0px !important;
    border-radius: 0px !important; }

  .sm-clean ul a, .sm-clean ul a:hover, .sm-clean ul a:focus, .sm-clean ul a:active, .sm-clean ul a.highlighted {
    border: 0 !important;
    font-size: 0.825em;
    padding: 10px 20px;
    color: #fff;
    background: #C10230; }

  .sm-clean ul a:hover, .sm-clean ul a:focus, .sm-clean ul a:active, .sm-clean ul a.highlighted {
    background: #fff;
    color: #C10230;
    font-weight: normal; }

  .sm-clean ul a.current {
    color: #C10230; }

  .sm-clean ul a.disabled {
    background: white;
    color: #cccccc; }

  .sm-clean ul a.has-submenu {
    padding-right: 20px; }

  .sm-clean ul a span.sub-arrow {
    right: 8px;
    top: 50%;
    margin-top: -5px;
    border-width: 5px;
    border-style: dashed dashed dashed solid;
    border-color: transparent transparent transparent #000; }

  /*  -- BUTTON ------------------------- */
  .sm-clean li.ab-nav-button a {
    padding-right: 0;
    font-size: 0.825em;
    outline: none; }

  .sm-clean li.ab-nav-button a:hover {
    color: #fff;
    outline: none; }

  .sm-clean li.ab-nav-button a div {
    position: relative;
    top: -10px;
    color: #C10230;
    background: #fff;
    margin: 0;
    padding: 10px;
    border-radius: 5px; }

  .sm-clean li.ab-nav-button a:hover div {
    color: #C10230;
    background: #fff; } }
@media (min-width: 1024px) {
  .sm-clean a, .sm-clean a:hover, .sm-clean a:focus, .sm-clean a:active, .sm-clean a.highlighted {
    font-size: 0.85em; }

  .sm-clean > li > a {
    padding: 5px 0 3px 0;
    margin: 0 20px;
    font-size: 0.85em; } }
/*  -------------------------------------------
    STANDARD
-----------------------------------------------*/
body {
  margin: 0;
  padding: 0;
  background: #fff;
  color: #5A5A5A;
  font-family: "PrimaryFont", sans-serif; }

p {
  font-family: "PrimaryFont", sans-serif;
  color: #5A5A5A;
  line-height: 150%; }

h1 {
  font-family: "PrimaryFont", sans-serif;
  font-weight: normal;
  line-height: 125%;
  font-size: 1.75em; }

h2 {
  font-family: "PrimaryFont", sans-serif;
  font-weight: normal;
  line-height: 125%;
  font-size: 1.35em; }

h3 {
  font-family: "PrimaryFont", sans-serif;
  font-weight: normal;
  line-height: 125%;
  font-size: 1.25em; }

h4 {
  font-family: "PrimaryFont", sans-serif;
  font-weight: normal;
  line-height: 125%;
  font-size: 1.15em; }

h5 {
  font-family: "PrimaryFont", sans-serif;
  font-weight: normal; }

h6 {
  font-family: "PrimaryFont", sans-serif;
  font-weight: normal; }

section {
  outline: none; }

@media (min-width: 768px) {
  h1 {
    font-size: 2.25em; }

  h2 {
    font-size: 1.75em; }

  h3 {
    font-size: 1.35em; }

  h4 {
    font-size: 1.25em; }

  h5 {
    font-size: 1.0em; } }
@media (min-width: 1280px) {
  h1 {
    font-size: 2.75em; }

  h2 {
    font-size: 2.25em; }

  h3 {
    font-size: 1.75em; }

  h4 {
    font-size: 1.35em; } }
@media (min-width: 1366px) {
  h1 {
    font-size: 3.0em; }

  h2 {
    font-size: 2.5em; } }
* {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }

*:focus {
  outline: 0; }

a {
  color: #5A5A5A;
  text-decoration: none;
  outline: none; }

a:link {
  outline: none; }

a:hover {
  color: #C10230; }

a:active {
  outline: none; }

a:visited {
  outline: none; }

.ab-clear {
  clear: both;
  outline: none; }

.ab-space {
  height: 20px;
  clear: both; }

.ab-space-extra {
  height: 50px;
  clear: both; }

.ab-txt-normal {
  font-weight: normal; }

.ab-txt-bold {
  font-weight: bold; }

.ab-txt-italic {
  font-style: italic; }

.ab-txt-underline {
  text-decoration: underline; }

.ab-txt-left {
  text-align: left; }

.ab-txt-right {
  text-align: right; }

.ab-txt-center {
  text-align: center; }

.ab-grid-vcenter {
  display: grid;
  align-items: center; }

.ab-flex-center {
  display: flex;
  justify-content: center;
  align-items: center; }

.ab-box-center {
  margin: 0px auto; }

.ab-box-left {
  float: left; }

.ab-box-right {
  float: right; }

.ab-txt-light {
  font-weight: normal; }

.ab-font-light {
  font-weight: normal; }

.ab-font-normal {
  font-weight: normal; }

.ab-font-bold {
  font-weight: bold; }

.ab-txt-shadow {
  text-shadow: 0 0 10px #000; }

.ab-txt-light {
  font-weight: normal; }

.ab-txt-verysmall {
  font-size: 0.625em; }

.ab-txt-small {
  font-size: 0.725em; }

.ab-txt-medium {
  font-size: 0.85em; }

.ab-txt-big {
  font-size: 1.25em; }

.ab-txt-bigger {
  font-size: 1.55em;
  font-weight: bold; }

.ab-txt-bigger-normal {
  font-size: 1.55em;
  font-weight: normal; }

.ab-txt-verybig {
  font-size: 2.0em; }

.ab-txt-highlight {
  font-size: 1.125em;
  font-weight: bold; }

.ab-txt-color-primary {
  color: #C10230; }

.ab-txt-color-white {
  color: #fff; }

.ab-txt-color-black {
  color: #000; }

.ab-line-small {
  line-height: 110%; }

.ab-line-normal {
  line-height: normal; }

.ab-line-big {
  line-height: 150%; }

.ab-no-margin {
  margin: 0; }

.ab-no-margin-top {
  margin-top: 0px; }

.ab-no-margin-bottom {
  margin-bottom: 0px; }

.ab-no-padding {
  padding: 0; }

.ab-no-padding-top {
  padding-top: 0px; }

.ab-padding-top-big {
  padding-top: 25px; }

.ab-no-padding-bottom {
  padding-bottom: 0px; }

.ab-padding-top-50 {
  padding-top: 50px; }

.ab-padding-bottom-50 {
  padding-bottom: 50px; }

.ab-padding-left-50 {
  padding-left: 50px; }

.ab-padding-right-50 {
  padding-right: 50px; }

.ab-padding-75 {
  padding: 75px 0px; }

.ab-padding-50 {
  padding: 50px 0px; }

.ab-padding-20 {
  padding: 20px 0px; }

.ab-img-reponsive {
  width: 100%;
  height: auto;
  outline: none;
  border: 0;
  padding: 0;
  margin: 0; }

a.ab-txt-color-white {
  color: #fff; }

a.ab-txt-color-white:hover.ab-txt-color-white {
  color: #fff; }

a.ab-txt-color-black {
  color: #000; }

a.ab-txt-color-black:hover {
  color: #000; }

.slick-slide {
  outline: none; }

/*  -------------------------------------------
    TEXT SIZE
-----------------------------------------------*/
.ab-vtxt-nm {
  font-size: 1.0em; }

.ab-vtxt-lg {
  font-size: 1.15em; }

.ab-vtxt-smlg {
  font-size: 0.5em; }

@media (min-width: 600px) {
  .ab-vtxt-smlg {
    font-size: 1.05em; } }
@media (min-width: 768px) {
  .ab-vtxt-nm {
    font-size: 1.05em; }

  .ab-vtxt-lg {
    font-size: 1.25em; }

  .ab-vtxt-smlg {
    font-size: 1.15em; } }
@media (min-width: 1024px) {
  .ab-vtxt-smlg {
    font-size: 1.25em; } }
@media (min-width: 1280px) {
  .ab-vtxt-nm {
    font-size: 1.15em; }

  .ab-vtxt-lg {
    font-size: 1.40em; }

  .ab-vtxt-smlg {
    font-size: 1.55em; } }
@media (min-width: 1500px) {
  .ab-vtxt-nm {
    font-size: 1.25em; }

  .ab-vtxt-lg {
    font-size: 1.55em; }

  .ab-vtxt-smlg {
    font-size: 1.75em; } }
/*  -------------------------------------------
    BACK TO TOP
-----------------------------------------------*/
.ab-top {
  display: inline-block;
  width: 40px;
  height: 41px;
  position: fixed;
  bottom: 10px;
  right: 10px;
  z-index: 10;
  overflow: hidden;
  text-indent: 100%;
  white-space: nowrap;
  background: transparent url(../graphics/ab-arrow-up-small.png) no-repeat top center;
  visibility: hidden;
  opacity: 0;
  -webkit-transition: opacity .3s 0s, visibility 0s .3s;
  -moz-transition: opacity .3s 0s, visibility 0s .3s;
  transition: opacity .3s 0s, visibility 0s .3s; }

.ab-top.ab-is-visible, .ab-top.ab-fade-out, .no-touch .ab-top:hover {
  -webkit-transition: opacity .3s 0s, visibility 0s 0s;
  -moz-transition: opacity .3s 0s, visibility 0s 0s;
  transition: opacity .3s 0s, visibility 0s 0s; }

.ab-top.ab-is-visible {
  visibility: visible;
  opacity: 1;
  outline: none;
  border: 0; }

.ab-top.ab-fade-out {
  opacity: .5; }

.no-touch .ab-top:hover {
  opacity: 1;
  outline: none;
  border: 0; }

@media (min-width: 768px) {
  .ab-top {
    right: 20px;
    bottom: 20px; } }
@media (min-width: 1024px) {
  .ab-top {
    width: 80px;
    height: 81px;
    right: 30px;
    bottom: 30px;
    background: transparent url("../graphics/ab-arrow-up.png") no-repeat top center; } }
/*  -------------------------------------------
    mfp-with-anim
-----------------------------------------------*/
.mfp-zoom-in .mfp-with-anim {
  opacity: 0;
  transition: all 0.2s ease-in-out;
  transform: scale(0.8); }

.mfp-zoom-in.mfp-bg {
  opacity: 0;
  transition: all 0.3s ease-out; }

.mfp-zoom-in.mfp-ready .mfp-with-anim {
  opacity: 1;
  transform: scale(1); }

.mfp-zoom-in.mfp-ready.mfp-bg {
  opacity: 0.8; }

.mfp-zoom-in.mfp-removing .mfp-with-anim {
  transform: scale(0.8);
  opacity: 0; }

.mfp-zoom-in.mfp-removing.mfp-bg {
  opacity: 0; }

/*  -------------------------------------------
HEADER:
-----------------------------------------------*/
.ab-header-margin-top {
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: 0;
  height: 68px; }

header {
  box-sizing: border-box;
  width: 100%;
  z-index: 1000;
  margin: 0;
  padding: 0;
  position: fixed;
  top: 0; }

.ab-header {
  box-sizing: border-box;
  margin: 0;
  padding: 10px 0;
  background: white;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease; }

.ab-header-container {
  box-sizing: border-box;
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
  padding: 0px 10px; }

.ab-header-logo-link {
  display: block;
  margin: 0;
  padding: 0;
  width: 104px;
  height: 48px;
  float: left; }

.ab-header-logo {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  text-indent: -9999px;
  width: 104px;
  height: 48px;
  background: url("../graphics/logo-tagline-sm.png") top left no-repeat;
  background-size: cover; }

.ab-header-container-grid {
  box-sizing: border-box;
  margin: 0;
  padding: 0; }

#ab-top-menu-container {
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: 0;
  text-align: right; }
  #ab-top-menu-container .ab-top-menu-social {
    display: none; }

#ab-main-menu-container {
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: 0;
  float: right; }

.ab-top-menu-container-txt, .ab-client-login-link {
  display: none; }

.sm-clean > li > a.ab-main-menu-search {
  display: none; }

.ab-header-menu-btn {
  box-sizing: border-box;
  margin: 0;
  padding: 0 40px 0 0;
  cursor: pointer;
  float: right;
  height: 48px;
  background: url("../graphics/menu-open-colored.png") right no-repeat;
  background-size: 20px 20px; }

.ab-header-menu-btn span {
  display: none;
  color: #3a3a3c;
  font-weight: bold;
  font-size: 1.2em;
  padding: 12px 0 0 0; }

.ab-header.ab-header-fixed {
  background: white; }

.ab-header.ab-header-fixed .ab-header-menu-btn {
  background: url("../graphics/menu-open-colored.png") right no-repeat;
  background-size: 20px 20px; }

.ab-header.ab-header-fixed .ab-header-menu-btn span {
  color: #3a3a3c; }

.ab-client-login-btn {
  box-sizing: border-box;
  margin: 0;
  padding: 5px 15px 5px 30px;
  background: #3a3a3c url("../graphics/icon-compass-white.png?NOCACHE=1") 5px 5px no-repeat;
  background-size: 20px 20px;
  color: #fff;
  border-radius: 3px;
  font-size: 0.825em; }

.ab-client-login-btn:hover {
  color: #fff;
  background-color: #C10230; }

@media (min-width: 768px) {
  .ab-header-margin-top {
    height: 90px; }

  .ab-header {
    padding: 10px 0; }

  .ab-header-logo-link {
    width: 163px;
    height: 75px; }

  .ab-header-logo {
    width: 163px;
    height: 75px;
    background: url("../graphics/logo-tagline-sm.png") top left no-repeat;
    background-size: cover; }

  .ab-top-menu-container-txt, .ab-client-login-link {
    display: inline-block; }

  .ab-top-menu-container-txt {
    font-family: "PrimaryFontBold", sans-serif;
    margin-right: 25px; }

  #ab-top-menu-container {
    margin: 0;
    padding: 12px 0 7px 0; }
    #ab-top-menu-container .ab-top-menu-social {
      display: inline-block;
      margin: 0;
      padding: 0;
      margin-right: 20px;
      font-size: 1.5em;
      position: relative;
      top: 3px; }

  #ab-main-menu-container {
    width: unset; }

  .sm-clean > li > a.ab-main-menu-search,
  .sm-clean > li > a.ab-main-menu-search:visited,
  .sm-clean > li > a.ab-main-menu-search:hover,
  .sm-clean > li > a.ab-main-menu-search:active {
    display: block;
    box-sizing: border-box;
    width: 18px;
    height: 16px;
    margin: 0 0 3px 10px;
    padding: 0;
    background: url("../graphics/search-form-button.png") top left no-repeat;
    background-size: cover;
    border: none;
    text-indent: -9999px; } }
@media (min-width: 1024px) {
  .ab-header-container {
    padding: 0px 25px; }

  .ab-header-margin-top {
    height: 90px; }

  .ab-header-logo-link {
    width: 422px;
    height: 70px; }

  .ab-header-logo {
    width: 422px;
    height: 70px;
    background: url("../graphics/logo-tagline.png") top left no-repeat;
    background-size: cover; } }
@media (min-width: 1280px) {
  .ab-header-container {
    padding: 0px 50px; }

  .ab-header-margin-top {
    height: 105px; }

  .ab-header-logo-link {
    width: 512px;
    height: 85px; }

  .ab-header-logo {
    width: 512px;
    height: 85px;
    background: url("../graphics/logo-tagline.png") top left no-repeat;
    background-size: cover; } }
@media (min-width: 1366px) {
  .ab-header-container {
    width: 100%;
    max-width: 5000px;
    margin: 0 auto;
    padding: 0px 50px; } }
/*  -------------------------------------------
VIDEO COVER
-----------------------------------------------*/
#ab-cover-video {
  display: none;
  box-sizing: border-box;
  outline: none;
  border: 0;
  padding: 0;
  margin: 0;
  width: 100%;
  overflow: hidden;
  position: relative; }

#ab-cover-video-mobile {
  display: block;
  box-sizing: border-box;
  outline: none;
  border: 0;
  padding: 0;
  margin: 0;
  width: 100%;
  overflow: hidden;
  position: relative; }

#ab-cover-video video, #ab-cover-video-mobile video {
  display: block;
  box-sizing: border-box;
  width: 100%;
  outline: none;
  border: 0;
  padding: 0;
  margin: 0; }

.ab-bg-video {
  display: block;
  width: 100%;
  height: auto;
  outline: none;
  border: 0;
  padding: 0;
  margin: 0;
  clip-path: inset(2px 2px); }

.ab-cover-video-link {
  display: inline-block;
  box-sizing: border-box;
  padding: 0 55px 0 0;
  margin: 0;
  color: #C10230;
  font-size: 0.875em;
  background: url("../graphics/cover-arrow-short.png") center right no-repeat;
  background-size: 50px 6px;
  position: absolute;
  bottom: 0px;
  left: 5.5%;
  opacity: 0;
  transition: all 0.5s ease; }

#ab-cover-video-mobile .ab-cover-video-link {
  position: absolute;
  bottom: 0px;
  left: 5.5%;
  opacity: 0;
  transition: all 0.5s ease; }

.ab-cover-video-link:hover {
  color: #C10230;
  background: url("../graphics/cover-arrow-long.png") center right no-repeat;
  background-size: 50px 6px; }

.ab-cover-video-link-show {
  position: absolute;
  bottom: 30%;
  left: 5.5%;
  opacity: 1;
  transition: all 0.5s ease; }

#ab-cover-video-mobile .ab-cover-video-link-show {
  position: absolute;
  bottom: 47%;
  left: 5.5%;
  opacity: 1;
  transition: all 0.5s ease; }

a#ab-cover-mobile-youtube-link {
  display: block;
  width: 100%;
  height: 22%;
  border: 0;
  padding: 0;
  margin: 0;
  position: absolute;
  bottom: 0px; }

a#ab-cover-play-btn {
  box-sizing: border-box;
  outline: none;
  border: 0;
  padding: 0;
  margin: 0;
  width: 100px;
  height: 100px;
  background: url("../graphics/play-icon.png") top left no-repeat;
  background-size: cover;
  position: absolute;
  bottom: -10%;
  left: calc(50% - 50px);
  opacity: 0;
  transition: all 0.5s ease; }

a:hover#ab-cover-play-btn {
  background: url("../graphics/play-icon-red.png") top left no-repeat;
  background-size: cover; }

a#ab-cover-play-btn.ab-cover-play-btn-show {
  position: absolute;
  bottom: 20%;
  left: calc(50% - 50px);
  opacity: 1;
  transition: all 0.5s ease; }

a#ab-cover-mobile-play-btn {
  box-sizing: border-box;
  outline: none;
  border: 0;
  padding: 0;
  margin: 0;
  width: 100px;
  height: 100px;
  background: url("../graphics/play-icon.png") top left no-repeat;
  background-size: cover;
  position: absolute;
  bottom: -10%;
  left: calc(50% - 50px);
  opacity: 0;
  transition: all 0.5s ease; }

a:hover#ab-cover-mobile-play-btn {
  background: url("../graphics/play-icon-red.png") top left no-repeat;
  background-size: cover; }

a#ab-cover-mobile-play-btn.ab-cover-mobile-play-btn {
  position: absolute;
  bottom: 25%;
  left: calc(50% - 50px);
  opacity: 1;
  transition: all 0.5s ease; }

@media (min-width: 768px) {
  #ab-cover-video {
    display: block; }

  #ab-cover-video-mobile {
    display: none; }

  a#ab-cover-youtube-link {
    display: block;
    width: 35%;
    height: 22%;
    border: 0;
    padding: 0;
    margin: 0;
    position: absolute;
    top: 40%;
    right: 0px; }

  a#ab-cover-play-btn.ab-cover-play-btn-show {
    position: absolute;
    bottom: 10%;
    left: calc(50% - 50px);
    opacity: 1;
    transition: all 0.5s ease; } }
@media (min-width: 1024px) {
  a#ab-cover-play-btn.ab-cover-play-btn-show {
    position: absolute;
    bottom: 20%;
    left: calc(50% - 50px);
    opacity: 1;
    transition: all 0.5s ease; } }
@media (min-width: 1366px) {
  a#ab-cover-play-btn.ab-cover-play-btn-show {
    position: absolute;
    bottom: 25%;
    left: calc(50% - 50px);
    opacity: 1;
    transition: all 0.5s ease; } }
@media (min-width: 2000px) {
  .ab-cover-video-link {
    font-size: 1.15em; } }
@media (min-width: 3000px) {
  .ab-cover-video-link {
    font-size: 1.25em; } }
/*  -------------------------------------------
FOOTER:
-----------------------------------------------*/
footer {
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: 50px 0;
  color: #fff;
  background: #2f3134; }

footer p {
  color: #fff;
  margin-top: 0;
  font-family: "PrimaryFontLight", sans-serif; }

footer a {
  color: #fff;
  text-decoration: none; }

.ab-footer-grid, .ab-footer-logo, .ab-footer-contact, .ab-footer-menu, .ab-footer-menu-item, .ab-footer-social, .ab-footer-search, .ab-footer-copy, .ab-footer-legal {
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: 0; }

.ab-footer-grid {
  display: grid;
  grid-template-columns: 250px auto auto; }

.ab-footer-logo {
  grid-column: 1 / 4;
  padding: 50px 0; }

.ab-footer-logo img {
  display: block;
  width: 292px;
  height: 100px; }

.ab-footer-contact {
  grid-column: 1 / 4; }

.ab-footer-menu {
  grid-column: 2 / 4;
  display: none;
  grid-template-columns: auto auto auto auto; }

.ab-footer-menu-item ul {
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: 0 0 50px 0;
  list-style: none; }

.ab-footer-menu-item ul li {
  box-sizing: border-box;
  width: 100%;
  margin: 0;
  padding: 12px 0 0 0;
  font-family: "PrimaryFontLight", sans-serif; }

.ab-footer-social {
  grid-column: 1 / 4;
  padding: 75px 0 10px 0; }

.ab-footer-social strong {
  display: inline-block;
  padding-right: 5px; }

.ab-footer-social a {
  display: inline-block;
  width: 30px;
  height: 30px;
  padding: 10px 5px 0 5px;
  margin: 5px;
  font-size: 1.35em;
  text-align: center;
  border: 1px #fff solid;
  border-radius: 25px; }

.ab-footer-social a:hover {
  color: #C10230;
  border: 1px #C10230 solid; }

.ab-footer-search {
  display: none;
  grid-column: 3 / 4;
  padding: 75px 0 10px 0; }

.ab-footer-copy {
  font-size: 0.725em;
  grid-column: 1 / 4;
  border-top: 1px #fff solid;
  padding: 35px 0; }

.ab-footer-legal {
  font-size: 0.725em;
  grid-column: 1 / 4;
  border-top: 1px #fff solid;
  padding: 35px 0; }

@media (min-width: 768px) {
  .ab-footer-contact {
    grid-column: 1 / 2; }

  .ab-footer-contact p {
    line-height: 175%; }

  .ab-footer-menu {
    grid-column: 2 / 4;
    display: grid;
    grid-template-columns: auto auto; }

  .ab-footer-social {
    grid-column: 1 / 3; }

  .ab-footer-search {
    display: block;
    text-align: right; }

  .ab-footer-search form {
    position: relative;
    overflow: hidden;
    display: inline-block;
    background: #fff;
    width: 40px;
    height: 40px;
    padding: 0;
    border: 1px #fff solid;
    border-radius: 25px;
    margin: 5px 0;
    transition: all 0.25s ease; }

  .ab-footer-search form.ab-footer-search-on {
    width: 260px; }

  .ab-footer-search form input[type="text"] {
    position: absolute;
    top: 0;
    left: 0px;
    display: inline-block;
    box-sizing: border-box;
    width: 0px;
    height: 40px;
    margin: 0 42px 0 15px;
    padding: 0;
    background: transparent;
    border: 0px;
    outline: none; }

  .ab-footer-search form input.ab-footer-search-on {
    float: none;
    width: auto;
    overflow: hidden; }

  .ab-footer-search form input[type="text"]:focus {
    outline: none; }

  .ab-footer-search form input[type="submit"] {
    position: absolute;
    top: 0;
    right: 0px;
    display: inline-block;
    box-sizing: border-box;
    margin: 1px;
    padding: 0;
    background: #fff url("../graphics/search-form-button.png") 11px 10px no-repeat;
    color: #3c3c3c;
    width: 40px;
    height: 40px;
    outline: none;
    border: 0px;
    border-radius: 25px;
    text-indent: -9999px; } }
@media (min-width: 1024px) {
  .ab-footer-logo {
    padding: 50px 0 75px 0; }

  .ab-footer-menu {
    grid-column: 2 / 4;
    display: grid;
    grid-template-columns: auto auto auto auto; } }
/*  -------------------------------------------
BUTTONS
-----------------------------------------------*/
/*  -------------------------------------------
    GENERAL
-----------------------------------------------*/
::placeholder {
  color: #939598; }

.ab-form {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  border: 0; }

.ab-form input[type=text] {
  box-sizing: border-box;
  padding: 15px 25px;
  margin: 6px 0;
  width: 100%;
  border: 0;
  border-radius: 5px; }

.ab-form input[type=email] {
  box-sizing: border-box;
  padding: 15px 25px;
  margin: 6px 0;
  width: 100%;
  border: 0;
  border-radius: 5px; }

.ab-form button {
  box-sizing: border-box;
  padding: 15px 50px;
  margin: 6px 0;
  border: 0;
  border-radius: 5px;
  background: #C10230;
  color: #fff; }

.ab-form button:hover {
  background: #5A5A5A; }

/*  -------------------------------------------
    FOOTER: CONTACT FORM
-----------------------------------------------*/
.ab-footer-form {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  background: url("../graphics/ab-footer-form.png") center left repeat-x; }

.ab-footer-form-dark {
  background: url("../graphics/ab-footer-form-dark.png") center left repeat-x; }

.ab-footer-form-bg {
  box-sizing: border-box;
  padding: 10px;
  margin: 0;
  width: 100%;
  border-radius: 5px;
  background: url("../graphics/ab-footer-form-bg.jpg") center center no-repeat;
  background-size: cover; }

.ab-footer-form h2 {
  color: #fff;
  margin: 0; }

.ab-footer-form p {
  color: #fff;
  margin: 0 0 35px 0; }

.ab-footer-form form {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  display: grid;
  grid-template-rows: auto auto;
  grid-row-gap: 20px; }

.ab-footer-form-grid {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  display: grid;
  grid-template-columns: auto;
  grid-row-gap: 20px; }

.ab-footer-form form input {
  box-sizing: border-box;
  padding: 15px 25px;
  margin: 0;
  width: 100%;
  border: 0;
  border-radius: 5px; }

.ab-footer-form form button {
  box-sizing: border-box;
  padding: 15px 25px;
  margin: 0;
  width: 100%;
  border: 0;
  border-radius: 5px;
  background: #5A5A5A;
  color: #fff; }

.ab-footer-form form button:hover {
  background: #C10230; }

.ab-footer-recaptcha-container {
  box-sizing: border-box;
  padding: 0;
  margin: 0 auto;
  width: 270px;
  overflow: hidden; }

@media (min-width: 360px) {
  .ab-footer-recaptcha-container {
    width: 305px; } }
@media (min-width: 768px) {
  .ab-footer-form-bg {
    padding: 50px; }

  .ab-footer-form form {
    display: grid;
    grid-template-rows: auto auto;
    grid-row-gap: 20px; }

  .ab-footer-form-grid {
    display: grid;
    grid-template-columns: auto auto auto;
    grid-column-gap: 20px; } }
@media (min-width: 1366px) {
  .ab-footer-form-bg {
    padding: 75px; } }
/*  -------------------------------------------
    SEARCH BOX (POP-UP)
-----------------------------------------------*/
#ab-search-form {
  display: block;
  position: relative;
  background: #fff;
  padding: 50px;
  width: auto;
  max-width: 500px;
  margin: 20px auto; }

#ab-search-form div {
  background: #f3f5fb;
  padding: 20px; }

#ab-search-form input[type="text"] {
  display: inline-block;
  width: 70%;
  height: 25px;
  padding: 0px 10px;
  margin: 0;
  background: transparent;
  border: 0px;
  outline: 0px;
  vertical-align: top; }

#ab-search-form input[type="submit"] {
  display: block;
  float: right;
  width: 30px;
  height: 25px;
  margin: 0;
  padding: 0;
  border: 0px;
  outline: 0px;
  background: transparent url("../graphics/search-form-button.png") top left no-repeat; }

@media (min-width: 768px) {
  .ab-searchbox {
    display: block; } }
/*  -------------------------------------------
    CLIENT LOGIN (POP-UP)
-----------------------------------------------*/
#ab-client-login {
  display: block;
  position: relative;
  background: #fff;
  padding: 50px 0px;
  width: auto;
  max-width: 700px;
  margin: 20px auto; }

#ab-client-login .ab-client-login-logo {
  display: inline-block;
  padding: 10px 10px 50px 10px; }

#ab-client-login .ab-client-login-logo .ab-logo-link {
  display: inline-block;
  height: 50px;
  width: auto; }

@media (min-width: 768px) {
  #ab-client-login {
    padding: 50px; }

  #ab-client-login .ab-client-login-logo {
    padding: 25px; }

  #ab-client-login .ab-client-login-logo .ab-logo-link {
    display: inline-block;
    height: 65px;
    width: auto; } }
/*  -------------------------------------------
    LAYOUT
-----------------------------------------------*/
.ab-container {
  box-sizing: border-box;
  width: 100%;
  max-width: 1500px;
  margin: 0 auto;
  padding: 0px 10px; }

.ab-clear-small {
  clear: both; }

.ab-break {
  display: inline; }

.ab-break-small {
  display: inline; }

.ab-break-medium {
  display: inline; }

.ab-break-large {
  display: inline; }

.ab-col-2 {
  box-sizing: border-box;
  width: 100%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-2-small {
  box-sizing: border-box;
  width: 50%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-2-medium {
  box-sizing: border-box;
  width: 100%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-3 {
  box-sizing: border-box;
  width: 100%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-3-small {
  box-sizing: border-box;
  width: 33%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-3-medium {
  box-sizing: border-box;
  width: 100%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-4 {
  box-sizing: border-box;
  width: 50%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-small-only {
  display: block; }

.ab-small-medium {
  display: block; }

.ab-medium-only {
  display: none; }

.ab-large-only {
  display: none; }

.ab-medium-large {
  display: none; }

.ab-medium-large-inline {
  display: none; }

.ab-col-13-small {
  box-sizing: border-box;
  width: 33%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-13-medium {
  box-sizing: border-box;
  width: 100%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-13 {
  box-sizing: border-box;
  width: 100%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-23-small {
  box-sizing: border-box;
  width: 66%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-23-medium {
  box-sizing: border-box;
  width: 100%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-23 {
  box-sizing: border-box;
  width: 100%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-25-small {
  box-sizing: border-box;
  width: 40%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-25-medium {
  box-sizing: border-box;
  width: 100%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-25 {
  box-sizing: border-box;
  width: 100%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-35-small {
  box-sizing: border-box;
  width: 60%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-35-medium {
  box-sizing: border-box;
  width: 100%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-35 {
  box-sizing: border-box;
  width: 100%;
  float: left;
  padding: 0;
  margin: 0; }

.ab-col-right {
  box-sizing: border-box;
  width: 100%;
  float: none;
  padding: 0;
  margin: 0; }

.ab-col-left {
  box-sizing: border-box;
  width: 100%;
  float: none;
  padding: 0;
  margin: 0; }

.ab-col-medium-right {
  box-sizing: border-box;
  width: 100%;
  float: none;
  padding: 0;
  margin: 0; }

.ab-col-medium-left {
  box-sizing: border-box;
  width: 100%;
  float: none;
  padding: 0;
  margin: 0; }

.ab-col-2-medium-padding {
  padding: 0px 10px 0px 10px; }

@media (min-width: 500px) {
  .ab-break-small {
    display: block; } }
@media (min-width: 768px) {
  .ab-clear-small {
    clear: none; }

  .ab-break-medium {
    display: block; }

  .ab-col-2-medium {
    width: 50%;
    float: left; }

  .ab-col-3-medium {
    width: 33%;
    float: left; }

  .ab-small-only {
    display: none; }

  .ab-medium-only {
    display: block; }

  .ab-large-only {
    display: none; }

  .ab-medium-large {
    display: block; }

  .ab-medium-large-inline {
    display: inline; }

  .ab-col-13-medium {
    width: 33%; }

  .ab-col-23-medium {
    width: 66%; }

  .ab-col-25-medium {
    width: 36%; }

  .ab-col-35-medium {
    width: 64%; }

  .ab-col-medium-right {
    box-sizing: border-box;
    width: 50%;
    float: right; }

  .ab-col-medium-left {
    box-sizing: border-box;
    width: 50%;
    float: none; }

  .ab-col-2-medium-padding {
    padding: 0px 10px 0px 20px; } }
@media (min-width: 1024px) {
  .ab-container {
    padding: 0px 25px; }

  .ab-break {
    display: block; }

  .ab-col-2 {
    width: 50%;
    float: left; }

  .ab-col-3 {
    width: 33%;
    float: left; }

  .ab-col-4 {
    width: 25%;
    float: left; }

  .ab-small-only {
    display: none; }

  .ab-small-medium {
    display: none; }

  .ab-medium-only {
    display: none; }

  .ab-large-only {
    display: block; }

  .ab-medium-large {
    display: block; }

  .ab-col-13 {
    width: 33%; }

  .ab-col-23 {
    width: 66%; }

  .ab-col-25 {
    width: 37%; }

  .ab-col-35 {
    width: 63%; }

  .ab-col-right {
    box-sizing: border-box;
    width: 50%;
    float: right; }

  .ab-col-left {
    box-sizing: border-box;
    width: 50%;
    float: none; }

  .ab-col-2-medium-padding {
    padding: 0px 10px 0px 25px; } }
@media (min-width: 1280px) {
  .ab-container {
    padding: 0px 75px; }

  .ab-break-large {
    display: block; } }
/*  -------------------------------------------
SECTIONS
-----------------------------------------------*/
.ab-sec-normal {
  box-sizing: border-box;
  padding: 30px 0px;
  margin: 0;
  background: transparent;
  outline: none; }

.ab-sec-white {
  box-sizing: border-box;
  padding: 30px 0px;
  margin: 0;
  background: #fff;
  outline: none; }

.ab-sec-grey {
  box-sizing: border-box;
  padding: 30px 0px;
  margin: 0;
  background: #eeeeef;
  outline: none; }

.ab-sec-lightgrey {
  box-sizing: border-box;
  padding: 30px 0px;
  margin: 0;
  background: #f7f7f7;
  outline: none; }

.ab-sec-colored {
  box-sizing: border-box;
  padding: 30px 0px;
  margin: 0;
  background: #182a54;
  outline: none; }

@media (min-width: 768px) {
  .ab-sec-white-box {
    padding: 25px; }

  .ab-sec-width-sm {
    box-sizing: border-box;
    width: 65%;
    margin: 0 auto; }

  .ab-sec-width-md {
    box-sizing: border-box;
    width: 85%;
    margin: 0 auto; }

  .ab-sec-width-lg {
    box-sizing: border-box;
    width: 100%;
    margin: 0 auto; } }
@media (min-width: 1024px) {
  .ab-sec-white-box {
    padding: 50px; }

  .ab-sec-width-sm {
    box-sizing: border-box;
    width: 60%;
    margin: 0 auto; }

  .ab-sec-width-md {
    box-sizing: border-box;
    width: 70%;
    margin: 0 auto; }

  .ab-sec-width-lg {
    box-sizing: border-box;
    width: 90%;
    margin: 0 auto; } }
@media (min-width: 1280px) {
  .ab-sec-width-sm {
    box-sizing: border-box;
    width: 55%;
    margin: 0 auto; }

  .ab-sec-width-md {
    box-sizing: border-box;
    width: 65%;
    margin: 0 auto; }

  .ab-sec-width-lg {
    box-sizing: border-box;
    width: 80%;
    margin: 0 auto; }

  .ab-sec-width-55 {
    box-sizing: border-box;
    width: 55%;
    margin: 0 auto; }

  .ab-sec-width-75 {
    box-sizing: border-box;
    width: 75%;
    margin: 0 auto; }

  .ab-sec-width-85 {
    box-sizing: border-box;
    width: 85%;
    margin: 0 auto; }

  .ab-sec-width-100 {
    box-sizing: border-box;
    width: 100%;
    margin: 0 auto; }

  .ab-sec-width-1000 {
    box-sizing: border-box;
    width: 100%;
    max-width: 1000px;
    margin: 0 auto; } }
/*  -------------------------------------------
EXTRA PADDING
-----------------------------------------------*/
.ab-prj-extra-space-10-25-50 {
  height: 10px; }

.ab-prj-extra-space-25-50-75 {
  height: 25px; }

.ab-prj-extra-space-50-75-100 {
  height: 50px; }

.ab-prj-extra-space {
  height: 30px; }

.ab-prj-padding-extra-TB {
  padding: 25px 0 25px 0; }

.ab-prj-padding-top {
  padding-top: 0px; }

.ab-prj-padding-bottom {
  padding-bottom: 0px; }

.ab-prj-padding-left {
  padding-left: 0px; }

.ab-prj-padding-right {
  padding-right: 0px; }

@media (min-width: 768px) {
  .ab-prj-extra-space-10-25-50 {
    height: 25px; }

  .ab-prj-extra-space-25-50-75 {
    height: 50px; }

  .ab-prj-extra-space-50-75-100 {
    height: 75px; }

  .ab-prj-padding-extra-TB {
    padding: 50px 0 50px 0; }

  .ab-prj-padding-top {
    padding-top: 25px; }

  .ab-prj-padding-bottom {
    padding-bottom: 25px; }

  .ab-prj-padding-left {
    padding-left: 25px; }

  .ab-prj-padding-right {
    padding-right: 25px; } }
@media (min-width: 1024px) {
  .ab-prj-extra-space-10-25-50 {
    height: 50px; }

  .ab-prj-extra-space-25-50-75 {
    height: 75px; }

  .ab-prj-extra-space-50-75-100 {
    height: 100px; }

  .ab-prj-padding-extra-TB {
    padding: 75px 0 75px 0; }

  .ab-prj-padding-top {
    padding-top: 50px; }

  .ab-prj-padding-bottom {
    padding-bottom: 50px; }

  .ab-prj-padding-left {
    padding-left: 50px; }

  .ab-prj-padding-right {
    padding-right: 50px; } }
/*  -------------------------------------------
    SLICK CAROUSEL
-----------------------------------------------*/
.slick-prev:hover, .slick-prev:focus, .slick-next:hover, .slick-next:focus {
  color: transparent;
  outline: none; }

.slick-prev {
  left: -100px; }

[dir='rtl'] .slick-prev {
  right: -100px;
  left: auto; }

.slick-next {
  right: -100px; }

[dir='rtl'] .slick-next {
  right: auto;
  left: -100px; }

.slick-slider {
  margin-bottom: 0px; }

.slick-dots {
  position: absolute;
  bottom: -45px;
  left: -10px;
  display: block;
  width: 100%;
  padding: 0;
  list-style: none;
  text-align: left; }

.slick-dots li {
  position: relative;
  display: inline-block; }

.slick-dots li button {
  /*
  font-size: 0;
  line-height: 0;
  display: block;
  width: 15px;
  height: 15px;
  margin: 5px;
  text-indent: -999px;
  cursor: pointer;
  background-color: #000 \9;
  background-color: rgba(0, 0, 0, 0);
  border: 2px solid #454545;
  border-radius: 15px;
  */
  font-size: 0;
  line-height: 0;
  display: block;
  width: 10px;
  height: 10px;
  margin: 5px;
  text-indent: -9999px;
  cursor: pointer;
  background-color: transparent;
  border: 1px #1ab7ea solid;
  border-radius: 10px; }

.slick-dots li button:hover, .slick-dots li button:focus {
  /*
  outline: none;
  width: 15px;
  height: 15px;
  margin: 5px;
  background-color: #454545;
  */
  outline: none;
  width: 10px;
  height: 10px;
  background-color: #1ab7ea; }

.slick-dots li button:hover:before, .slick-dots li button:focus:before {
  opacity: 1; }

.slick-dots li.slick-active button {
  /*
    width: 15px;
    height: 15px;
    margin: 5px;
    background-color: #454545;
  */
  width: 10px;
  height: 10px;
  background-color: #1ab7ea; }

/*  -------------------------------------------
BANNERS
-----------------------------------------------*/
.ab-banner-img {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  border: 0;
  position: relative; }

.ab-banner-img img.ab-small-only {
  display: block;
  width: 100%;
  height: auto; }

.ab-banner-img img.ab-medium-large {
  display: none;
  width: 100%;
  height: auto; }

.ab-banner-text-box {
  box-sizing: border-box;
  position: absolute;
  bottom: 40%;
  left: 0;
  padding: 0;
  width: 100%; }

.ab-banner-text-box h1 {
  font-family: "PrimaryFontLight", sans-serif;
  color: #fff;
  margin: 0;
  padding: 0;
  font-size: 1.45em;
  font-weight: normal;
  text-shadow: -1px -1px 1px rgba(255, 255, 255, 0.1), 1px 1px 1px rgba(0, 0, 0, 0.5), 2px 2px 2px rgba(206, 89, 55, 0); }

@media (min-width: 768px) {
  .ab-banner-img img.ab-small-only {
    display: none; }

  .ab-banner-img img.ab-medium-large {
    display: block; }

  .ab-banner-text-box h1 {
    font-size: 1.75em; } }
@media (min-width: 1024px) {
  .ab-banner-text-box h1 {
    font-size: 2.0em; } }
@media (min-width: 1280px) {
  .ab-banner-text-box h1 {
    font-size: 2.75em; } }
@media (min-width: 1600px) {
  .ab-banner-text-box h1 {
    font-size: 3.0em; } }
@media (min-width: 2000px) {
  .ab-banner-text-box h1 {
    font-size: 4.0em; } }
/*  -------------------------------------------
    PARALLAX SECTIONS
-----------------------------------------------*/
.ab-sec-parallax {
  padding: 0;
  margin: 0;
  color: #fff; }

.ab-sec-parallax h1 {
  color: #fff;
  margin: 0;
  padding: 0; }

.ab-sec-parallax h3 {
  color: #fff; }

.ab-sec-parallax h2 {
  color: #fff; }

.ab-sec-parallax p {
  color: #fff; }

.ab-sec-parallax-padding-grey-layer h2 {
  color: #1c5aa8; }

.ab-sec-parallax-padding-grey-layer p {
  color: #000; }

.ab-sec-parallax-padding-white-layer h2 {
  color: #1c5aa8; }

.ab-sec-parallax-padding-white-layer p {
  color: #000; }

.ab-sec-parallax-padding-white-layer-medium h2 {
  color: #1c5aa8; }

.ab-sec-parallax-padding-white-layer-medium h4 {
  color: #000; }

.ab-sec-parallax-padding-white-layer-medium p {
  color: #000; }

/*
.ab-sec-parallax-left-shade { background:transparent url("../graphics/bg-shade-left.png") top left repeat-y; }
.ab-sec-parallax-right-shade { background:transparent url("../graphics/bg-shade-right.png") top right repeat-y; }
*/
.ab-sec-parallax-left-shade {
  background: transparent; }

.ab-sec-parallax-right-shade {
  background: transparent; }

.ab-sec-parallax-padding-shadow-layer {
  background: rgba(0, 0, 0, 0.5);
  padding: 50px 0px; }

.ab-sec-parallax-padding-grey-layer {
  background: #ededed;
  padding: 50px 0px;
  color: #000; }

.ab-sec-parallax-padding-white-layer {
  background: #fff;
  padding: 50px 0px;
  color: #000; }

.ab-sec-parallax-padding-white-layer-medium {
  background: #fff;
  padding: 50px 0px;
  color: #000; }

.ab-sec-parallax-padding-layer {
  padding: 50px 0px; }

.ab-sec-parallax-footer {
  min-height: 400px;
  background: transparent; }

.ab-sec-parallax-01 {
  min-height: 450px;
  background: transparent; }

.ab-sec-parallax-02 {
  min-height: 450px;
  background: transparent; }

.ab-sec-parallax-grid-01 {
  min-height: 350px;
  background: transparent; }

.ab-sec-parallax-grid-02 {
  min-height: 350px;
  background: transparent; }

.ab-sec-parallax-grid-03 {
  min-height: 350px;
  background: transparent; }

@media (min-width: 768px) {
  .ab-sec-parallax-grid-01 {
    min-height: 500px; }

  .ab-sec-parallax-grid-02 {
    min-height: 500px; }

  .ab-sec-parallax-grid-03 {
    min-height: 500px; }

  .ab-sec-parallax-left-shade {
    background: transparent url("../graphics/bg-shade-left.png") top center repeat-y; }

  .ab-sec-parallax-right-shade {
    background: transparent url("../graphics/bg-shade-right.png") top center repeat-y; }

  .ab-sec-parallax {
    padding: 0;
    margin: 0; }

  .ab-sec-parallax-padding-shadow-layer {
    background: transparent;
    padding: 75px 0px; }

  .ab-sec-parallax-padding-grey-layer {
    background: transparent;
    padding: 75px 0px; }

  .ab-sec-parallax-padding-white-layer {
    background: transparent;
    padding: 75px 0px; }

  .ab-sec-parallax-padding-white-layer-medium {
    padding: 75px 0px; }

  .ab-sec-parallax-padding-layer {
    padding: 75px 0px; } }
@media (min-width: 1024px) {
  .ab-sec-parallax-grid-01 {
    min-height: 800px; }

  .ab-sec-parallax-grid-02 {
    min-height: 800px; }

  .ab-sec-parallax-grid-03 {
    min-height: 800px; }

  .ab-sec-parallax-padding-white-layer-medium {
    background: transparent;
    padding: 75px 0px; } }
@media (min-width: 1280px) {
  .ab-sec-parallax-padding-layer {
    padding: 100px 0px; } }
/*  -------------------------------------------
    PROJECT 
-----------------------------------------------*/
body {
  background: #fff; }

body.ab-body-bg-dark {
  background: #f7f7f7; }

.ab-color-grey {
  color: #5A5A5A; }

.ab-color-red {
  color: #C10230; }

h2 {
  color: #3c3c3c; }

h3 {
  color: #3c3c3c; }

#ab-diagnol-bg {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  background: url("../graphics/ab-diagnol-bg.png") bottom left no-repeat; }

.ab-prj-2col-grid {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  display: grid;
  grid-template-columns: 100%;
  row-gap: 20px; }

.ab-prj-h3-line {
  box-sizing: border-box;
  padding: 0 0 0 10px;
  margin: 0;
  width: 100%;
  border-left: 1px #C10230 solid; }

.ab-prj-btn-link {
  display: inline-block;
  box-sizing: border-box;
  padding: 15px 25px;
  margin: 0;
  width: 100%;
  max-width: 400px;
  text-align: center;
  border-radius: 5px;
  background: #C10230;
  color: #fff; }

.ab-prj-btn-link:hover {
  background: #5A5A5A;
  color: #fff; }

@media (min-width: 768px) {
  .ab-prj-2col-grid {
    display: grid;
    grid-template-columns: 53.5% 43.5%;
    justify-content: space-between;
    align-items: center; } }
@media (min-width: 1280px) {
  .ab-prj-2col-grid {
    display: grid;
    grid-template-columns: 63.5% 33.5%;
    justify-content: space-between;
    align-items: center; } }
@media (min-width: 5000px) {
  #ab-diagnol-bg {
    background: url("../graphics/ab-diagnol-bg.png") bottom right no-repeat; } }
/*  -------------------------------------------
    PROCESS 
-----------------------------------------------*/
.ab-sec-process {
  background: url("../graphics/visual-03.jpg") top center no-repeat;
  background-size: cover; }

.ab-process-steps {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%; }

.ab-process-steps-grid {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  display: grid;
  grid-template-columns: 100%;
  align-items: center; }
  .ab-process-steps-grid .ab-process-steps-grid-diagram {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%; }
    .ab-process-steps-grid .ab-process-steps-grid-diagram .ab-process-steps-diagram-continer {
      box-sizing: border-box;
      padding: 0;
      margin: 0;
      width: 100%;
      position: relative; }
      .ab-process-steps-grid .ab-process-steps-grid-diagram .ab-process-steps-diagram-continer img {
        display: block;
        padding: 0;
        margin: 0;
        width: 100%;
        height: auto; }
      .ab-process-steps-grid .ab-process-steps-grid-diagram .ab-process-steps-diagram-continer .ab-process-steps-img-grid {
        box-sizing: border-box;
        padding: 0;
        margin: 0;
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        display: grid;
        grid-template-columns: 50% 50%;
        grid-template-rows: 50% 50%; }
        .ab-process-steps-grid .ab-process-steps-grid-diagram .ab-process-steps-diagram-continer .ab-process-steps-img-grid .ab-process-step-link-1, .ab-process-steps-grid .ab-process-steps-grid-diagram .ab-process-steps-diagram-continer .ab-process-steps-img-grid .ab-process-step-link-2, .ab-process-steps-grid .ab-process-steps-grid-diagram .ab-process-steps-diagram-continer .ab-process-steps-img-grid .ab-process-step-link-3, .ab-process-steps-grid .ab-process-steps-grid-diagram .ab-process-steps-diagram-continer .ab-process-steps-img-grid .ab-process-step-link-4 {
          box-sizing: border-box;
          padding: 0;
          margin: 0;
          width: 100%;
          height: 100%;
          cursor: pointer; }
  .ab-process-steps-grid .ab-process-steps-grid-details {
    box-sizing: border-box;
    padding: 0 10px;
    margin: 0;
    width: 100%; }
    .ab-process-steps-grid .ab-process-steps-grid-details .ab-process-step-heading {
      box-sizing: border-box;
      padding: 0 0 3px 0;
      margin: 0;
      font-weight: bold;
      color: #fff;
      border-bottom: 2px #a09ea1 solid; }
    .ab-process-steps-grid .ab-process-steps-grid-details .ab-process-step-list {
      box-sizing: border-box;
      padding: 0 0 35px 0;
      margin: 0;
      width: 100%;
      list-style: none; }
      .ab-process-steps-grid .ab-process-steps-grid-details .ab-process-step-list li {
        box-sizing: border-box;
        padding: 8px 0 8px 20px;
        margin: 0;
        width: 100%;
        color: #fff;
        background: url("../graphics/ab-process-steps-arrow.png") 0px 15px no-repeat;
        background-size: 8px 11px;
        font-family: "PrimaryFontLight", sans-serif;
        border-bottom: 1px #a09ea1 dotted; }

.ab-process-nav {
  box-sizing: border-box;
  padding: 20px 0;
  margin: 0;
  width: 100%;
  list-style: none;
  display: grid;
  grid-template-columns: auto auto auto auto; }
  .ab-process-nav li {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    text-align: center;
    background: url("../graphics/ab-process-nav-arrow-grey.png") center right no-repeat;
    background-size: 10px 14px;
    cursor: pointer;
    font-size: 0.765em;
    letter-spacing: 1px;
    color: #c0bec1; }
    .ab-process-nav li div {
      display: none;
      font-size: 1.15em;
      color: #c0bec1;
      font-family: "PrimaryFontBold", sans-serif; }
  .ab-process-nav li:hover {
    color: #5A5A5A; }
    .ab-process-nav li:hover div {
      color: #5A5A5A; }
  .ab-process-nav li.ab-process-current-step, .ab-process-nav li.ab-process-current-step:hover {
    background: url("../graphics/ab-process-nav-arrow-red.png") center right no-repeat;
    background-size: 10px 14px;
    color: #C10230; }
    .ab-process-nav li.ab-process-current-step div, .ab-process-nav li.ab-process-current-step:hover div {
      color: #C10230; }
  .ab-process-nav li:last-child, .ab-process-nav li.ab-process-current-step:last-child {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    text-align: center;
    background: none; }

@media (min-width: 768px) {
  .ab-process-nav li div {
    display: block; } }
@media (min-width: 1024px) {
  .ab-process-steps-grid {
    padding: 75px 0 0 0;
    display: grid;
    grid-template-columns: 50% 50%; }
    .ab-process-steps-grid .ab-process-steps-grid-details {
      padding: 0 50px; } }
@media (min-width: 1280px) {
  .ab-process-steps-grid {
    padding: 75px 0 0 0;
    display: grid;
    grid-template-columns: 50% 50%; }
    .ab-process-steps-grid .ab-process-steps-grid-details {
      padding: 0 100px; } }
/*  -------------------------------------------
    PROCESS INTRO 
-----------------------------------------------*/
.ab-process-intro {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  position: relative; }
  .ab-process-intro img {
    display: inline-block;
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%; }
  .ab-process-intro .ab-process-intro-grid {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%; }
    .ab-process-intro .ab-process-intro-grid .ab-process-intro-box {
      position: relative;
      box-sizing: border-box;
      padding: 35px 25px;
      margin: -25px 0 0 0;
      width: 100%;
      background: #C10230;
      color: #fff;
      font-family: "PrimaryFontLight", sans-serif;
      line-height: 150%; }

@media (min-width: 768px) {
  .ab-process-intro {
    position: relative;
    text-align: right; }
    .ab-process-intro img {
      width: 60%;
      height: 100%; }
    .ab-process-intro .ab-process-intro-grid {
      width: 100%;
      height: 100%;
      display: grid;
      align-items: center;
      text-align: left;
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0; }
      .ab-process-intro .ab-process-intro-grid .ab-process-intro-box {
        position: unset;
        padding: 35px;
        width: 50%; } }
@media (min-width: 1024px) {
  .ab-process-intro .ab-process-intro-grid .ab-process-intro-box {
    position: unset;
    padding: 70px;
    width: 45%; } }
@media (min-width: 1366px) {
  .ab-process-intro .ab-process-intro-grid .ab-process-intro-box {
    font-size: 1.65em; } }
/*  -------------------------------------------
    ARTICLES OF INTEREST
-----------------------------------------------*/
.ab-articles-container {
  box-sizing: border-box;
  padding: 0 0 100px 0;
  margin: 0;
  width: 100%;
  list-style: none; }

.ab-articles-grid {
  box-sizing: border-box;
  padding: 25px;
  margin: 0;
  width: 100%;
  display: grid;
  grid-template-columns: 100%;
  border-bottom: 1px #e6e7e8 solid; }
  .ab-articles-grid .ab-articles-text {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%; }
    .ab-articles-grid .ab-articles-text .ab-article-title {
      font-family: "PrimaryFontLight", sans-serif;
      font-size: 1.35em;
      cursor: pointer; }
    .ab-articles-grid .ab-articles-text .ab-article-description {
      box-sizing: border-box;
      padding: 0;
      margin: 0;
      display: none;
      font-family: "PrimaryFontLight", sans-serif;
      padding-top: 10px; }
  .ab-articles-grid .ab-articles-link {
    box-sizing: border-box;
    padding: 7px 0 0 0;
    margin: 0;
    width: 100%; }
    .ab-articles-grid .ab-articles-link a {
      display: inline-block;
      box-sizing: border-box;
      padding: 0 25px 0 0;
      margin: 0;
      height: 20px;
      font-size: 0.9em;
      font-weight: bold;
      background: url("../graphics/readmore-white.png") center right no-repeat; }

.ab-articles-grid-open {
  border-bottom: 0;
  background: #C10230;
  color: #fff; }
  .ab-articles-grid-open .ab-articles-text .ab-article-title {
    color: #fff; }
  .ab-articles-grid-open .ab-articles-text .ab-article-description {
    display: block;
    color: #fff; }
  .ab-articles-grid-open .ab-articles-link a {
    color: #fff;
    background: url("../graphics/readmore-grey.png") center right no-repeat; }

@media (min-width: 768px) {
  .ab-articles-grid {
    display: grid;
    grid-template-columns: 75% 25%; }
    .ab-articles-grid .ab-articles-link {
      text-align: right; } }
@media (min-width: 1024px) {
  .ab-articles-grid .ab-articles-text .ab-article-title {
    font-size: 1.55em; } }
/*  -------------------------------------------
    SERVICES 
-----------------------------------------------*/
.services {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%; }

.services-header {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  position: relative; }
  .services-header .services-header-img {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 476px; }
  .services-header .services-header-img-01 {
    background: url("../graphics/services-01.jpg") top center no-repeat;
    background-size: cover; }
  .services-header .services-header-img-02 {
    background: url("../graphics/services-02.jpg") top center no-repeat;
    background-size: cover; }
  .services-header .services-header-img-03 {
    background: url("../graphics/services-03.jpg") top center no-repeat;
    background-size: cover; }
  .services-header .services-header-img-04 {
    background: url("../graphics/services-04.jpg") top center no-repeat;
    background-size: cover; }
  .services-header .services-header-txt {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    display: grid;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0; }
    .services-header .services-header-txt .services-header-txt-box {
      box-sizing: border-box;
      padding: 0 10px 75px 10px;
      margin: 0; }

.services-txt-box {
  position: relative;
  box-sizing: border-box;
  padding: 50px 25px;
  margin: -125px auto 0 auto;
  width: 90%;
  max-width: 1100px;
  background: #f7f7f7;
  border-top: 5px #C10230 solid; }

.services-diagram-box {
  box-sizing: border-box;
  padding: 50px 0;
  margin: 0 auto;
  width: 90%;
  max-width: 1500px; }

.services-diagram-grid-container {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  position: relative; }
  .services-diagram-grid-container img {
    display: block;
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    height: auto; }
  .services-diagram-grid-container .services-diagram-grid {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    display: grid;
    grid-template-columns: 50% 50%;
    grid-template-rows: 50% 50%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0; }
    .services-diagram-grid-container .services-diagram-grid .services-diagram-grid-item {
      box-sizing: border-box;
      padding: 0;
      margin: 0;
      width: 100%;
      height: 100%;
      cursor: pointer; }
  .services-diagram-grid-container .services-diagram-grid-A {
    display: grid;
    grid-template-columns: 50% 50%;
    grid-template-rows: 50% 50%; }
  .services-diagram-grid-container .services-diagram-grid-B {
    display: grid;
    grid-template-columns: 50% 50%;
    grid-template-rows: 35% 30% 35%; }
  .services-diagram-grid-container .services-diagram-grid-C {
    display: grid;
    grid-template-columns: 50% 50%;
    grid-template-rows: 35% 30% 35%; }
  .services-diagram-grid-container .services-diagram-grid-D {
    display: grid;
    grid-template-columns: 50% 50%;
    grid-template-rows: 50% 50%; }
  .services-diagram-grid-container .services-A-bg1 {
    background: url("../graphics/services-A-01.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-A-bg2 {
    background: url("../graphics/services-A-02.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-A-bg3 {
    background: url("../graphics/services-A-03.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-A-bg4 {
    background: url("../graphics/services-A-04.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-B-bg1 {
    background: url("../graphics/services-B-01.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-B-bg2 {
    background: url("../graphics/services-B-02.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-B-bg3 {
    background: url("../graphics/services-B-03.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-B-bg4 {
    background: url("../graphics/services-B-04.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-B-bg5 {
    background: url("../graphics/services-B-05.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-B-bg6 {
    background: url("../graphics/services-B-06.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-C-bg1 {
    background: url("../graphics/services-C-01.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-C-bg2 {
    background: url("../graphics/services-C-02.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-C-bg3 {
    background: url("../graphics/services-C-03.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-C-bg4 {
    background: url("../graphics/services-C-04.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-C-bg5 {
    background: url("../graphics/services-C-05.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-C-bg6 {
    background: url("../graphics/services-C-06.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-D-bg1 {
    background: url("../graphics/services-D-01.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-D-bg2 {
    background: url("../graphics/services-D-02.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-D-bg3 {
    background: url("../graphics/services-D-03.png") top left no-repeat;
    background-size: cover; }
  .services-diagram-grid-container .services-D-bg4 {
    background: url("../graphics/services-D-04.png") top left no-repeat;
    background-size: cover; }

@media (min-width: 768px) {
  .services-txt-box {
    padding: 50px;
    margin: -125px auto 0 auto; } }
@media (min-width: 1366px) {
  .services-header .services-header-img {
    height: 635px; }
  .services-header .services-header-txt .services-header-txt-box {
    padding: 0 0 100px 0; }

  .services-txt-box {
    padding: 75px 100px;
    margin: -125px auto 0 auto; } }
@media (min-width: 1600px) {
  .services-header .services-header-img {
    height: 700px; } }
/*  -------------------------------------------
    PARNERS
-----------------------------------------------*/
.ab-partners-container-bg {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%; }

.ab-partners-container {
  box-sizing: border-box;
  padding: 0 0 25px 0;
  margin: 0;
  width: 100%;
  background: #f7f7f7;
  position: relative; }
  .ab-partners-container .ab-partners-links {
    box-sizing: border-box;
    padding: 20px 10px;
    margin: 0;
    width: 100%; }
    .ab-partners-container .ab-partners-links ul {
      box-sizing: border-box;
      padding: 0;
      margin: 0;
      width: 100%;
      list-style: none;
      text-align: center; }
    .ab-partners-container .ab-partners-links ul li {
      display: inline-block;
      box-sizing: border-box;
      padding: 0;
      margin: 0; }
    .ab-partners-container .ab-partners-links ul li a {
      display: inline-block;
      box-sizing: border-box;
      padding: 0 0 2px 0;
      margin: 0 15px;
      border-bottom: 3px transparent solid;
      font-size: 0.815em; }
    .ab-partners-container .ab-partners-links ul li a.ab-partners-link-current {
      border-bottom: 3px #C10230 solid;
      color: #C10230;
      font-weight: bold; }
  .ab-partners-container .ab-partners-slider {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%; }
    .ab-partners-container .ab-partners-slider .ab-partners-grid {
      box-sizing: border-box;
      padding: 0;
      margin: 0;
      width: 100%;
      display: grid;
      grid-template-columns: 100%; }
      .ab-partners-container .ab-partners-slider .ab-partners-grid .ab-partners-grid-logo {
        box-sizing: border-box;
        padding: 20px 10px;
        margin: 0;
        width: 100%;
        height: 100%;
        display: grid;
        justify-content: center;
        align-items: center; }
        .ab-partners-container .ab-partners-slider .ab-partners-grid .ab-partners-grid-logo img {
          display: block;
          padding: 0;
          margin: 0;
          width: 100%;
          max-width: 250px;
          height: auto; }
        .ab-partners-container .ab-partners-slider .ab-partners-grid .ab-partners-grid-logo img.ab-partners-grid-logo-correction {
          width: auto;
          height: 50px; }
      .ab-partners-container .ab-partners-slider .ab-partners-grid .ab-partners-grid-txt {
        box-sizing: border-box;
        padding: 20px 10px;
        margin: 0;
        width: 100%;
        height: 100%; }
  .ab-partners-container .ab-partners-nav {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 50px;
    height: 25px;
    position: absolute;
    bottom: 0px;
    left: 0px;
    display: grid;
    grid-template-columns: 25px 25px; }
  .ab-partners-container .ab-partners-nav div:first-child {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 25px;
    height: 25px;
    text-align: center;
    background: #5A5A5A url("../graphics/ab-nav-arrow-left.png") center center no-repeat;
    background-size: 9px 14px;
    color: #fff;
    cursor: pointer; }
  .ab-partners-container .ab-partners-nav div:last-child {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 25px;
    height: 25px;
    text-align: center;
    background: #C10230 url("../graphics/ab-nav-arrow-right.png") center center no-repeat;
    background-size: 9px 14px;
    color: #fff;
    cursor: pointer; }

@media (min-width: 768px) {
  .ab-partners-container .ab-partners-links {
    padding: 25px 25px 25px 35%; }
    .ab-partners-container .ab-partners-links ul {
      text-align: left; }
    .ab-partners-container .ab-partners-links ul li a {
      margin: 0 5px 0 25px;
      font-size: 1.0em; }
  .ab-partners-container .ab-partners-slider .ab-partners-grid {
    display: grid;
    grid-template-columns: 35% 65%; }
    .ab-partners-container .ab-partners-slider .ab-partners-grid .ab-partners-grid-logo {
      padding: 25px; }
    .ab-partners-container .ab-partners-slider .ab-partners-grid .ab-partners-grid-txt {
      padding: 25px; } }
@media (min-width: 1024px) {
  .ab-partners-container-bg {
    background: url("../graphics/ab-partners-container-bg.png") top center repeat-y; }

  .ab-partners-container-padding {
    padding-left: 175px; } }
@media (min-width: 1280px) {
  .ab-partners-container-padding {
    padding-left: 275px; }

  .ab-partners-container .ab-partners-links {
    padding: 50px 25px 25px 35%; }
    .ab-partners-container .ab-partners-links ul {
      text-align: left; }
    .ab-partners-container .ab-partners-links ul li a {
      margin: 0 5px 0 25px;
      font-size: 1.0em; }
  .ab-partners-container .ab-partners-slider .ab-partners-grid {
    display: grid;
    grid-template-columns: 35% 65%; }
    .ab-partners-container .ab-partners-slider .ab-partners-grid .ab-partners-grid-logo {
      padding: 25px; }
    .ab-partners-container .ab-partners-slider .ab-partners-grid .ab-partners-grid-txt {
      padding: 0 50px 50px 25px; } }
/*  -------------------------------------------
   TEAM POPUP
-----------------------------------------------*/
.ab-team-popup {
  display: block;
  position: relative;
  background: #C10230;
  color: #fff;
  padding: 0;
  width: auto;
  max-width: 800px;
  margin: auto; }

.ab-team-popup-grid {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: 100%; }

.ab-team-popup-bio {
  box-sizing: border-box;
  padding: 20px;
  margin: 0;
  width: 100%;
  height: 100%;
  background: #C10230;
  color: #fff;
  display: grid;
  align-content: center;
  grid-area: 2 / 1 / 3 / 2; }
  .ab-team-popup-bio p {
    color: #fff; }
  .ab-team-popup-bio a {
    color: #fff; }

.ab-team-popup-pic {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  height: 400px;
  grid-area: 1 / 1 / 2 / 2;
  position: relative; }
  .ab-team-popup-pic .ab-team-popup-pic-box {
    display: block;
    box-sizing: border-box;
    padding: 0 0 0 15px;
    margin: 0;
    position: absolute;
    bottom: 10%;
    left: 10%;
    border-left: 1px #C10230 solid;
    font-family: "PrimaryFontLight", sans-serif; }
    .ab-team-popup-pic .ab-team-popup-pic-box .ab-team-popup-pic-box-a, .ab-team-popup-pic .ab-team-popup-pic-box .ab-team-popup-pic-box-b {
      box-sizing: border-box;
      padding: 0;
      margin: 0;
      width: 100%;
      line-height: 100%;
      text-shadow: 1px 1px 5px #000; }
    .ab-team-popup-pic .ab-team-popup-pic-box .ab-team-popup-pic-box-a span, .ab-team-popup-pic .ab-team-popup-pic-box .ab-team-popup-pic-box-b span {
      font-size: 0.715em; }

#ab-team-01-popup .ab-team-popup-pic {
  background: url("../graphics/team-01-photo.jpg") top center no-repeat;
  background-size: cover; }

#ab-team-02-popup .ab-team-popup-pic {
  background: url("../graphics/team-02-photo.jpg") top center no-repeat;
  background-size: cover; }

#ab-team-03-popup .ab-team-popup-pic {
  background: url("../graphics/team-03-photo.jpg") top center no-repeat;
  background-size: cover; }

#ab-team-04-popup .ab-team-popup-pic {
  background: url("../graphics/team-04-photo.jpg") top center no-repeat;
  background-size: cover; }

#ab-team-05-popup .ab-team-popup-pic {
  background: url("../graphics/team-05-photo.jpg") top center no-repeat;
  background-size: cover; }

@media (min-width: 768px) {
  .ab-team-popup {
    max-width: 800px;
    height: 400px; }

  .ab-team-popup-grid {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    display: grid;
    grid-template-columns: 60% 40%; }

  .ab-team-popup-bio {
    grid-area: unset; }

  .ab-team-popup-pic {
    grid-area: unset;
    width: 100%;
    height: 100%; }

  #ab-team-01-popup .ab-team-popup-pic {
    background: url("../graphics/team-frame-left.png?NOCACHE=1") top left no-repeat, url("../graphics/team-01-photo.jpg") top center no-repeat;
    background-size: contain, cover; }

  #ab-team-02-popup .ab-team-popup-pic {
    background: url("../graphics/team-frame-left.png?NOCACHE=1") top left no-repeat, url("../graphics/team-02-photo.jpg") top center no-repeat;
    background-size: contain, cover; }

  #ab-team-03-popup .ab-team-popup-pic {
    background: url("../graphics/team-frame-right.png?NOCACHE=1") top right no-repeat, url("../graphics/team-03-photo.jpg") top center no-repeat;
    background-size: contain, cover; }

  #ab-team-04-popup .ab-team-popup-pic {
    background: url("../graphics/team-frame-left.png?NOCACHE=1") top left no-repeat, url("../graphics/team-04-photo.jpg") top center no-repeat;
    background-size: contain, cover; }

  #ab-team-05-popup .ab-team-popup-pic {
    background: url("../graphics/team-frame-right.png?NOCACHE=1") top right no-repeat, url("../graphics/team-05-photo.jpg") top center no-repeat;
    background-size: contain, cover; }

  #ab-team-03-popup .ab-team-popup-grid, #ab-team-05-popup .ab-team-popup-grid {
    display: grid;
    grid-template-columns: 40% 60%; }

  #ab-team-03-popup .ab-team-popup-bio, #ab-team-05-popup .ab-team-popup-bio {
    grid-area: 1 / 2 / 2 / 3; }

  #ab-team-03-popup .ab-team-popup-pic, #ab-team-05-popup .ab-team-popup-pic {
    grid-area: 1 / 1 / 2 / 2; } }
@media (min-width: 1024px) {
  .ab-team-popup {
    max-width: 1000px;
    height: 400px; }

  .ab-team-popup-bio {
    padding: 50px; } }
@media (min-width: 1280px) {
  .ab-team-popup-grid {
    display: grid;
    grid-template-columns: 65% 35%; }

  #ab-team-03-popup .ab-team-popup-grid {
    display: grid;
    grid-template-columns: 35% 65%; }

  .ab-team-popup {
    max-width: 1200px;
    height: 400px; } }
@media (min-width: 1366px) {
  .ab-team-popup-bio {
    padding: 75px 50px; } }
@media (min-width: 1500px) {
  .ab-team-popup {
    max-width: 1350px;
    height: 400px; }

  .ab-team-popup-bio {
    padding: 75px; } }
/*  -------------------------------------------
   TEAM 
-----------------------------------------------*/
.ab-sec-team {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%; }

.team-grid-container {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  position: relative; }
  .team-grid-container img {
    display: block;
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    height: auto; }
  .team-grid-container .team-grid {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    display: grid;
    grid-template-columns: 33.33% 33.33% 33.33%;
    grid-template-rows: 100%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0; }
    .team-grid-container .team-grid .team-grid-item {
      box-sizing: border-box;
      padding: 10px;
      margin: 0;
      width: 100%;
      height: 100%;
      cursor: pointer;
      position: relative; }
      .team-grid-container .team-grid .team-grid-item .team-grid-item-box {
        display: block;
        box-sizing: border-box;
        padding: 0 0 0 5px;
        margin: 0;
        position: absolute;
        bottom: 15px;
        left: 5px;
        border-left: 1px #C10230 solid;
        font-family: "PrimaryFontLight", sans-serif; }
        .team-grid-container .team-grid .team-grid-item .team-grid-item-box .team-grid-item-box-a, .team-grid-container .team-grid .team-grid-item .team-grid-item-box .team-grid-item-box-b {
          box-sizing: border-box;
          padding: 0;
          margin: 0;
          width: 100%;
          line-height: 100%; }
        .team-grid-container .team-grid .team-grid-item .team-grid-item-box .team-grid-item-box-a span, .team-grid-container .team-grid .team-grid-item .team-grid-item-box .team-grid-item-box-b span {
          font-size: 0.715em; }
  .team-grid-container .teamB-grid {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    display: grid;
    grid-template-columns: 16.67% 33.33% 33.33% 16.67%;
    grid-template-rows: 100%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0; }
    .team-grid-container .teamB-grid .team-grid-item {
      box-sizing: border-box;
      padding: 10px;
      margin: 0;
      width: 100%;
      height: 100%;
      cursor: pointer;
      position: relative; }
      .team-grid-container .teamB-grid .team-grid-item .team-grid-item-box {
        display: block;
        box-sizing: border-box;
        padding: 0 0 0 5px;
        margin: 0;
        position: absolute;
        bottom: 15px;
        left: 5px;
        border-left: 1px #C10230 solid;
        font-family: "PrimaryFontLight", sans-serif; }
        .team-grid-container .teamB-grid .team-grid-item .team-grid-item-box .team-grid-item-box-a, .team-grid-container .teamB-grid .team-grid-item .team-grid-item-box .team-grid-item-box-b {
          box-sizing: border-box;
          padding: 0;
          margin: 0;
          width: 100%;
          line-height: 100%; }
        .team-grid-container .teamB-grid .team-grid-item .team-grid-item-box .team-grid-item-box-a span, .team-grid-container .teamB-grid .team-grid-item .team-grid-item-box .team-grid-item-box-b span {
          font-size: 0.715em; }
  .team-grid-container .team-grid-bg0 {
    background: url("../graphics/team-00.jpg") top left no-repeat;
    background-size: cover; }
  .team-grid-container .team-grid-bg1 {
    background: url("../graphics/team-01.jpg") top left no-repeat;
    background-size: cover; }
  .team-grid-container .team-grid-bg2 {
    background: url("../graphics/team-02.jpg") top left no-repeat;
    background-size: cover; }
  .team-grid-container .team-grid-bg3 {
    background: url("../graphics/team-03.jpg") top left no-repeat;
    background-size: cover; }
  .team-grid-container .teamB-grid-bg0 {
    background: url("../graphics/teamB-00.jpg") top left no-repeat;
    background-size: cover; }
  .team-grid-container .teamB-grid-bg1 {
    background: url("../graphics/teamB-01.jpg") top left no-repeat;
    background-size: cover; }
  .team-grid-container .teamB-grid-bg2 {
    background: url("../graphics/teamB-02.jpg") top left no-repeat;
    background-size: cover; }

@media (min-width: 600px) {
  .team-grid-container .team-grid .team-grid-item .team-grid-item-box {
    padding: 0 0 0 10px;
    position: absolute;
    bottom: 25px;
    left: 10px; } }
@media (min-width: 768px) {
  .team-grid-container .team-grid .team-grid-item .team-grid-item-box {
    padding: 0 0 0 10px;
    position: absolute;
    bottom: 25px;
    left: 25px; } }
@media (min-width: 1280px) {
  .team-grid-container .team-grid .team-grid-item .team-grid-item-box {
    padding: 0 0 0 15px;
    position: absolute;
    bottom: 50px;
    left: 25px; } }
/*  -------------------------------------------
   BELIEFS AND VALUES 
-----------------------------------------------*/
.beliefs-values-grid-container {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  position: relative; }
  .beliefs-values-grid-container img {
    display: block;
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    height: auto; }
  .beliefs-values-grid-container .beliefs-values-grid {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%;
    display: grid;
    grid-template-columns: 50% 50%;
    grid-template-rows: 50% 50%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0; }
    .beliefs-values-grid-container .beliefs-values-grid .beliefs-values-grid-item {
      box-sizing: border-box;
      padding: 0;
      margin: 0;
      width: 100%;
      height: 100%;
      cursor: pointer; }
  .beliefs-values-grid-container .beliefs-values-grid-bg1 {
    background: url("../graphics/beliefs-values-01.png") top left no-repeat;
    background-size: cover; }
  .beliefs-values-grid-container .beliefs-values-grid-bg2 {
    background: url("../graphics/beliefs-values-02.png") top left no-repeat;
    background-size: cover; }
  .beliefs-values-grid-container .beliefs-values-grid-bg3 {
    background: url("../graphics/beliefs-values-03.png") top left no-repeat;
    background-size: cover; }
  .beliefs-values-grid-container .beliefs-values-grid-bg4 {
    background: url("../graphics/beliefs-values-04.png") top left no-repeat;
    background-size: cover; }

/*  -------------------------------------------
    OUR STORY 
-----------------------------------------------*/
.ab-ourstory-grid {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  display: grid;
  grid-template-columns: 100%; }

.ab-ourstory-grid-item-padding {
  box-sizing: border-box;
  padding: 0 0 20px 0;
  margin: 0;
  width: 100%; }

@media (min-width: 768px) {
  .ab-ourstory-grid {
    display: grid;
    grid-template-columns: 50% 50%;
    align-items: center; }

  .ab-ourstory-grid-item-padding {
    padding: 0 50px 0 0; } }
@media (min-width: 1366px) {
  .ab-ourstory-grid-item-padding {
    padding: 0 75px 0 0; } }
/*  -------------------------------------------
    UNIQUE FEATURES
-----------------------------------------------*/
.ab-uf-grid {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  display: grid;
  grid-template-columns: 100%; }

.ab-uf-grid-item-1 {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%; }

.ab-uf-grid-item-2 {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  position: relative; }
  .ab-uf-grid-item-2 .ab-uf-slider-nav {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 50px;
    height: 25px;
    position: absolute;
    bottom: 0px;
    left: 0px;
    display: grid;
    grid-template-columns: 25px 25px; }
  .ab-uf-grid-item-2 .ab-uf-slider-nav div:first-child {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 25px;
    height: 25px;
    text-align: center;
    background: #5A5A5A url("../graphics/ab-nav-arrow-left.png") center center no-repeat;
    background-size: 9px 14px;
    color: #fff;
    cursor: pointer; }
  .ab-uf-grid-item-2 .ab-uf-slider-nav div:last-child {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 25px;
    height: 25px;
    text-align: center;
    background: #C10230 url("../graphics/ab-nav-arrow-right.png") center center no-repeat;
    background-size: 9px 14px;
    color: #fff;
    cursor: pointer; }

.ab-uf-slider {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%; }

.ab-uf-slider-item {
  box-sizing: border-box;
  padding: 20px;
  margin: 0;
  width: 100%;
  height: 400px;
  background: #fff; }

.ab-uf-slider-item img {
  display: block;
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 50px;
  height: auto; }

@media (min-width: 768px) {
  .ab-uf-grid {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    display: grid;
    grid-template-columns: 40% 60%; }

  .ab-uf-slider-item {
    padding: 35px;
    margin: 0;
    height: 350px; }

  .ab-uf-grid-item-2 .ab-uf-slider-nav {
    position: absolute;
    bottom: 0px;
    left: -25px; } }
@media (min-width: 1024px) {
  .ab-uf-grid {
    display: grid;
    grid-template-columns: 30% 70%; }

  .ab-uf-slider-item {
    margin: 0 15px;
    height: 425px; }

  .ab-uf-grid-item-2 .ab-uf-slider-nav {
    position: absolute;
    bottom: 0px;
    left: -10px; } }
@media (min-width: 1366px) {
  .ab-uf-grid {
    display: grid;
    grid-template-columns: 32% 68%; }

  .ab-uf-slider-item {
    padding: 50px;
    margin: 0 25px;
    height: 475px; }

  .ab-uf-grid-item-2 .ab-uf-slider-nav {
    position: absolute;
    bottom: 0px;
    left: 1px; } }
/*  -------------------------------------------
    TOP STRATEGIES
-----------------------------------------------*/
.ab-ts-grid {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  display: grid;
  grid-template-columns: auto;
  grid-gap: 50px;
  justify-content: space-between;
  align-content: space-between; }

.ab-ts-grid-item {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  position: relative; }

.ab-ts-grid-item img {
  display: block;
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  height: auto; }

.ab-ts-grid-overlay {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  height: 100%;
  color: #fff;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.5);
  display: grid;
  align-content: center;
  cursor: pointer; }
  .ab-ts-grid-overlay .ab-ts-grid-item-txt {
    box-sizing: border-box;
    padding: 0 25px;
    margin: 0;
    width: 100%; }
  .ab-ts-grid-overlay .ab-ts-grid-item-title {
    font-weight: bold;
    text-align: center;
    padding: 0 0 25px 0;
    font-size: 1.15em;
    transition: all 0.25s ease; }
  .ab-ts-grid-overlay .ab-ts-grid-item-content {
    text-align: center;
    padding: 0;
    transition: all 0.25s ease; }
  .ab-ts-grid-overlay .ab-ts-grid-item-btn {
    display: block;
    box-sizing: border-box;
    padding: 10px 20px;
    width: 200px;
    margin: 0 auto;
    text-align: center;
    background: #fff;
    border: 1px #5A5A5A solid;
    color: #5A5A5A;
    font-weight: bold;
    position: absolute;
    bottom: -25px;
    left: 0;
    right: 0; }

.ab-ts-grid-overlay-off {
  height: 30%;
  position: absolute;
  top: unset;
  transition: height 0.25s ease; }
  .ab-ts-grid-overlay-off .ab-ts-grid-item-txt {
    padding: 0 25px; }
  .ab-ts-grid-overlay-off .ab-ts-grid-item-title {
    padding: 0;
    font-size: 1.25em; }
  .ab-ts-grid-overlay-off .ab-ts-grid-item-content {
    display: none; }
  .ab-ts-grid-overlay-off .ab-ts-grid-item-btn {
    display: none; }

@media (min-width: 768px) {
  .ab-ts-grid {
    display: grid;
    grid-template-columns: auto auto auto;
    grid-gap: 25px; }

  .ab-ts-grid-overlay .ab-ts-grid-item-txt {
    padding: 0 25px; }
  .ab-ts-grid-overlay .ab-ts-grid-item-title {
    font-size: 1.0em;
    padding: 0 0 15px 0; }
  .ab-ts-grid-overlay .ab-ts-grid-item-content {
    font-size: 0.815em; }
  .ab-ts-grid-overlay .ab-ts-grid-item-btn {
    font-size: 0.815em; }

  .ab-ts-grid-overlay-off .ab-ts-grid-item-txt {
    padding: 0 25px; }
  .ab-ts-grid-overlay-off .ab-ts-grid-item-title {
    padding: 0; }
  .ab-ts-grid-overlay-off .ab-ts-grid-item-content {
    display: none; }
  .ab-ts-grid-overlay-off .ab-ts-grid-item-btn {
    display: none; } }
@media (min-width: 1280px) {
  .ab-ts-grid {
    grid-gap: 50px; }

  .ab-ts-grid-overlay .ab-ts-grid-item-txt {
    padding: 0 25px; }
  .ab-ts-grid-overlay .ab-ts-grid-item-title {
    font-size: 1.15em;
    padding: 0 0 35px 0; }
  .ab-ts-grid-overlay .ab-ts-grid-item-content {
    font-size: 1.0em; }
  .ab-ts-grid-overlay .ab-ts-grid-item-btn {
    font-size: 1.0em; }

  .ab-ts-grid-overlay-off .ab-ts-grid-item-txt {
    padding: 0 25px; }
  .ab-ts-grid-overlay-off .ab-ts-grid-item-title {
    padding: 0;
    font-size: 1.25em; }
  .ab-ts-grid-overlay-off .ab-ts-grid-item-content {
    display: none; }
  .ab-ts-grid-overlay-off .ab-ts-grid-item-btn {
    display: none; } }
/*  -------------------------------------------
    QUOTATION 
-----------------------------------------------*/
.ab-quotation {
  box-sizing: border-box;
  padding: 0 0 0 25px;
  margin: 0;
  width: 100%;
  background: url("../graphics/quote-start.png") 0px 0px no-repeat;
  background-size: 20px; }

.ab-quotation p {
  font-family: "PrimaryFontLight", sans-serif; }

.ab-quotation div {
  font-size: 0.875em;
  line-height: 115%;
  text-align: right;
  padding: 0 15px 0 0;
  border-right: 1px #5A5A5A solid; }

.ab-quotation div span {
  font-size: 0.875em; }

.ab-quotation-end {
  display: inline-block;
  position: absolute;
  box-sizing: border-box;
  padding: 0;
  margin: 0 0 0 3px;
  width: 20px;
  height: 38px;
  background: url("../graphics/quote-end.png") 0px 10px no-repeat;
  background-size: 20px; }

/*  -------------------------------------------
    CMG INTRO SEC
-----------------------------------------------*/
.ab-cmg-intro-sec {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  position: relative; }
  .ab-cmg-intro-sec img {
    display: block;
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 100%; }
  .ab-cmg-intro-sec .ab-cmg-intro-sec-grid-container {
    display: block;
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%; }
    .ab-cmg-intro-sec .ab-cmg-intro-sec-grid-container .ab-cmg-intro-sec-grid {
      display: block;
      box-sizing: border-box;
      padding: 0;
      margin: 0;
      width: 100%; }
      .ab-cmg-intro-sec .ab-cmg-intro-sec-grid-container .ab-cmg-intro-sec-grid .ab-cmg-intro-sec-box {
        box-sizing: border-box;
        padding: 35px 25px;
        margin: -25px 0 0 0;
        width: 100%;
        background: #C10230;
        color: #fff;
        font-family: "PrimaryFontLight", sans-serif;
        line-height: 150%; }

@media (min-width: 768px) {
  .ab-cmg-intro-sec {
    position: relative; }
    .ab-cmg-intro-sec img {
      width: 60%;
      height: 100%; }
    .ab-cmg-intro-sec .ab-cmg-intro-sec-grid-container {
      width: 100%;
      height: 100%;
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      display: grid;
      align-items: center; }
      .ab-cmg-intro-sec .ab-cmg-intro-sec-grid-container .ab-cmg-intro-sec-grid {
        width: 100%;
        display: grid;
        grid-template-columns: 70%;
        justify-content: end; }
        .ab-cmg-intro-sec .ab-cmg-intro-sec-grid-container .ab-cmg-intro-sec-grid .ab-cmg-intro-sec-box {
          width: 100%;
          padding: 25px;
          margin: 0; } }
@media (min-width: 1024px) {
  .ab-cmg-intro-sec .ab-cmg-intro-sec-grid-container .ab-cmg-intro-sec-grid {
    grid-template-columns: 60%; }
    .ab-cmg-intro-sec .ab-cmg-intro-sec-grid-container .ab-cmg-intro-sec-grid .ab-cmg-intro-sec-box {
      padding: 50px 45px;
      width: 100%; } }
@media (min-width: 1280px) {
  .ab-cmg-intro-sec .ab-cmg-intro-sec-grid-container .ab-cmg-intro-sec-grid {
    grid-template-columns: 55%; }
    .ab-cmg-intro-sec .ab-cmg-intro-sec-grid-container .ab-cmg-intro-sec-grid .ab-cmg-intro-sec-box {
      padding: 70px 50px; } }
/*  -------------------------------------------
    REPORT ACCESS SEC
-----------------------------------------------*/
.ab-report-access-sec {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%; }
  .ab-report-access-sec .ab-report-access-sec-item {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%; }

@media (min-width: 768px) {
  .ab-report-access-sec {
    display: grid;
    grid-template-columns: 45% 55%;
    justify-content: space-between; } }
/*  -------------------------------------------
    PROFILE FORM
-----------------------------------------------*/
.ab-ec-msg-box {
  font-size: 0.725em;
  padding: 5px 10px; }

.ab-ec-msg-error {
  color: #c00; }

.ab-ec-msg-success {
  color: #090; }

.ab-profile-form-container a {
  color: #C10230; }

.ab-profile-form-container a:hover {
  color: #5A5A5A; }

.ab-profile-form {
  box-sizing: border-box;
  padding: 0;
  margin: 0 auto;
  width: 100%;
  max-width: 500px;
  border: 0; }

.ab-profile-form-space {
  box-sizing: border-box;
  padding: 10px 0 0 0;
  margin: 0; }

.ab-profile-form input[type=text] {
  box-sizing: border-box;
  padding: 15px 25px;
  margin: 6px 0;
  width: 100%;
  border: 0;
  border-radius: 5px; }

.ab-profile-form input[type=email] {
  box-sizing: border-box;
  padding: 15px 25px;
  margin: 6px 0;
  width: 100%;
  border: 0;
  border-radius: 5px; }

.ab-profile-form input[type=password] {
  box-sizing: border-box;
  padding: 15px 25px;
  margin: 6px 0;
  width: 100%;
  border: 0;
  border-radius: 5px; }

.ab-profile-form input[type=submit] {
  box-sizing: border-box;
  padding: 15px 50px;
  margin: 6px 0;
  border: 0;
  border-radius: 5px;
  background: #5A5A5A;
  color: #fff; }

.ab-profile-form input[type=submit]:hover {
  background: #C10230; }

/*  -------------------------------------------
    SCHEDULE SECTION (form-contact.php)
-----------------------------------------------*/
.ab-sec-schedule {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 100%;
  background: url("../graphics/ab-sec-schedule-bg.jpg") top center no-repeat;
  background-size: cover; }

.ab-sec-schedule-container {
  box-sizing: border-box;
  padding: 50px 0;
  margin: 0;
  width: 100%;
  color: #fff; }
  .ab-sec-schedule-container h2 {
    margin: 0; }
  .ab-sec-schedule-container h2, .ab-sec-schedule-container p, .ab-sec-schedule-container ul, .ab-sec-schedule-container li {
    color: #fff; }
  .ab-sec-schedule-container .ab-prj-list-white-triangle {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    width: 100%;
    list-style: none; }
    .ab-sec-schedule-container .ab-prj-list-white-triangle li {
      box-sizing: border-box;
      padding: 0 0 10px 20px;
      margin: 0;
      width: 100%;
      background: url("../graphics/ab-prj-list-white-triangle.png") 1px 7px no-repeat;
      background-size: 8px 12px; }

.ab-schdule-link {
  display: inline-block;
  box-sizing: border-box;
  padding: 15px 25px;
  margin: 0;
  width: 100%;
  max-width: 400px;
  text-align: center;
  border-radius: 5px;
  background: #C10230;
  color: #fff; }

.ab-schdule-link:hover {
  background: #5A5A5A;
  color: #fff; }

.ab-schdule-link-reverse {
  display: inline-block;
  box-sizing: border-box;
  padding: 15px 25px;
  margin: 0;
  width: 100%;
  max-width: 400px;
  text-align: center;
  border-radius: 5px;
  background: #5A5A5A;
  color: #fff; }

.ab-schdule-link-reverse:hover {
  background: #C10230;
  color: #fff; }

.ab-schdule-link-space {
  display: inline-block;
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  width: 5px; }

@media (min-width: 768px) {
  .ab-schdule-link-space {
    display: block;
    height: 10px; } }
@media (min-width: 1024px) {
  .ab-schdule-link-space {
    display: inline-block;
    width: 35px; } }

/*# sourceMappingURL=default.css.map */
