/*====================*/
/*=== Thanks for taking the time to read ===*/
/*====================*/

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;600&display=swap');

/* Some basic animations */
@keyframes fadeup { 0% { opacity:0; } 100% {opacity:1;} }
#wrapper.transitionOut { opacity:0;}
#wrapper { animation-duration:1s; animation-name:fadeup; opacity:1;}

/* Some basic animations */
@keyframes slideUp { 0% { margin-bottom:-40px; opacity: 0; } 100% {margin-bottom:0; opacity: 1;} }
.slideUp { animation-duration:1s; animation-name:slideUp; margin-bottom:0; opacity: 1;}

@keyframes slidePush { 0% { padding-top:40px; opacity: 0; } 100% {padding-top:0; opacity: 1;} }
.slidePush { animation-duration:1s; animation-name:slidePush; padding-top:0; opacity: 1;}

@media ( min-width: 1200px){ .container{ width:1500px; max-width:100%; }}

.theme-checkbox { float:right; margin-top:3px;  z-index:10; opacity:.8; /* Set the global opacity of the switch*/ }
.checkbox { opacity: 0; position: absolute; height:inherit;  }
.checkbox-label {  width: 52px; height: 26px; border-radius: 50px; position: relative; padding: 0px; cursor: pointer; display: flex; justify-content: space-between; align-items: center; color:#000; border:solid 1px rgba(0,0,0,0.5);  }
.checkbox-label .ball { background-color: #000; width: 22px; height: 22px; position: absolute; left: 2px; top: 1px; border-radius: 50%; transition: transform 0.2s linear; }
.checkbox:checked + .checkbox-label .ball {transform: translateX(24px);}
.checkbox-label i { padding:5px; top:3px; position:relative; top:2px;}
.checkbox-label i svg { fill:#000; }

/* Smooth state transitions */
.transitionOut {}
.transitionIn {}
.tr-gone { transition: .5s;}
.tr-slideUp,.tr-slideDown { transition: 1s; margin-top: inherit; animation-timing-function: ease-in; -webkit-animation-timing-function: ease-in;}
.transitionOut .tr-gone { opacity: 0;}
.transitionOut .tr-slideDown  { opacity: 0; display: block; margin-top:-50px!important; transition: .3s; animation-timing-function: ease-out; -webkit-animation-timing-function: ease-out; }
.transitionOut .tr-slideUp  { opacity: 0; display: block; margin-top:50px!important; transition: .3s; animation-timing-function: ease-out; -webkit-animation-timing-function: ease-out; }

.transitionOut #logo { bottom: 0; opacity: 0; margin-bottom: -50px;}
.logo { transition: 1s;}

/* Scrolling menu only */
#menu-wrapper { z-index:50; display:block; position:relative; height: 60px;}
#header.fix #menu-wrapper { position:fixed; top:0; left:0; right:0; }
#menu-wrapper-faux { width:100%; display:none; height:60px; }

.canvas { overflow:hidden; position:relative; display:block;}

#oldie { background:#2b333c; color:#fff; padding:10px 15px; position:fixed; bottom:0; left:0; right:0; z-index:900; font-size:12px;}

body { font-size: 14px; position: relative; overflow-y: scroll!important; font-weight:normal; margin-bottom:0!important; color: #111; background:#fff; }
body,h1,h2,h3,h4,h5,h6,.tp-caption{ font-family: 'Inter', sans-serif; text-rendering: optimizelegibility; font-weight:300;  }



.notice { text-transform: none; font-size: 13px; text-align: center; line-height: 20px; background: #eee; padding: 20px; }

/*@media ( min-width: 800px){.container.thin{ max-width:840px; }}*/

h1 { font-size:28px;}
h2 { font-size:24px;}
h3 { font-size:18px;}


.b-lazy { visibility: hidden; opacity: 0!important; transition: .3s; }
.b-loaded { visibility: visible; opacity: 1!important;}
.bkg-image { position: absolute; top:0; bottom:0; left: 0; right:0; background-position: center; background-size: cover;}

a,a:focus,a:hover {color:#f4ce00; text-decoration:none;}

blockquote { font-size:inherit; font-style:italic; background:rgba(255,255,255,.05);}

.main strong { color: #f4ce00;}

strong,b { font-weight:bold;}

.anim-in.off { opacity:0; padding-top:100px;}

.clear_break { display:block; height:30px; width:100%; clear:both; float:none;}

.horizontal_break_pull { display:block; height:20px; margin:0 0 30px 0; clear:both; background:#eee; position:relative;
-moz-box-shadow:inset 0 0 10px rgba(0,0,0,0.42); -webkit-box-shadow:inset 0 0 10px rgba(0,0,0,0.42); box-shadow:inset 0 5px 5px rgba(0,0,0,0.08);}

hr,.horizontal_break { display:block; height:1px; margin:0; background:rgba(255,255,255,.1)!important; border:none; clear:both; margin:40px 0;}

.button { padding:10px 22px; border:solid 1px #333; color:#333; font-weight:600; display:inline-block;}
.button:hover {border:solid 1px #f4ce00; background:#f4ce00; color:#fff;}

.btn {-webkit-border-radius:0px;-moz-border-radius:0px; border-radius:0px;}

.rounded {-webkit-border-radius:50px;-moz-border-radius:50px; border-radius:50px; }

.btn-primary { border:none; }
.btn-primary,a.orange { position:relative; overflow:hidden; display:inline-block;  padding:15px 40px; font-weight:600; border: solid 2px #f4ce00; color:#f4ce00; background:none;  text-decoration:none!important; text-transform: uppercase; font-weight: normal; letter-spacing:.1em; font-size: 13px; font-weight: bold;}
.btn-primary:hover,.btn-primary:active,.btn-primary:focus,a.orange:focus,a.orange:hover,a.orange:active { background:#fff; color:#fff; border:solid 2px #f4ce00; background:none;  }
.btn-wide { display:block; width:100%;}


.btn-default { border:none; }
.btn-default { position:relative; overflow:hidden; display:inline-block;  padding:15px 40px; font-weight:600; border: none; color:#f4ce00; background:none;  text-decoration:none!important; text-transform: uppercase; font-weight: normal; letter-spacing:.1em; font-size: 13px; font-weight: bold;
    background: -webkit-linear-gradient(left,#f4ce00,#d8ae00);
    background: -o-linear-gradient(left,#f4ce00,#d8ae00);
    background: -moz-linear-gradient(left,#f4ce00,#d8ae00);
    background: linear-gradient(left,#f4ce00,#d8ae00);
}
.btn-default:hover,.btn-primary:active,.btn-default:focus { color:#000; }

.grad {  background: -webkit-linear-gradient(left,#f4ce00,#d8ae00);
    background: -o-linear-gradient(left,#f4ce00,#d8ae00);
    background: -moz-linear-gradient(left,#f4ce00,#d8ae00);
    background: linear-gradient(left,#f4ce00,#d8ae00); }

#top-bar {   }
#top-bar a { color:#000; font-weight:600; }
#top-bar .social-links { float:right; display:inline-block;  margin:0; padding:5px 0 0;}
#top-bar .social-links a {  color:#000; font-weight:normal; font-size:16px; margin-right:10px;  }
#top-bar ul.menu { display:inline-block; list-style:none; float:left; margin:0; padding:5px 0;}
#top-bar ul li { float:left; display:inline-block; margin-right:30px;}
#top-bar #contacts { float:right; padding:5px 0;}
#top-bar #contacts a { margin-left:30px;}
#top-bar #contacts a span {  color:#000;}

.sbi_load_btn {-webkit-border-radius:0px!important;-moz-border-radius:0px!important; border-radius:0px!important; padding: 15px 30px!important;}

.download_sheet { text-decoration: none!important; display: block; text-align: center; background: #fff; border: solid 2px #1a69b3; padding: 10px 0; margin-top: 30px; display: block;  clear: both;}
.download_sheet span { margin-left: 15px;}
.download_sheet:hover { color: #fff; background: #1a69b3; }

/* Icon box */
.iconbox { display: inline-block; float: left; border-top: solid 1px #eee; width: 50%; box-sizing: border-box; padding: 20px; position: relative; min-height: 240px; line-height: 20px;}
.iconbox:nth-child(odd) { }
.iconbox span { width: 50px; height: 50px; font-size: 38px; display: inline-block; float: left; margin:0 15px 15px 0; color: #1a69b3 ;}
.iconbox p { clear: both;}
.iconbox h3 { margin: 10px 0 15px; font-size: 16px; line-height: 20px;}

.iconbox.small { border: none; min-height: inherit; padding: 5px 15px; }
.iconbox.small h3 {font-size: 13px;}

.iconbox.smaller { border: none; min-height: 80px; padding: 5px 15px; }
.iconbox.smaller h3 {font-size: 13px; text-transform: none; }

.iconbox.short { min-height: 100px;}

.menu-navigation-container li a,.ghost img,.ghost div ,.ghost h2:after,#links a:after,#cta-box span,#cta h2:after,#scroll-header,.ghost-service img,.ghost-service h2:after,.service-drop-small,.service-banner .blue-tint,.service-banner .tint,.service-banner h2,.btn,.rslides_nav,.single-service span,#slider #cats a,.download_sheet,#cta a,.rslides .info a {-webkit-transition: all 0.2s; -moz-transition: all 0.2s; -ms-transition: all 0.2s; -o-transition: all 0.2s; transition: all 0.2s; }

.searchform input[type=text],.service-dropdown,.menu-navigation-container .dropdown-menu,#header:before,#info,#banner .title,.ghost div,.menu-navigation-container .dropdown-menu li a:after,.ghost-dropdown div,.ghost h2,.ghost .dots,#slider #info,#controls .control .arr,.item > b,.rslides .info,.rslides img {-webkit-transition: all 0.4s; -moz-transition: all 0.4s; -ms-transition: all 0.4s; -o-transition: all 0.4s; transition: all 0.4s;}

#accordion-menu li,#accordion-menu li *,#page-controls form > div,#page-controls form > span,.gallery .overlay{-webkit-transition: all 0.6s; -moz-transition: all 0.6s; -ms-transition: all 0.6s; -o-transition: all 0.6s; transition: all 0.6s;}


body,.main ul li:before,.b-lazy {-webkit-transition: all 1s; -moz-transition: all 1s; -ms-transition: all 1s; -o-transition: all 1s; transition: all 1s; -webkit-animation-timing-function: ease-out; animation-timing-function: ease-out;}

#contact-details { display:block; font-size: 16px; position: absolute; top:10px; right:30px; color: #333; opacity: 1; }
#contact-details a { color: #333; margin-left: 20px;}

.logo { width: 290px; background:url('../images/logo.svg'); background-position:center center; height:100%; background-size:contain; background-repeat:no-repeat;   display:inline-block;  outline: none!important; top:0px; padding:0!important; text-indent:-9999px;}
.logo a { padding:0 30px; height:70px; }
.logo img { width:100%; overflow:hidden;}

#header,.logo,#toggle-holder,.menu-navigation-container,#contact-details {-ms-transition: all .15s; -o-transition: all .15s; transition: all .15s;}
#header { background:#2d2f39; color:#fff;  display:block; min-height: 100px;z-index:50; position: relative;}

.main table { width:100%;}

/* Search */
.searchform { position:absolute; width:220px; overflow: hidden; bottom:0px; right: 30px;   }
.searchform > div { z-index:100; position:relative;}
.searchform > div > span { display:block; position:relative; width:180px!important;  }
.searchform > div input[type=text]::-webkit-input-placeholder { color: #bbb; font-size: 13px; }
:-moz-placeholder {color:#bbb; opacity:1;}::-moz-placeholder {color:#bbb; opacity:1;}:-ms-input-placeholder{color:#bbb; opacity:1;}
.searchform > div input[type=text] { border: none; padding: 5px 0 5px 10px; outline: none; width: 160px; }
.searchform > div > span > input,.tt-dropdown-menu { width:100%; padding:1px 5px; border:none!important; /*background:#eee!important;*/ }
.searchform > div > i { position: absolute; padding:3px; top:0px; right:0px; font-size: 18px;}
.searchform > div input[type=submit] { border:none; background:none; color:#333; width:100%; text-indent:-9999px; position:absolute; top:0; bottom:0; left:0; right:0; }

#trigger-menu.fix { top: 22px;}

/* Main menu */
.menu-navigation-container { display:block; width:100%; margin: 15px auto!important; }
.menu-navigation-container > ul { margin: 0; padding: 0; display:-ms-flexbox; display:-webkit-flex; display:flex; text-align: center; justify-content:space-between; flex-wrap: wrap; flex-direction: row; align-items:center;}
.menu-navigation-container > ul > li { width:13.3%; display:inline-block; list-style: none; position: relative; }
.menu-navigation-container > ul > li.logo { width:20%; }
.menu-navigation-container li a {  border-bottom:0; outline: none; display: block; color:#999; position: relative; padding:0px 0px;  text-transform: uppercase; font-size: 14px; letter-spacing: .05em; font-weight: 600;}

.menu-navigation-container > ul > li.current-menu-item a { color: #fff;  }
.menu-navigation-container > ul > li.current-menu-item a:hover,.menu-navigation-container > ul > li a:hover { color: #fff;  }
.menu-navigation-container li.active a { }
.menu-navigation-container > ul > li a:hover {}
.menu-navigation-container .caret { display: none;}

.white-bkg { background:#fff;}

/* Dropdowns */
.menu-navigation-container li ul { width:auto; display:block; opacity:0; padding:0 0 10px; margin:0; position:absolute; border:none; -webkit-border-radius:0;-moz-border-radius:0; border-radius:0; background: rgba(0,0,0,.8); visibility: collapse; left: -20px;}
.menu-navigation-container li ul li a { display:block; width:100%; box-sizing:border-box; border:none; color:rgba(255,255,255,.7); padding: 7px 20px!important; font-size:13px;}

.menu-navigation-container li:hover ul {opacity:1; visibility: visible;}
.menu-navigation-container li ul li a:hover,.dropdown-menu > .active > a, .dropdown-menu > .active > a:focus, .dropdown-menu > .active > a:hover  {  background:#000!important; color:#fff!important;}

.menu-navigation-container .dropdown-menu li.current-menu-item:hover a { background: none;}

.menu-navigation-container .dropdown-menu.constant { visibility: visible; opacity: 1;}
.menu-navigation-container .dropdown-menu.constant.off { visibility: hidden; opacity: 0;}
.menu-navigation-container .dropdown-menu.on { visibility: visible; opacity: 1;}
.menu-navigation-container .dropdown-menu.on.constant.off { visibility: visible; opacity: 1;}

/* Overlay style for huge menu */
.overlay-hugeinc {  visibility: hidden; position: fixed; width: 100%; height: 100%; top: 0; left: 0; z-index:100; background: rgba(0,0,0,0.9); }
.overlay-hugeinc nav { text-align: center; position: relative; top:50%; height:70%; font-size:15px; -webkit-transform: translateY(-50%); transform: translateY(-50%); }
.overlay-hugeinc .menu-mobile-menu-container > ul { list-style: none; padding: 0; margin: 0 auto; height:75vh; position: relative; display: table; }
.overlay-hugeinc ul li {  display: table-row;}
.overlay-hugeinc ul li a { position:relative; text-decoration:none; outline:none; background:none!important; font-weight:700; margin-right:-0.1em; letter-spacing:0.1em; display:inline-block; color: #fff!important; -webkit-transition: color 0.2s; transition: color 0.2s;  vertical-align: central; font-size:16px; border: none!important; }
.overlay-hugeinc ul li a:hover, .overlay ul li a:focus { color: rgba(255,255,255,0.9); }
.overlay-hugeinc ul li .dropdown-menu { display: block; visibility: visible; position: relative; }

/* Effects */
.overlay-hugeinc { opacity: 0; visibility: hidden; -webkit-transition: opacity 0.5s, visibility 0s 0.5s; transition: opacity 0.5s, visibility 0s 0.5s; }
.overlay-hugeinc.open {  opacity: 1; visibility: visible; -webkit-transition: opacity 0.5s; transition: opacity 0.5s; }
.overlay-hugeinc nav { -webkit-perspective: 1200px; perspective: 1200px; }
.overlay-hugeinc nav ul { opacity: 0.4; -webkit-transform: translateY(-25%) rotateX(35deg); transform: translateY(-25%) rotateX(35deg); -webkit-transition: -webkit-transform 0.5s, opacity 0.5s; transition: transform 0.5s, opacity 0.5s; }
.overlay-hugeinc.open nav ul { opacity: 1; -webkit-transform: rotateX(0deg); transform: rotateX(0deg); }
.overlay-hugeinc.close nav ul { -webkit-transform: translateY(25%) rotateX(-35deg); transform: translateY(25%) rotateX(-35deg); }

/* Highlight hover effect */
.overlay-hugeinc ul li a:before {content:""; display:block; position:absolute; margin:0 auto; bottom:0%; left:0; right:0; width:0%; background:rgba(0,0,0,0.00); height:2px;}


.mobile-logo { background:#333; display:block;}
.mobile-logo img { margin:10px 15px; max-width:70%;}

/*Animating hamburger menu - amimate to x*/
.mobile-search { display:none; float:none; position:relative; margin-top:50px; width:100%; padding:10px; margin-bottom:-50px;}
.mobile-search .twitter-typeahead { width:85%!important;}
.mobile-search div input[type="text"] { opacity:1; width: 100%;}

#trigger-overlay { background:none; z-index:500; border:none; top:22px; display:block; right:15px; text-indent:-9999px; position:absolute; visibility:visible!important; }
#trigger-overlay:active { padding:0; margin:0;}
.c-hamburger { display: block; position: relative; margin: 0; padding: 0; overflow:visible; width: 32px; height: 32px;  appearance: none; box-shadow: none; border:none; cursor: pointer; }
.c-hamburger:focus { outline: none; }
.c-hamburger span { display: block; position: absolute; top: 14px; left:0; right:0; height: 3px; background:#fff; }
.c-hamburger span::before, .c-hamburger span::after { position: absolute; display: block; left: 0; width: 100%; height: 3px; background-color:#fff; content: ""; }
.c-hamburger span::before { top: -8px; }
.c-hamburger span::after { bottom: -8px; }
.c-hamburger--htx span { transition: background 0s 0.3s; }
.c-hamburger--htx span::before, .c-hamburger--htx span::after { transition-duration: 0.3s, 0.3s; transition-delay: 0.3s, 0s; }
.c-hamburger--htx span::before { transition-property: top, transform; }
.c-hamburger--htx span::after { transition-property: bottom, transform; }
/* active state, i.e. menu open */
.c-hamburger--htx.is-active span { background: none; }
.c-hamburger--htx.is-active span::before { top: 0; transform: rotate(45deg); }
.c-hamburger--htx.is-active span::after { bottom: 0; transform: rotate(-45deg); }
.c-hamburger--htx.is-active span::before, .c-hamburger--htx.is-active span::after { transition-delay: 0s, 0.3s; background-color:#fff; }

.grey_grad {
    box-shadow:0 0 4px 0 rgba(0,0,0,.1);
    background: -webkit-linear-gradient(top,#fff,#f4f4f4);
    background: -o-linear-gradient(top,#fff,#f4f4f4);
    background: -moz-linear-gradient(top,#fff,#f4f4f4);
    background: linear-gradient(top,#fff,#f4f4f4);
    }


    /* Welcome video */
#slider { clear-after:both; float: left; width: 100%; position: relative;  margin:0; z-index: 1; min-height:70%; }

#slider .overlay  { position: absolute; top:0; bottom: 0; left: 0; right:0; background: rgba(0,0,0,.1); }

.rslides {  position:relative; list-style: none; overflow: hidden; width: 100%; padding: 0; margin: 0; height:100%; }
.rslides li { min-height:calc(100vh - 200px); -webkit-backface-visibility: hidden; position: absolute; display:none; width: 100%;  height:100%; background-position:center top; background-size:cover; background-repeat:no-repeat; z-index:20; display: flex; align-items: center; justify-content: center; flex-direction:row-reverse; }
.rslides li h1 { font-size: 42px; font-weight: bold; line-height: 38px; margin: 0px 0 15px; text-transform:none;   }
.rslides li h2 { background:#f4ce12; display:inline-block; padding:10px 20px; border-radius:4px; color:#111; font-size: 20px; line-height: 24px;  margin: 0px 0 30px;   font-weight:bold; text-transform:none;}
.rslides li h3 {  font-size: 14px; line-height: 24px; max-width: 850px; margin: 0 auto 10px;  text-transform: none; }
.rslides img { display:inline-block; margin:5vh 0; height:500px; animation-delay: 1s;}
.rslides .info {color: #111; margin-left:130px; display:inline-block; max-width:600px; opacity:0; animation-delay: 1s; }
.rslides .info a { border-radius:4px; display:inline-block; margin: 40px 0 0;  font-weight: bold; text-transform: uppercase; border:solid 3px #f4ce12; padding:15px 30px; color:#111;}
.rslides .info a:hover { color: #000;}

.rslides .rslides1_on .info { opacity:1; margin-left:60px; }


.rslides li.particle-holder h2 { font-size: 52px; }

#slider .rslides_nav { margin:0;  color:#111; line-height:50px;  opacity:0; z-index:150; position:absolute; top:50%;  display:block; width:30px; height:50px; outline:none!important; background:rgba(255,255,255,0.3); padding: 0 8px; }
#slider .rslides_nav:hover { background:rgba(255,255,255,0.5);}
#slider .rslides_nav.prev { left:0;}
#slider .rslides_nav.next { right:0;}
#slider:hover .rslides_nav { opacity:1;}

.rslides_tabs { text-align:center; display:-ms-flexbox; display:-webkit-flex; display:flex; text-align: center; justify-content:space-between; flex-wrap: wrap; flex-direction: row; padding:15px 30px; margin:0 auto 30px; max-width:1400px;  }
.rslides_tabs li { display:inline-block; list-style:none;}
.rslides_tabs li a {color:#999;  font-weight:600; font-size:18px; padding:10px 20px; border-radius:4px; border:solid 3px transparent;}
.rslides_tabs li.rslides_here a { color:#111; border:solid 3px #f4ce00; background:#f4ce00; box-shadow:0 0 4px 0px rgba(0,0,0,.1); }

/* Home products */
#home-products { padding:40px 0 0; position:relative; color:#000;}
#home-products .col-xs-12 { text-align: center; border-bottom: solid 1px rgba(255,255,255,.1); padding-bottom:40px; margin-bottom: 30px; }
#home-products .image-wrap { width: 200px; height: 230px; margin:10px 40px 20px 0; }
#home-products .overlay {  opacity:0; position: absolute; top:0; bottom:0; left:0; right:0;}
#home-products h2 { font-size: 15px; font-weight: bold;}
#home-products img { width: 100%; }
#home-products .btn { margin:20px auto 40px; text-align: center;}

#home-products  .col-xs-12 { text-align: left; position:relative; box-sizing:border-box; }
#home-products img { width:300px; float:left; margin-top:50px;}
#home-products .info { background:#f4ce00; float:right; max-width:800px; padding:30px 40px; }
#home-products .info h2 { line-height:22px; margin-top:0; font-size:14px; border-left:solid 2px #000; padding-left:10px;}
#home-products .info h3 { font-size:16px;}
#home-products .image-wrap { float: left; margin-right: 40px;}

#home-products .col-xs-12{ text-align: left; }
#home-products .col-xs-12:nth-child(even) { border-bottom: none; }
#home-products .col-xs-12:nth-child(even) .image-wrap { float: right; margin: 10px 0 20px 40px;  }

/* Opener */
#opener {  color: #fff;  margin:40px 0 60px;  font-weight:400; }
.opener_heading h1 { font-weight:bold;  line-height: 32px; margin:60px 0 0; font-size: 28px; text-align:center; }
#opener .btn { text-align: center; margin: 30px auto;}
#opener {-moz-column-count:2; -webkit-column-count:2; column-count:2;-moz-column-gap:30px; -webkit-column-gap:30px; column-gap:20px;}

.title { margin:0; padding-bottom: 0px; display: inline-block; font-size:28px; font-weight: bold; }
.subtitle:after { content: ""; bottom: 0; height: 3px; background: #eee; width: 70px; display: block; margin: 15px auto 0;}
.subtitle { font-size: 14px; margin: 5px 0 0;}

/* What we do */
#what_we_do {  text-align: center; margin: 20px 0 0; padding: 30px 0;  position: relative;}
#what_we_do h2.title { font-size: 28px; height: inherit;}
#what_we_do h3.subtitle { margin-bottom: 50px;}
#what_we_do .feat { margin-bottom: 80px; }
#what_we_do .feat p { min-height: 90px; }
#what_we_do .feat:after { content: ""; bottom: 0; height: 3px; background: #eee; width: 70px; display: block; margin: 15px auto 0; display: none; }
#what_we_do h2 { font-size: 18px; height: 40px; }
#what_we_do .icon { color: #2b3991; display: block; margin: 0 auto; font-size: 28px;}
#what_we_do p { max-width:230px; margin: 0 auto;}
#what_we_do img { max-width: 280px; height: 130px; margin:0 auto; display: block; position: relative;}
#what_we_do .btn {  margin-bottom: 50px;}


/* Homepage services */
.service-holder { margin-top: 40px;}
.service-holder > span {height: 1px; background: #eee; width: 100%; display: block; float: right; }
.service-holder:before { width: 1px; background: #eee; height: 100%; position: absolute; content: ""; left: 33.0%;}
.service-holder:after { width: 1px; background: #eee; height: 100%; position: absolute; content: ""; right:33.0%;}
.single-service { display: inline-block; width: 33.3%;  box-sizing: border-box; min-height: 250px; float: left; position: relative; padding: 15px; text-decoration: none!important; outline: none; }
.single-service h2 { font-size: 18px; margin: 0 0 10px;}
.single-service span { text-transform: uppercase; position: absolute; bottom: 25px; right:15px;}
.single-service.first span { right: 30px;}
.single-service span i { padding-left: 10px;}
.single-service:hover span { padding-right:5px; color: #385dbb ;}
.single-service.first { padding: 30px 30px 30px 0; }
.single-service.second { padding: 30px 15px;}
.single-service.third { padding: 30px 0 30px 30px; }
.single-service .icon { position: absolute; bottom: 30px; left:30px; font-size: 42px; color:#385dbb; text-align: left; }

/* Features */
.feature { width:100%; display:block; position: relative; padding:0px;box-sizing: border-box; text-align: center; margin-bottom: 20px; background: #000; }
.feature img { width: 100%; }
.feature h2 { margin: 0; color: #fff; font-size: 16px; font-weight: bold; position: absolute; bottom:0; left:0; right:0; padding: 30px 0 10px;
    background: -webkit-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
    background: -o-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
    background: -moz-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
    background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
}

/* Services */
.services { margin-top: 40px;}
.service { width:20%; display:inline-block; float: left; position: relative;box-sizing: border-box; text-align: center; background: #000; }
.service img { width: 100%; }
.service h2 { color: #fff; margin:0; font-size: 16px; font-weight: bold; position: absolute; bottom:0; left:0; right:0; padding: 30px 15px 10px;
    background: -webkit-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
    background: -o-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
    background: -moz-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
    background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
}

/* Hover effects */
.hover img {-webkit-transition:.3s; -moz-transition:.3s;  -o-transition:.3s;  transition:.3s;}
.blur,.hover.down img { /*filter:blur(1px); -webkit-filter:blur(1px);  -moz-filter:blur(1px); -o-filter:blur(1px); -ms-filter:blur(1px); filter: progid:DXImageTransform.Microsoft.Blur(PixelRadius='1'); */ opacity: .5; }
.hover.down img {}

/* Home news */
#home-news { background-size: cover; padding: 30px 0 40px; margin-top: 40px; position: relative; overflow: hidden; background: #000;}
#home-news .title { margin: 0 0 30px; color: #fff;}
#home-news a { background: #fff; display: block; position: relative; min-height: 330px; }
#home-news a div { max-width: 400px; height: 200px; overflow: hidden; position: relative; display: block; background-size: cover; background-position: center;}
#home-news a div img { max-width:100%;  }
#home-news a div h2 { position: absolute; bottom: 0; left:0; right:0; padding: 50px 0 10px; color: #fff; font-size: 18px; margin: 0 auto; text-align: center;
    background: -webkit-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,6));
    background: -o-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.6));
    background: -moz-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.6));
    background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.6));
}
#home-news a p { padding:15px 20px;}


.case-holder .single-case { box-sizing: border-box; text-decoration: none; min-height:360px; display: block;}
.case-holder .single-case div { max-width: 400px; height: 200px; overflow: hidden; position: relative; display:block; background-size: cover; background-position: center;}
.case-holder .single-case h2 { position: absolute; bottom: 0; left:0; right:0; padding: 50px 0 10px; color: #fff; font-size: 18px; margin: 0 auto; text-align: center;
    background: -webkit-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
    background: -o-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
    background: -moz-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
    background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));}
.case-holder .single-case p { padding: 15px 0; }

.case-headings { margin-bottom: 30px; border-bottom: solid 1px #eee; padding-bottom: 20px;}
.case-headings h2,.case-headings h3  { text-align: center;}

/* CTA section */
#cta { margin:0px 0 0; display: block; position: relative; text-align: center; font-size: 13px; position:relative; color:#111; font-size: 16px; padding: 100px 0 80px; background-color: #eee; }
#cta .bkg-image { position:absolute; top:0; bottom:0; left:0; right:0; opacity:.2;}
#cta .overlay { background: rgba(0,0,0,.2); position: absolute; top:0; bottom:0; left:0; right:0;}
#cta h2 { margin-bottom:30px; font-weight:bold; font-size:28px;}
#cta h3 { text-transform:none; margin:0px auto 20px; font-size:16px; color:#111; background:#f4ce00; padding:10px 20px; display:inline-block; max-width:750px; line-height:1.6em; font-weight:bold; border-radius:4px; }
#cta .subtitle { margin-bottom: 30px;}
#cta .subtitle:after { background: rgba(255,255,255,.3); }
#cta span  { display: block; margin: 0 auto 50px; line-height: 24px; }
#cta a { padding: 15px 40px;  letter-spacing:0.1em;  color: #111; display: inline-block; margin: 0 1.5% 0; position: relative; border: solid 3px #f4ce00; width: auto; font-size: 14px; border-radius:4px; }
#cta a:hover {    }
#cta .break { width:100%; display:block;}

#cta-single-holder #ContactForm input[type=text] { border:solid 1px rgba(255,255,255,.4);}
#cta-single-holder #ContactForm input[type=submit],#cta-single-holder #ContactForm button { background: #49ae47; color:#fff; border:solid 1px #49ae47 ;}

#cta .alert { padding: 20px; }
#cta .alert h3 {margin: 0 0 10px;}
#cta .alert { margin: 20px 0 ;}


#cta #ContactForm { padding: 0 40px; display: block; position: relative; z-index: 80;}
#cta #ContactForm h2 { text-align: center;}
#cta #ContactForm fieldset { margin-top:30px; display: block; text-align: center; }
#cta #ContactForm input[type=text],#cta #ContactForm button { box-sizing: border-box; border: solid 2px rgba(255,255,255,1); background:rgba(0,0,0,.2);  width:24%; padding: 15px 15px;  height:inherit; display: inline-block;  color: #fff; float: left; margin-right:10px; }
#cta #ContactForm input[type=submit],#cta #ContactForm button { border: solid 2px #f4ce00; padding: 15px 15px;  height: inherit; font-weight: normal; color:#fff; text-transform: uppercase; letter-spacing:.1em; margin: 0!important; }
#cta #ContactForm input[type=submit],#cta #ContactForm button { color: #000; font-weight: bold;}
#cta #ContactForm input[type=submit]:hover,#cta #ContactForm button:hover { }

.service-holder #cta { text-align: left; color: #333; background: #eee; margin: 0px 0 0 -7px; z-index: 50; display: inline-block; float: left; width: 66.6%; box-sizing: border-box; padding: 20px 30px;}
.service-holder #cta { font-size: 18px;}
.service-holder #cta span { margin: 0; line-height: 20px; font-size: 14px;}
.service-holder #cta a { text-decoration: none; text-align: center; margin: 0 20px 0 0}


.contactpage {  margin-top: 40px;}
.contactpage h2 { font-size: 18px; margin: 0;}
.contactpage a { text-decoration:none!important;}

.contact-page .col-sm-6 > span { display: block; margin-bottom: 10px;}
.contact-page .col-sm-6 > span a{ color:#000; text-decoration: none; }

.contact-page .form-control { padding: 5px; border:solid 1px #e4e4e4; border-radius:0; -webkit-border-radius:0;-moz-border-radius:0; box-shadow:none; margin-bottom: 15px; }

#ContactForm { text-align: left; margin-bottom:40px;}
#ContactForm .btn { float: left; margin-top: 15px;}
#ContactForm label {text-transform: uppercase; font-weight: normal; font-size: 12px; letter-spacing: .1em;}


.grecaptcha-badge { z-index: 100; background: #fff; }


    /* Partners page */
.partner { border: solid 5px #ddd; margin-bottom: 20px; padding: 20px 30px; min-height: 140px; box-sizing: border-box; position: relative; cursor: pointer; display: block; float: left;}
.partner .partner-header p { padding: 15px 0 0 280px;}
.partner .partner-header .hold {position: absolute; top: 20px; left: 20px; width: 240px; text-align: center;}
.partner .partner-header .hold img { margin: 0 auto;}
.partner .partner-header span { position:  absolute; bottom: 20px; right: 30px;}
.partner .partner-header span.off { display: none; }
.partner-body { visibility: collapse; opacity: 0; height: 0; margin-top: 60px; display: block; position: relative; float: left;}
.partner-body.on { visibility: visible; opacity: 1; height: auto;}



/* Quote section */
#quote { padding: 70px 0 20px; text-align: center; }
#quote p { font-size: 16px; padding: 0 60px; box-sizing: border-box;}
#quote h2 { text-transform: none; color: #1a69b3; margin: 25px 0 0;}
#quote .col-xs-12 {position: relative;}
#quote .col-xs-12:before { content: '"'; position: absolute; top:-70px; left:0; font-size: 16em; color: #aaa;}
#quote .col-xs-12:after { content: '"'; position: absolute; top:-70px; right:0; font-size: 16em; color: #aaa;}

/* Body quotes */
.quote { background: #eee; padding: 20px 80px; border-left: solid 3px #ddd; position: relative; margin:15px 0 30px;}
.quote span {display: block; text-align: right;}
.quote:before { content: '"'; position: absolute; top:90px; left:0; font-size: 16em; color: #aaa;}
.quote:after { content: '"'; position: absolute; top:90px; right:0; font-size: 16em; color: #aaa;}

/* Built with */
#built-with { margin: 50px 0 0;}
#built-with h2 { text-align: center; font-size: 18px; margin-bottom: 40px;}
#built-with .col-xs-12 { display:-ms-flexbox; display:-webkit-flex; display:flex; text-align: center; justify-content:space-between; flex-wrap: wrap; flex-direction: row; margin-bottom: 30px;}
#built-with .col-xs-12 > .tech  {text-align: center; color: #333; position: relative;  font-size: 16px;  box-sizing:border-box; max-width: 150px; }
#built-with .col-xs-12 > .tech img { max-width: 100%;}
#built-with .col-xs-12 > .tech:last-child { margin-top: -10px; border:none;}
#built-with .col-xs-12 > .tech.dell { max-width: 170px; margin-top: 10px;}

/* Process */
#process { margin: 50px 0 0; }
#process h2 { text-align: center; font-size: 18px;}
#process .col-xs-12,.proc-holder {  display: flex; }
.proc  {flex-grow:1; text-align: center; color: #333; position: relative; padding-bottom:6px; font-size: 16px; margin: 15px 0 20px; padding:0 15px;}
.proc .icon { width: 90px; height: 90px;  display: block; margin: 0 auto; font-size: 68px; color: #385dbb;}
#process .proc h2 { font-size: 16px; min-height: 50px; line-height: 22px; }
#process .proc p { font-size: 14px; }
#process .proc:after { position: absolute; top: 30px; right: -61px; content: ""; display: block; width: 123px; height: 12px; background: url('../images/dots.jpg'); }
#process .proc:last-child:after { display: none;}

.proc-holder .proc h2 { font-size: 16px;}
.proc-holder .proc p { font-size: 13px;}

/* Clients */
#clients { margin-bottom: 20px; display:-ms-flexbox; display:-webkit-flex; display:flex; text-align: center; justify-content:space-around; flex-wrap: wrap; flex-direction: row; background:#fff!important; color:#000!important; border-radius:4px;}
.clients_title { text-align: center; font-size: 18px; margin:50px 0 30px;}
#clients .hold { display: inline-block; margin: 15px;  padding:10px; position:relative; max-width:50%; }
#clients .hold > img { max-width: 210px; box-sizing: border-box;}
#clients .hold a span { color:#000; display:block; color:#777; margin-top:10px;}

/* Single page title */
.main h4.contact-heading { text-transform: uppercase; margin: 0 0 30px; font-size: 14px;}

.individual_social {float:right; color:#999; z-index:100; position:relative;}
.individual_social a { font-size:22px; margin-left:10px;}

/* People page */
#title { text-align: center; padding-bottom: 30px;}
#title h1 { margin: 0; font-size: 20px;}
#title h2 { font-size: 14px; color: #888; margin-top: 10px;}

.people { }
.people .person { color:#000; text-decoration:none; width: 100%; display: inline-block;  text-align: center; box-sizing: border-box; padding: 8px; }
.people .person .info {  display:flex; flex-direction:column; justify-content:space-between;}
.people .person img { width: 100%; border-radius:4px; }
.people .person h2 { font-weight:bold; margin:12px 0 0; height: 40px; display: block;}
.people .person h3 { display: none;}
.people i { font-style:normal; margin-bottom:10px; display:block;}
.people p { color:#000; background:#f4ce00; padding:10px 15px; border-radius:4px; font-weight:bold;}
.dark .people .person { color:#fff;}

.radio-label { min-height:230px;}

.person .info p { display:none;}

.single-person h2 { font-size: 18px;}
.single-person h3 { font-size: 14px; margin-top: 50px;}
.single-person ul { margin-bottom: 30px!important; display: block!important; position: relative; }
.single-person h5 { font-size: 14px; display: block; }


/* Sidebar */
#sidebar { border-right: solid 1px #eee; padding-left: 20px;}
#sidebar h3 { margin-top: 0;}
#sidebar .news-article { display: block; text-align: left; text-decoration: none; padding-bottom: 15px; border-bottom: solid 1px #eee; }
#sidebar .news-article h4 { text-align: left; font-size: 15px; line-height: 18px; margin: 20px 0 5px;}
#sidebar .news-article p { line-height: 16px;}
#sidebar li { margin-bottom:5px; padding-left: 10px; list-style: none; padding: 0; line-height: 16px; margin-bottom: 10px; position: relative; }
#sidebar li:before { position:absolute; left:-15px; top: 0; bottom: 0; -webkit-border-radius:0;-moz-border-radius:0; border-radius:0; display: block; content: ""; width: 3px; height:100%; background: #ddd; }

    /* Services*/
.service-ghosts { margin-top: 30px;}
.services { text-align: center; justify-content:center; display:flex; flex-wrap: wrap; flex-direction: row; }
.services .ghost-service { width: 20%; display: inline-block;  text-align: center; box-sizing: border-box; padding: 8px;  background: #000; }
.services .ghost-service > img { width: 100%; }
.services .ghost-service > div h2 { font-size: 14px; margin: 12px 0 0; height: 40px; display: block;}
.services .ghost-service > div h3 { display: none;}


/* Single Pages */
.service_image { max-width:50%; margin: 0 0 20px 20px; float:right; -webkit-border-radius:4px;-moz-border-radius:4px; border-radius:4px; overflow:hidden; width:100%; }
.service_image img { width:100%; height:auto!important;}

/* Single pages */
#banner { background-color: #212328; position:relative;  box-sizing:border-box;  text-align:center;  background-position:center; background-repeat:no-repeat; background-size:cover; margin: 0; padding: 0; overflow:hidden;  }
.banner-inner { position:relative;  display:flex; justify-content:space-between; align-items:center; max-width:1500px; padding:0 30px; margin:0 auto; box-sizing:border-box;}
#banner .overlay { z-index: 5; position: absolute; bottom: 0; left:0; right:0; height: 180px;
    background: -webkit-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.7));
    background: -o-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.7));
    background: -moz-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.7));
    background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.7));
}

#banner .bkg-image { position:absolute; top:0; bottom:0; left:0; right:0; opacity:0;}
#banner h1 { font-weight:bold; color: #111; font-size:42px; display:block; margin:0 0 5px;  line-height:36px; position:relative; z-index: 10; }
#banner h2 { font-size: 20px; line-height:24px; color:#111; background:#f4ce00; border-radius:4px; padding:10px 20px; margin:20px 0 0; text-transform:none; }
#banner h3 { font-size: 16px; line-height: 24px; max-width: 700px; }

#banner .btn { text-transform:uppercase; border:solid 1px #fff; background: rgba(0,0,0,0.4); color:#fff;  padding:15px 25px; clear:none; font-size:16px; margin-top:15px; display:inline-block; font-weight:600;}
#banner .btn:hover { background:#000;}

#banner .case { position: absolute; top: 138px; z-index: 30; margin: 0 auto; left:0; right:0;}


#banner img { display:inline-block; height:400px; animation-delay: 1s; margin:0px 0 0px;}
#banner .info  {color: #fff; margin-right:40px;  display:inline-block; text-align:left; }

.dark #banner h1 { color:#fff;}



img.alignright { float:right; margin-left:15px; margin-bottom:15px;}
img.alignleft { float:left; margin-right:15px; margin-bottom:15px;}


/* News archive page */
#news { margin: 0; padding: 0;}

#news ul { list-style: none;}
.main .article { border-bottom: solid 1px #eee; padding: 15px 0; line-height: 20px; }
.main .article:before { display: none; }
.main .article span.date { color: #1a69b3; font-size: 14px;}
.main .article a { text-decoration: none;}
.main .article h3 { margin: 0 0 5px;}
.main .article img { float: right; margin-left: 15px;}


/* Banner Navigation controls */
#controls { position: relative; width:100%;  display: block; }
#controls a { padding:10px; color: #fff; font-size: 14px;}
#controls a span { font-size: 12px;}
#controls a div { color: #f4ce00; font-size: 13px;}
#controls #prev { float: left; text-align: left;}
#controls #next { float: right; text-align: right;}
#controls #prev span { padding-right: 10px;}
#controls #next span { padding-left: 10px;}

/* Controls */
#controls {  border-top: solid 1px #444;   border-bottom: solid 1px #444;  margin: 20px 0 -35px;  display:block; position:relative; overflow:hidden;}
#controls .wrap { max-width:1170px; margin:0 auto;}
#controls .control { float:left; width:33%; border-left: solid 1px #444;  min-height:110px; text-align:center; box-sizing: border-box; padding:20px 15px 10px; }
#controls .control:first-child { border:none;}
#controls .control > a { position: relative; overflow: hidden; padding: 0; color:#fff; text-decoration:none; text-transform: uppercase; font-weight: bold;}
#controls .control > a i { display: block; font-size:12px; font-style: normal; font-weight: normal; color:#f4ce00;}


#page-controls { position: relative; overflow: hidden; text-align: center; border-bottom: solid 1px #eee; margin-bottom: 20px; padding-bottom:20px;}
#page-controls h2 { font-size: 18px;}

#page-controls form > span { position: absolute; left:-50px;  display: inline-block; cursor: pointer;}
#page-controls form input[type=text] { border:none; width:50%; margin: 0 0 10px 30px;}
#page-controls form i { overflow: hidden; text-align: center; float: right; width:30px; position: relative; height: 30px; padding:7px;}
#page-controls form i input { line-height: 42px; display: block; text-indent: -9999px; position: absolute; top:0; left:0; right:0; bottom:0; border:none; background: none; padding:10px; }
#page-controls #tags,#page-controls #filter { position: absolute; bottom:10px; right:0; border:none;}

#newsfilters { float: left;}
#newsfilters select {padding: 5px;}
#news-search { float: right; display: inline-block; width: 200px; position: relative;}

/* Footer Section*/
#footer-wrapper { margin: 30px 0 0;  padding:50px 0 30px; font-size:13px;  text-align: center; position: relative; }
#footer-wrapper .middle:after { position: absolute; content: ""; width:1px; background: #444; margin: auto 0; height: 50%; top:0; bottom:0; right:0;}
#footer-wrapper .middle:before { position: absolute; content: ""; width:1px; background: #444; margin: auto 0; height: 50%; top:0; bottom:0; left:0;}
#footer-wrapper h2 { margin-top: 0; color: #111; font-size: 16px; font-weight: bold; }
#footer-wrapper ul { padding: 0; margin: 0;}
#footer-wrapper li { list-style: none; display: inline-block; margin: 0 10px 20px;}
#footer-wrapper a { color: #111;  letter-spacing: 0.1em; display: block; }
#footer-wrapper span { display: block; margin-bottom: 5px;}
#footer-wrapper a { color: #111; font-weight:bold;}

#footer-wrapper .address { display: inline-block;  padding: 0 20px; display: block; text-align: center; margin-top: 30px; color:#000;}
#footer-wrapper .address a { font-size: 14px; display: inline-block;}

#footer-wrapper hr { background: #333; border:none; height: 4px;}

#footer-wrapper .social-links { display:-ms-flexbox; display:-webkit-flex; display:flex; margin: 0 auto; text-align: center; align-items: center;  justify-content: center;}
#footer-wrapper .social-links a { font-weight:normal;  display: inline-block; width: 45px; margin: 15px 0px 0; height:50px;  position: relative; font-size: 28px;}

#copyright {  float: left;}
#copyright,#scorch  {  font-size:11px; color:#555;  position:relative; display: inline-block; margin: 10px 0; }
#scorch { color: #888;float: right;  }
#scorch a { color: #888!important; }

.disclaimer {position: relative;}
#disclaimer-menu { display:block; position: absolute; left:0; right: 0; margin: 0 auto; padding:12px 0; font-size: 13px; text-align: center;}
#disclaimer-menu ul { margin: 0; padding:0;}
#disclaimer-menu li { list-style: none; display: inline-block; }
#disclaimer-menu li a { list-style: none; display: inline-block; margin: 0 7px; color: #333; }

/* Social bar */
#social { background:#6b6b6b; color:#fff;}
#social h2 { text-transform:uppercase; letter-spacing:0.2em; text-align:center; font-weight:700; font-size:18px; margin:0; padding:5px 0;  }
#social span {  display:inline-block; vertical-align:top; padding:20px 0 0;}
#social #crestashareiconincontent { display:inline-block; position:relative; margin-left:20px;}

.search-result { color:#333; outline:none; margin:20px 0; padding:15px 0; border-bottom:solid 1px #eee; display:block; position: relative; overflow:hidden; }
.search-result h2 {}
.search-result .more { font-weight:bold;}
.search-result:hover { color:#333;}
.search-result:hover .more { color:#f4ce00;}

/* Contact Page */
.map { display:block; width:100%; height:240px; font-size:15px; margin-bottom: 15px; }
.contact { }
.contact h2 { text-align:center!important;}
.contact { display:block; text-align:center; margin-bottom:10px; color:#777;}
.contact a { font-weight:bold; color:#333!important; text-decoration:none!important; font-size:26px;}
.contact .btn { border:none; background:#f4ce00; text-decoration:none!important; color:#000; -webkit-border-radius:6px;-moz-border-radius:6px; padding:15px 20px; margin:20px 0; border-radius:6px; clear:both; display:block; float:left; }

.contactpage { text-align:center; margin-top: 40px;}
.contactpage h2 { font-size: 18px; margin: 0;}
.contactpage a { text-decoration:none!important;}
.contact-page { text-align: center;}
.contact-page .col-sm-6 > span { display: block; margin-bottom: 10px;}
.contact-page .col-sm-6 > span a{ color:#000; text-decoration: none; font-weight: bold; }


#ContactForm { text-align: left; }
#ContactForm .btn { float: left; margin-top: 15px; clear:both;}
#ContactForm label { font-weight: normal; text-transform: uppercase;}
#ContactForm input,#ContactForm textarea { border:solid 1px rgba(125,125,125,.25); margin-bottom:10px; border-radius:4px; background:none; color:#000;}
.dark #ContactForm input,.dark #ContactForm textarea { color:#fff;}
#ContactForm .btn { border:none; background:#f4ce00; text-decoration:none!important; color:#000; -webkit-border-radius:6px;-moz-border-radius:6px; padding:15px 20px; margin:20px 0; border-radius:6px; clear:both; display:block; float:left; }

/* Accordion*/
.acc { margin-bottom:10px; position: relative;}
.acc > h2 { display:block; background:#fff; border:solid 1px #e4e4e4; color:#333; padding:20px 20px; margin:0!important; font-size:16px; cursor:pointer;   }
.main .acc > h2:after { width: inherit; height:inherit; content: '\e259'; font-family: "Glyphicons Halflings"; background: none; position: absolute; text-align: right; right:20px; top:22px; font-size: 12px; }
.acc.active > h2,.acc > h2:hover  { background:#f4f4f4; }
.acc.active > h2:after  { content: "\e260"; }
.acc-body { padding:15px 0; display:none;}

/* Downloads */
.downloads .acc-body a { display: block; border-bottom: solid 1px #eee; padding:10px 15px 10px; }
.downloads .acc-body a span { float: right; }

/* General page */
.main { margin-top:30px; margin-bottom: 40px; line-height: 22px; display: block; position: relative; }
.main.medium { max-width: 900px;}
.main.slim { max-width: 650px;}
.main.single-person { max-width:800px;}
.main.single-person ul,.main .two_column ul { margin-left: 0;  transform: translateX(0);}
.main.single-service { }
.main h2 { margin-top: 0; clear:right;}
.main h2:after { margin: 0; width: 60px;}
.main h4 { text-transform: none; font-size: 16px; line-height: 26px; margin: 60px 0 20px; text-align: center;}
.main img { max-width:100%; height:auto; }
.main a { text-decoration:underline; }
.main a:hover { text-decoration:none; }
.page-section { width:100%; position: relative; padding:25px 0; background:#f4f4f4; border-bottom:solid 1px #ddd; border-top:solid 1px #ddd; }

.main ul { list-style: none; padding:0; margin:0 auto; display: inline-block; }
.main ul li { padding-left:15px; margin-bottom: 5px; opacity: 1; position: relative;}
.main ul li:before { content: "•"; color:#ccc; position: absolute; left:0; }
.main ul li.waypoint:before { opacity: 0; }

.main .aligncenter { text-align: center; margin: 0 auto; display: block; }

.main.single-person {}

.main .col-md-6 a.orange { margin-top: 30px;}

.summary .variations { margin-top: 20px;}
.summary .variations .label label{ color: #000!important; font-size: 13px; font-weight: bold; text-transform: uppercase; margin-right: 20px; padding-top: 10px;}
.summary .variations select { border: solid 1px #eee; padding: 10px 15px; margin-bottom: 15px; }
.summary .product_meta { display: none;}

.pricing-table .col { background: #1a69b3; color: #fff; padding: 14px; text-align: center; min-height: 400px; display: inline-block; float: left; width: 33.3%; padding: 30px 30px 15px; box-sizing: border-box; border: solid 10px #fff; position: relative; }

.pricing-table h2 { font-size: 14px; font-weight: bold; text-transform: none; margin: 0 0 12px; padding-bottom: 20px; border-bottom: solid 1px rgba(255,255,255,.3)}
.pricing-table ul { margin: 10px 0 20px;  padding: 0;}
.pricing-table ul li { text-transform: uppercase; padding: 8px; list-style: none; display: block; border-bottom: solid 1px #444; text-align: left;}
.pricing-table strong { color: inherit; text-transform: uppercase; }
.pricing-table .holder { background:#1a69b3; padding: 20px; display: block; width: 100%; position: relative;float: left; }
.pricing-table a {  text-transform: uppercase; color: #fff; padding: 15px 30px; display: block; position: relative; text-align: center; }
.pricing-table a:hover { border-color: #fff; color: #fff; }

.main .col-md-4 h3 { min-height: 40px; font-size: 16px;}
.single-service { }
.service-title { text-align: center; font-size: 18px; max-width: 900px; font-weight: bold; margin: 15px auto 30px; line-height: 26px; }
.service-opener { margin: 0 auto 40px; max-width: 900px; font-size: 16px; text-transform: uppercase;  text-align: center; line-height: 26px;}
.service-image { max-width: 50%; float:right; position:relative; margin:0 0 20px 20px; display:inline-block; border:solid 1px #444;}
.about-text {  text-align: right; position: relative; z-index: 5; padding: 20px 0 20px 500px; margin-bottom: 30px; }
.about-text p { position: relative; z-index: 5;}
.about-text:before { content: ""; position: absolute; top:0; bottom: 0; left:0; right:500px; display: block; background-size:100%; background-position: center}
.about-text:after { content: ""; position:absolute; top:0; bottom: 0; left:0; right:500px; display: block;
    background: -webkit-linear-gradient(left, rgba(255,255,255,0),rgba(255,255,255,1));
    background: -o-linear-gradient(left, rgba(255,255,255,0),rgba(255,255,255,1));
    background: -moz-linear-gradient(left, rgba(255,255,255,0),rgba(255,255,255,1));
    background: linear-gradient(left, rgba(255,255,255,0),rgba(255,255,255,1)); }

.main.two_column .col-xs-12, .col-xs-12 .two_column {-moz-column-count:2; -webkit-column-count:2; column-count:2;-moz-column-gap:30px; -webkit-column-gap:30px; column-gap:20px;}

/* Hide the icons maybe? */
#bar-menu a span { font-size:20px; font-weight:700; text-align:center; line-height:24px;  padding:0 20px; background:none!important;}

#registerform { width:100%; height:4300px;}

.modal-dialog {  height:auto; width:90vw; max-height:90vh; margin:4vh auto!important; box-sizing:border-box!important;}
.modal-body iframe { display:block; overflow:visible; width:100%; min-height:80vh; border:none;}

.modal-open {
    padding-right: 0 !important;
}

/* Events */

.event-page .col-xs-12 > h2 { font-weight: bold; text-align: center;}
.event { position:relative; border:solid 1px #eee; box-sizing:border-box; padding:15px; margin-bottom:30px; position: relative; overflow: hidden;}
.event-page .col-xs-12:first-child .event { background: #eee;}
.event img { float: right; margin: 10px 0 10px 20px;}
.event h2 { font-size: 18px; font-weight: bold; color: #2b3991;}
.event h3 { margin:10px 0; padding:0; text-transform: none; font-size: 14px; color: #555;}
.event span.link { position:absolute; bottom:15px; right:15px; color:#999;}
.event span.link a { color:#555;}
.event.next-event { border:solid 5px #ccb152;}

#page-controls { position: relative; overflow: hidden; text-align: center; border-bottom: solid 1px #ddd; margin-bottom: 20px; }
#page-controls h2 { font-size: 18px;}

#page-controls form > span { position: absolute; left:-50px;  display: inline-block; cursor: pointer;}
#page-controls form > div { text-align: left; visibility: hidden; opacity: 0;  background:#fff; display: block; position: absolute; left:0; right:100%; bottom: 0;}
#page-controls form.on > div { visibility:visible; opacity: 1; }
#page-controls form > div input[type=text] { border:none; width:50%; margin: 0 0 10px 30px;}
#page-controls form > div i { line-height: 30px; overflow: hidden; text-align: center; float: right; width:30px; height: 30px; position: relative;}
#page-controls form > div i input { display: block; text-indent: -9999px; position: absolute; top:0; left:0; right:0; bottom:0; border:none; background: none; padding: 15px;}
#page-controls form > .search-on { left:0; }
#page-controls form.on > .search-off { left:0; }
#page-controls form.on > .search-on { left:-50px;}
#page-controls form > div {right:0;}


/* Pagination links */
.pagination {display: block; width: 100%; margin-top: 30px;}
.nav-links { border-bottom: solid 1px #ddd; text-align:center; padding:0; border-top:solid 1px #ddd;}
.nav-links a,.nav-links span { padding: 10px; display: inline-block; text-decoration: none;}
.nav-links a:hover { background: #f8f8f8;}
.nav-links span { background: #000; color: #fff;}


/* Share */
#share { text-align: center; position: relative; display: block;}
#share h2 { display: block; color: #bbb; font-size: 16px;}
#share #crestashareiconincontent .sbutton { display: inline-block; float: none;}

.woocommerce-thankyou-order-received { font-size: 14px; font-weight: bold; text-align: center; margin-bottom: 35px;}

/* Tick lists */
ul.tick { margin-left: 30px; list-style: none;}
ul.tick li { padding-left: 35px;}
ul.tick li:before { content: "\e013"; font-family: 'Glyphicons Halflings'; color: #1a69b3; }


/* Woocommerce product page */
.woocommerce-product-gallery { width: 40%; display: inline-block; box-sizing: border-box; float:left; }
.product .summary { width: 60%; display: inline-block; box-sizing: border-box; float: left; }
.product .summary .addon-name { text-transform: inherit!important; font-weight: bold; font-size: 14px; margin: 30px 0;}
.product .summary .price .woocommerce-Price-amount { font-weight: bold; font-size: 26px; color: #29b733;}
.product .summary .product-addon label { font-weight: normal;}
.product .summary .product-addon .woocommerce-Price-amount  { color: #29b733;}
.product .summary .single_add_to_cart_button { text-transform: uppercase; font-weight: bold; border: none; background: #faa42b; -webkit-border-radius:30px;-moz-border-radius:30px; border-radius:30px; padding: 15px 30px; margin-top: 25px; }
.product-addon-totals {}
.product-addon-totals dt,.product-addon-totals dd { font-weight: normal; margin-bottom: 5px; font-weight: bold;}
.product-addon-totals dd span { color: #000;}


.woocommerce-billing-fields input[type=text],.woocommerce-billing-fields input[type=tel],.woocommerce-billing-fields input[type=email],.woocommerce-billing-fields select { padding: 10px; border: solid 1px #eee;}
.woocommerce-additional-fields__field-wrapper textarea {padding: 10px; border: solid 1px #eee; min-height: 300px;}
.woocommerce-billing-fields .select2-container--default .select2-selection { border: solid 1px #eee; padding: 10px; height: 48px;}
.woocommerce-billing-fields .select2-container--default .select2-selection--single .select2-selection__arrow { top: 10px; right:10px;}


.woocommerce .woocommerce-error { width:100%; right:0; padding: 10px 60px; box-sizing: border-box; }

.dcwss-content { text-align: center;}
.stream { padding: 0; margin: 0; list-style: none; }
.stream li { list-style: none; }

#sub-menu { background: #ddd;list-style: none; margin: 0; padding: 0; text-align: center; display:none;  position: relative; text-transform: uppercase; }
#sub-menu li { display: inline-block; float: none; }
#sub-menu li a { color: #777;  padding: 15px 30px; display: inline-block; }
#sub-menu li a.active,#sub-menu li a:hover { color: #000;  }

.news-items { padding-top:40px;}

/* Item */
.item { display: block; color: #fff; text-decoration: none!important; height: 165px; position: relative; overflow: hidden; margin-bottom: 15px; border-bottom: solid 1px #222; box-sizing: border-box; }
.item h2 { text-transform: uppercase; margin-bottom: 10px; font-size: 14px; font-weight:bold;}
.item h2:after { display: none;}
.item h3 { font-weight: normal; margin: 5px 0; font-size: 14px; margin-bottom: 10px; color: #aaa; text-transform: none; }
.item .image-wrap { position: relative; float:right; height: 100%; overflow: hidden; margin-bottom: 15px; margin-left: 50px;  }
.item .image-wrap img { position: relative; }
.item > b { position: absolute; left: 0; bottom: 15px; }

.item:hover > b { position: absolute; left: 15px; }
.item:hover { color:#fff; }
.item:hover h2 { color:#fff; }
.item:hover .strip { opacity: 1;}

.addon-checkbox {
    border: 1px solid #fff;
    background: transparent;
@include transition(0.5s, ease, all);
}

.addon-checkbox:checked {
    border: 1px solid #fff;
    background: #fff;
}


/* Team gallery */
.gallery { position: relative; overflow: hidden; margin-bottom: 30px; display: block;}
.gallery img { width: 100%;}
.gallery .overlay { position: absolute; top:10px; left:10px; right:10px; bottom:10px; background:rgba(0,0,0,.7); color: #fff; text-align: center; opacity: 0; padding-top: 35%; }
.gallery:hover .overlay { opacity: 1;}
.gallery h2 { font-size: 18px; margin: 10px 0 0;}
.gallery h3 { font-size: 14px; margin: 0;}
.featherlight-content { overflow: visible!important; min-width: 800px; max-width: 1000px;}
.featherlight-content div { font-size: 13px!important; line-height: 18px;}
.featherlight .featherlight-close-icon { position: fixed!important; top: 30px!important; right:30px!important; color: #fff!important; background: none!important; font-size: 22px;}
.featherlight-previous span,.featherlight-next span { display: block!important; font-size: 18px!important; }
.featherlight-previous { position: absolute!important; top:0; bottom:0;  left:-120px!important; right: 95%!important; background:none!important; }
.featherlight-next { position: absolute!important; top:0; bottom:0; right:-120px!important; left: 95%!important; background:none!important; }
.featherlight-content img { float: left; margin-right: 30px;}
.featherlight-content h2 { margin: 10px 0 20px;}
.featherlight-content h3 { margin: 0;  text-transform: none; color: #777;}
.featherlight-content > div span { display: inline-block; padding: 15px 0; margin: 0 auto; border-top:solid 1px #eee; }
.featherlight-content > div span > i { font-style: normal; min-width: 100px; display: inline-block;}
.featherlight-content > div span > a { min-width: 200px; display: inline-block;}
.featherlight-content span:before {}

/* Products Loop */
.enhanced-dd { margin-top:30px!important; list-style:none; display:flex!important;  justify-content: center!important; position:relative; }
.enhanced-dd li { display:inline-block; list-style:none; box-sizing:border-box; text-align:center; position:relative;  }
.enhanced-dd li:before { display:none;}
.enhanced-dd li div { text-decoration:none; display:block; position:relative;  border:solid 2px #f4ce00; padding:15px; border-radius:4px; }
.enhanced-dd h2 { font-weight:bold; font-size:18px; }
.enhanced-dd strong { }
.enhanced-dd span.pri { color:#00dd1c;}
.enhanced-dd div.btn { border-color:#fff!important; color:#fff!important; margin-top:15px;}

/* Single Product pages */
.woocommerce-product-gallery { display:none;}
.product .summary { text-align:center; float:none; margin:0 auto; display:block; width:inherit;}

.alg-product-input-fields-table { margin:0 auto;}
.alg-product-input-fields-table label { display:block; text-align:left; margin-right:15px;}
.yith_wapo_group_total,.alg-product-input-fields-table { width:100%; margin:30px auto 15px;}
.yith_wapo_group_total table td { width:50%!important; text-align:right!important;}
.yith_wapo_group_total table td:first-child {text-align:left!important;}
.summary input,.summary textarea { width:100%; display:block; background:#212328; border:solid 1px #444; padding:5px 15px; margin-bottom:5px;}

/* Checkout page */

.woocommerce-NoticeGroup,.woocommerce-message,.woocommerce-info,.create-account { display:none!important;}

.woocommerce-billing-fields input[type=text],.woocommerce-billing-fields input[type=tel],.woocommerce-billing-fields input[type=email],.woocommerce-additional-fields textarea,.woocommerce-billing-fields select {background:#212328; border:solid 1px #444; padding:15px 15px;}

.woocommerce-billing-fields .select2-container--default .select2-selection { border-color:#444;}
.select2-container--default .select2-selection--single { background-color:#212328!important; }
.select2-container--default .select2-selection--single .select2-selection__rendered { color:#fff!important;}
.select2-results__option,.select2-search__field { color:#000!important;}
.woocommerce-checkout-review-order-table .product-quantity { display:none;}

#add_payment_method #payment, .woocommerce-cart #payment, .woocommerce-checkout #payment { background:#212328!important; border:solid 1px #444!important;}
#add_payment_method #payment ul.payment_methods, .woocommerce-cart #payment ul.payment_methods, .woocommerce-checkout #payment ul.payment_methods { border:none!important;}
.woocommerce #respond input#submit.alt, .woocommerce a.button.alt, .woocommerce button.button.alt, .woocommerce input.button.alt { background-color:#f4ce00!important; color:#000!important; text-transform:uppercase;}

.ywapo_options_container label { display:inline-block; font-weight:normal;}
.ywapo_input_container { text-align:left;}
.ywapo_options_container input[type=checkbox] { display:inline-block; width:inherit; margin-right:15px;}
.ywapo_label_price { color:#00dd1c;}


/* Mailchimp signup form */
#chimp_form { background:#2d2f39; margin:40px 0 0; display:none;}
#mc_embed_signup { background:none!important; padding:40px 0; }
#mc_embed_signup form { padding:0!important; }
#mc_embed_signup h2 { font-weight:normal!important; text-align:center; font-size:24px!important; letter-spacing:0.15em!important;}

#mc_embed_signup input {  background:#212328!important; border:solid 1px #444!important; padding:10px 15px!important; height:inherit!important; max-height:inherit!important;}
#mc_embed_signup .datefield .monthfield input, #mc_embed_signup .datefield .dayfield input { width:50px!important;}
#mc_embed_signup  .mc-field-group { box-sizing:border-box; clear:inherit!important; margin:0!important; padding:0 20px!important; float:left!important; width:25%!important; display:inline-block!important; position:relative!important;}
#mc_embed_signup .asterisk { top:0!important; height:3px!important; width:3px; font-size:inherit!important; }
#mc_embed_signup .button { -webkit-border-radius:0!important; -moz-border-radius:0!important; border-radius:0!important; border:solid 2px #f4ce00!important; font-weight:bold!important; text-transform:uppercase!important; margin:0 auto!important; padding:15px 30px!important; float:none!important; display:block!important; letter-spacing:0.15em; background:none!important;}


/* Flash pop-up banner */
.modal { background:#2d2f39; padding:0px!important; border:solid 1px #f4ce00; color:#fff; max-width:650px; overflow:hidden; height:450px; max-height:inherit; margin:auto;}
.modal .close { cursor:pointer!important; text-shadow:none; color:#fff!important; opacity:1; margin:20px 20px 0 0; font-size:18px;}
.modal h2 { margin:0 0 15px;}
.modal img { float:right; max-width:50%; margin:0 0 15px 15px;}
.modal .btn { clear:both; display:block; width:50%; text-align:center; margin:0 auto;}


/* Account page */

#account-nav { display:block; list-style:none; margin-bottom:30px;}
#account-nav li { list-style:none; display:inline-block; padding:10px 20px;}
#account-nav li:before { display:none; }
#account-nav li a { text-decoration:none; text-transform:uppercase; color:#aaa;}
#account-nav li.active a,#account-nav li:hover a  { color:#fff;}

.alert-success h2 { font-size:16px;margin-bottom:0!important; }
.main.account-page { text-align:center; max-width:480px; }
.main.account-page h2 { text-align:center; margin:0 0 10px;}
.main.account-page h4 { margin:0 0 30px;}
.main.account-page label { display:block; text-transform:uppercase; font-weight:normal;}
.main.account-page .login-remember label{ font-size:11px; }
.main.account-page input[type=text],.main.account-page input[type=password] { padding:10px 20px; width:100%; display:block; background: #fff; border: solid 1px #eee; }
.main.account-page input[type=button],.main.account-page input[type=reset],.main.account-page input[type=submit] { background:none; color:#111; border:solid 2px #f4ce00!important; font-weight:bold!important; text-transform:uppercase!important; letter-spacing:0.15em; margin-top:20px;}


/* Accordion*/

.acc.knowledge > h2 { display:block; border-color:#444; background:#2d2f39; color:#fff; padding:15px 20px; margin:0!important; font-weight:300; font-size:16px; cursor:pointer; text-transform:none;  }
.acc.knowledge > h2 span { float:right; margin-right:30px;}
.acc.knowledge.active > h2,.acc.knowledge > h2:hover  { background:#fe9c0e; color:#000; }
.acc.knowledge .acc-body { display:none; padding:0;}
.acc.knowledge .acc-body a,.acc.knowledge .acc-body button { padding:10px 0 0 10px; border:none; display:block; border-bottom:solid 1px #222; display:block; background:none;   text-decoration:none; width:100%; text-align:left; color:#f4ce00;}
.acc.knowledge .acc-body a span,.acc.knowledge .acc-body button span { margin-right:10px; color:#ccc; display:inline-block; float:right; }
.acc.knowledge .acc-body a span.right,.acc.knowledge .acc-body button span.right { float:right; display:block;}

.download-modal .modal .modal-title { font-size:22px; margin:10px 0 20px 15px; text-transform:none;}
.download-modal .modal h4 { margin:0 15px 20px; font-size:14px; text-align:left; line-height:20px;}
.download-modal .modal .close { position:absolute; top:0px; right:10px; z-index:500; border:none; }
.download-modal .modal .close span { display:block; font-size:20px; border:none; padding:0; margin:0; color:#f4ce00;}

.download-modal .modal { padding:20px!important;}
.download-modal input[type=text],.download-modal input[type=email] { margin-bottom:15px; background: #212328; border: solid 1px #444;  }
.download-modal .google { margin-top:10px;}

#intro { display:block; float:left; font-size:18px; background:#f4ce00; color:#000; width:100%; margin-bottom:40px; padding:40px 0;}
#intro ul { margin:20px;}

#home-feature {  display:block; float:left; clear:both; width:100%; margin: 0 auto 20px; z-index:1000;}
#home-feature img { float:right; margin: 0 0 30px 50px; border-radius:4px; max-width:50%;}
#home-feature h4 { color:#777; font-weight:bold;}
#home-feature h2 { display:inline-block; background:#f4ce00; padding:10px 20px; font-weight:bold; border-radius:4px; margin-top:10px;}
#home-feature .container { max-width:1130px;}
#home-feature .container a {  text-transform:uppercase; border-radius:4px;  z-index:1; margin-top:10px; font-weight:bold; display:block; border:solid 3px #f4ce00; color:#000; padding:15px 30px; display:inline-block;}

#home-feature .col-xs-12 { display:flex; align-items:center; justify-content:center;}

/* Mod Overlay Spinner */
.mod-overlay { opacity:0; visibility:hidden; position:absolute; top:0; bottom:0; left:0; right:0; background:rgba(0,0,0,.75); z-index:10;}
.mod-overlay.on { opacity:1; visibility:visible; text-align:center; padding-top:30%;}
.lds-roller { display: inline-block; position: relative; width: 64px; height: 64px; }  .lds-roller div { animation: lds-roller 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite; transform-origin: 32px 32px; }  .lds-roller div:after { content: " "; display: block; position: absolute; width: 6px; height: 6px; border-radius: 50%; background: #fff; margin: -3px 0 0 -3px; }  .lds-roller div:nth-child(1) { animation-delay: -0.036s; }  .lds-roller div:nth-child(1):after { top: 50px; left: 50px; }  .lds-roller div:nth-child(2) { animation-delay: -0.072s; }  .lds-roller div:nth-child(2):after { top: 54px; left: 45px; }  .lds-roller div:nth-child(3) { animation-delay: -0.108s; }  .lds-roller div:nth-child(3):after { top: 57px; left: 39px; }  .lds-roller div:nth-child(4) { animation-delay: -0.144s; }  .lds-roller div:nth-child(4):after { top: 58px; left: 32px; }  .lds-roller div:nth-child(5) { animation-delay: -0.18s; }  .lds-roller div:nth-child(5):after { top: 57px; left: 25px; }  .lds-roller div:nth-child(6) { animation-delay: -0.216s; }  .lds-roller div:nth-child(6):after { top: 54px; left: 19px; }  .lds-roller div:nth-child(7) { animation-delay: -0.252s; }  .lds-roller div:nth-child(7):after { top: 50px; left: 14px; }  .lds-roller div:nth-child(8) { animation-delay: -0.288s; }  .lds-roller div:nth-child(8):after { top: 45px; left: 10px; }
@keyframes lds-roller {0% { transform: rotate(0deg);}100% {transform: rotate(360deg);} }

/* Dark theme changes */
.dark { background:#111; color:#fff;}
.dark .grey_grad {
    box-shadow:0 0 4px 0 rgba(0,0,0,.1);
    background: -webkit-linear-gradient(top,#111,#222);
    background: -o-linear-gradient(top,#111,#222);
    background: -moz-linear-gradient(top,#111,#222);
    background: linear-gradient(top,#111,#222);
    }
.dark .info { color:#fff;}
.dark .info a { color:#fff;}
.dark #slider .rslides_nav { color:#fff; background:rgba(0,0,0,0.5);}
.dark #home-feature h2 { color:#000;}
.dark #home-feature .container a { color:#fff;}
.dark #cta { background-color:#222; color:#fff;}
.dark #cta a { color:#fff;}


@media (max-width: 1380px) {
    .logo { width: 200px; }

}

@media (max-width: 1199px) {
    .logo { width: 170px; margin-top: 20px;}
    .menu-navigation-container > ul > li { margin-left:10px; font-size: 13px;}

    #home-news { background: #222;}
    #home-news .bkg-image { display: none; }
    #home-news a { margin: 0 0 30px 0; min-height: inherit;}
    #home-news a div { max-width: 100%; min-height: inherit; height: 140px; min-height: inherit!important; position: relative;}
    #home-news a div img { min-width: 100%; width: auto; height: auto;  position: absolute; top:0; left:0; right:0; }

    #header.fix .logo { width: 140px; margin-top: 10px;}
    #footer-wrapper li { margin: 0 0 15px; font-size: 11px;}
    #what_we_do h2.middle::before { top: -16px;}
    #what_we_do h2 { font-size: 16px;}
}

@media (max-width: 991px) {
    .logo { width: 170px; margin-top: 20px;}
    #header.fix .logo { width: 140px; margin-top: 10px;}
    .menu-navigation-container > ul > li { margin-left:5px;}
    .menu-navigation-container > ul > li a { letter-spacing: 0;  font-size: 13px;}

    #home-news a div {height: 110px; }

    #process .proc .icon { width: 50px; height: 30px; font-size:36px; text-align: center;}
    #process .proc::after { display: none;}
    #what_we_do h2 { font-size: 14px;}
    #what_we_do .feat p { min-height: 90px; }
}


@media (max-width: 900px) {


}


@media (max-width: 767px) {

    #home-feature img { max-width:100%; margin: 10px 0 0;}

    #cta { padding:40px 0;}

    #intro { font-size:14px;}

    #banner h1 { font-size:18px;}

    .rslides_tabs li{ margin-top:20px;}
    #home-feature .col-xs-12 { display:block;}

    #mc_embed_signup  .mc-field-group { width:100%!important; margin-bottom:15px!important;}

    .enhanced-dd { display:block!important;}
    .enhanced-dd li { margin-bottom:20px!important;}

    .enhanced-dd li { width:100%!important;}

    #header { display:none!important;}

    .logo { margin:15px 0 15px 15px;}


    #home-products img { max-width:50%; display:block; margin:0 auto 15px; float:none; text-align:center;}

    #opener { -moz-column-count: 1; -webkit-column-count: 1; column-count: 1;}

    .gallery .overlay { opacity: 1; top: inherit; padding: 15px 0;}
    .featherlight {overflow-y: scroll;}
    .featherlight-content { box-sizing: border-box; max-width: 97%; min-width: inherit; margin: 5px auto; min-height: 100%; max-height: inherit!important; }
    .featherlight-content img { float: none; max-width: 100%; padding: 0 15px; box-sizing: border-box; margin: 40px 0 10px;}
    .featherlight .featherlight-close-icon { color: #000!important; z-index: 500; top: 20px!important;  right: 20px!important;}
    .featherlight-previous { left: 0!important; right: 90%!important; bottom: inherit!important; height: 300px!important;}
    .featherlight-next { right: 0!important; left: 90%!important; bottom: inherit!important; height: 300px!important;}
    .featherlight-previous span i,.featherlight-next span i { color: #000;}

    #sub-menu { display: none; float: left; width: 100%; margin: -30px 0 20px;}
    #sub-menu li { display: block;}

    .item { height: inherit;}
    .item .image-wrap {display: block; width: 100%; float: none; margin: 0 0 20px;}
    .item img { }
    .item > b { display: none;}


    #ContactForm { padding: 0;}
    #ContactForm fieldset { display: block;}
    #ContactForm input[type="text"], #ContactForm button { display: block; width: 100%; margin-bottom: 10px;}
    #cta a { display: block; width: 100%;}

    #home-news a div {height: 130px; }

    .main .article img { display: none;}

    #banner { padding: 80px 0 5px!important;}
    #banner .case { max-width: 100%; height: 200px; top:75px; max-height: 200px; overflow: hidden;}
    #banner .case > img { width: 100%; height: auto; }

    #built-with { display: block; }
    #built-with .col-xs-12 > .tech {max-width: 50%; padding: 15px; box-sizing: border-box;}

    .partner { min-height: inherit;}
    .partner .partner-header .hold { position: relative; display: block; width: auto; margin: 0; padding: 0; top: 0; left:0;}
    .partner .partner-header p { padding: 15px 0 ;}
    .partner .partner-body { margin: 0;}

    .proc-holder { display: block;}
    .proc-holder .proc { width: 100%!important;}

    .iconbox { width: 100%; float: none;}


    #slider #cats { bottom: 0;}
    #slider #cats a { border: none!important; display: block; padding: 5px!important; font-size: 16px!important;  float: none; text-align: center; width: 100%;}

    .menu-navigation-container { float: none; margin: 0!important;}

    #contact-details { display:none;}

    #opener { margin: 10px 0;}
    #opener h1 { font-size: 14px; line-height: 22px;}

    .about-text { padding: 0; text-align: left;}
    .about-text:before,.about-text:after { display: none; }

    #menu-wrapper { display: none;}

    #slider { padding-top:20px;}

    .rslides .info { top:25vh; }
    .rslides li { display:block; min-height:350px; height:inherit;}
    .rslides li img { display:block; max-width:70%; margin:0 auto; height:inherit;}
    .rslides li h1 { font-size: 16px;  margin: 0px 0 20px; line-height: 16px; }
    .rslides li h2 { font-size: 16px;  margin: 10px 0 10px; line-height: 20px; text-transform:none; }
    .rslides li h3 {  font-size: 13px; line-height: 14px; max-width:95%; margin: 0 auto; display:none; }
    .rslides .info { top: 15px; margin:15px 0 0!important; text-align:center;}
    .rslides .info a {  margin: 25px 0 0; font-size: 13px;}
    .rslides a.linkto { display: inline-block; margin: 0 auto;}

    .rslides_tabs { display:block;}
    .rslides_tabs li { text-align:center; display:block;}

    #what_we_do h2 { margin-bottom: 0px!important; font-size: 14px!important; line-height: 18px;}
    #what_we_do h2.title { font-size: 18px!important;}
    #what_we_do img { margin-bottom: 00px;}

    #cta .title { font-size: 18px;}

    #home-products { text-align: center;}
    #home-products .image-wrap { display: block; margin: 0 auto; text-align: center; float: none!important;}

    #clients .hold { max-width: 90%; position: relative; }
    #clients .hold img { width: 100%;}

    #what_we_do .feat p { min-height:inherit;}
    #what_we_do .feat span { margin-top: 15px;}

    #home-news { background: #222;}
    #home-news .bkg-image { display: none; }
    #home-news a { margin: 0 0 30px 0;}
    #home-news a div { max-width: 100%; min-height: inherit; height: 100px; min-height: inherit;}
    #home-news a div img { min-width: 100%; width: auto; height: auto;  position: absolute; top:0; left:0; right:0; }

    #cta #ContactForm { padding: 0;}
    #cta #ContactForm input[type="text"], #cta #ContactForm button { width: 100%; display: block; float: none;}

    .pricing-table .col { width: 100%; display: block;}


    .article h3 { font-size: 16px;}

    #controls .control .arr { top: 200px;}

    #process .col-xs-12 { display: block;}
    #process .container .row .col-xs-12 .proc { display: block; width: 100%!important; float: none; flex-grow:0;}

    .service-holder {}

    .service-holder::before,.service-holder::after { display: none;}
    .service-holder .single-service { width: 100%; display: block; border-bottom: solid 1px #eee;}

    #clients .hold > img { max-width: 150px; vertical-align: middle;}

    #footer-wrapper { padding: 20px 0;}
    #footer-wrapper .address { width: 100%; margin-bottom: 40px;}

    .scroll { display: none!important;}


    a.menu-logo,a.menu-tel,a.menu-email { display: none; }

   .logo { width: 180px!important;}
   #header { position: relative; min-height:80px; }
   #trigger-menu { top: 20px!important; position: absolute;}
   #header-faux { display: none!important;}

    .service-ghosts { margin-top: 20px;}
    .services .ghost-service{ width: 50%; }
    .services .ghost-service > div h2 { font-size: 13px;}

    #banner  .title { margin: 0;}

    #people { margin-top:-80px;}

    #footer-wrapper ul { display: none;}

    .people .person > div h2 { font-size: 13px;}
    #footer-wrapper { margin: 20px 0;}

    .single-person img { margin-bottom: 30px;}
    .single-person .btn { margin-bottom: 30px;}

    #banner.service-banner ul { display: none;}

    .services .service { width: 100%; margin-bottom: 30px; height: 130px; overflow: hidden;}

.g-recaptcha.google { max-width:80%; overflow: hidden;}
.form-control {  box-sizing: border-box;}

.main .service-image {height: 170px; overflow: hidden; width:auto; max-width: inherit; margin-left: -15px;}

#header { margin-bottom: 0;}
#header.constant::before { display: none;}
.main.two_column .col-xs-12 {-moz-column-count:1; -webkit-column-count:1; column-count:1; -moz-column-gap:0; -webkit-column-gap:0; column-gap:0;}

.main { margin-top: 0;}
.contact-page { margin-top: 0;}
#welcome,#banner { height: 300px;}

#head .logo {  float: none; margin:75px auto 5px; max-width:85%; display: block;}

#scroll-header,.service-dropdown,#header .menu-navigation-container { display: none;}
    
.main .two-column { -moz-column-count: 1; -webkit-column-count: 1; column-count: 1; -moz-column-gap: 0; -webkit-column-gap: 0; column-gap: 0; }

.modal-dialog {  height:auto; width:95vw; max-height:70vh; margin:1vh auto!important; box-sizing:border-box!important;}

.ghost { width:50%;}
.ghost div {}
.ghost div h2 { left:5px; bottom: 5px; font-size: 14px; text-align: left!important;}
.ghost.first h2 {  font-size: 14px; line-height: 18px;  }
    .ghost div { position:absolute; top:0; bottom:0; left:0; right:0; display:block; text-align:center; height:100%;
        background: -webkit-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
        background: -o-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
        background: -moz-linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
        background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,.5));
        }

#cta { margin: 0;}
#cta-box, #events { width:100%; border: none; margin:15px 0;}

#links { border: none; display: block; margin: 0;}
#links a {  display: block; border:none;}

body { font-size:13px;}

#head { display: block; position:relative;}

h2 { font-size:18px;}

.dropdown-menu,.caret { display:none!important;}

#banner { min-height:200px; padding: 20px 15px!important;}

#banner.buttoned .col-xs-12 { margin-top:40px;}

#banner .info { padding-top:0; padding-right:30%; box-sizing:border-box;}

#banner { height:inherit; margin:0; min-height: inherit;}
#banner .banner-inner { text-align:center;}
#banner .title { margin: 0; top: 73px; left:0; right:0; text-align: center; float: none; }
#banner .title h1 { margin: 0; font-size: 16px; display: block; float: none; display: none; }
#banner h2 { font-size:16px;}
#banner h3 { display: none;}
#banner .title span { margin: 0; font-size: 16px; display: none; }
#banner .info { padding:0; margin:0; text-align:center; width:100%;}
    #banner img {  position:absolute; height:inherit; top:25px; right:-10%; float:right; display:none; margin:0 auto!important; max-width:40%;}


.iconbox.small { width: 100%;}
.iconbox.small h3 { font-size: 14px;}

    #cta a { margin-bottom: 20px;}

#people #banner { display:none; }
#people .ms-staff-carousel { margin-top:0!important;}

.ms-staff-carousel .ms-staff-info h3, .ms-staff-carousel .ms-staff-info h4 { color:#333!important;}
.ms-staff-carousel .ms-staff-info h3 { font-size:18px!important;}
.ms-staff-carousel .ms-staff-info h4 { font-size:16px!important;}


#filters { margin-bottom:15px;}
#filters button { font-size:14px; padding:10px ;}
.news-archive .news h3 { font-size:16px;}

.main { padding-bottom:20px; padding-top:20px;}

#feature { padding:20px 0;}


.acc > h2 { font-size:16px;}

#feature iframe,#my-video  { max-width:100%; display:block; float:none; margin:0; height:150px; margin-bottom:20px;}

.vjs-big-play-button { position:absolute; top:40%!important; left:40%!important; right:0!important;}

.latest-news h2 { font-size:18px;}

.latest-news .news h3 { font-size:14px;}

.contactpage { text-align:center; margin-bottom:20px;}

#menu { display:none;}

.scorch { opacity:1!important;}

.overlay-hugeinc ul { height:75vh;}
.overlay-hugeinc ul li a { font-size:16px; }

#footer { margin:10px 0 0 0;}
#copyright,#scorch  { font-size:11px; text-align:center;  padding:10px 0 0; display:block;  float:none; }


#call-to-action h2 { font-size:18px;}
#call-to-action .btn { padding:15px 20px;}

.contact a { font-size:18px;}

#footer { text-align:center;}
#footer .col-xs-12 { margin-top: 15px; margin-bottom: 15px;}
#footer #address { margin-top:10px;}
#footer li a { padding:0!important;}
#footer span.glyphicon { display:none;}
}

/* Old browser nonsence for the rubbish */
.oldbrowser {}

.oldbrowser #bar-menu .menu { text-align:justify; clear:both; display:block; margin:0; padding:0; height:45px;}
.oldbrowser #bar-menu .menu:after {content: ''; display: inline-block;width: 100%;}
.oldbrowser #bar-menu .menu li { display: inline-block; padding-top:2px;  text-align:center; color:#fff; background-position:top left!important; background-size:100% 100%!important; }
.oldbrowser #bar-menu .menu li .dropdown-menu { display:none;}
.oldbrowser .info h2 { font-weight:600!important;}
