/* SITEWIDE ELEMENTS */

html,
body {
  height: 100%;
}

body {
  position: relative;
  font-family: "Lato", "Helvetica", "Arial", sans-serif;
  color: #000;
  font-weight: 400;
  font-size: 1.5em;
  background-color: #444;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  padding-top: 0;
  margin-top: 0;
}

a {
  color: #208cc3;
}

/* SITEWIDE ELEMENT STYLES */

/* BOOTSTRAP MODIFICATIONS */

.panel.panel-danger {
  background-color: #ffcccc;
}

.panel.panel-success {
  background-color: #ccffcc;
}

ol.breadcrumb {
  background-color: #eee;
  padding: 0;
  margin: 0.5em 0;
}

ol.breadcrumb li {
  float: none;
  display: inline;
}

/* SITEWIDE PAGE STYLES */

.page-wrapper {
  position: relative;
  background-color: #fff;
  padding-bottom: 3em;
}

.page {
  position: relative;
  padding-bottom: 2em;
  min-height: 750px;
  background-color: #fff;
}

h2.page-heading {
  font-size: 1.8em;
  margin: 1em 0 2em 0;
  color: #e25600;
  text-transform: uppercase;
}

/* SITEWIDE ARTICLE STYLES */

h3.article-title {
  font-size: 1.3em;
  margin: 1em 0;
  color: #e25600;
  font-weight: bold;
}

h3.article-subtitle {
  font-weight: bold;
  font-size: 1.1em;
  margin: 1em 0;
}

article div.article-header {
  margin-bottom: 2.5em;
}

article div.article-header h3.article-title {
  font-size: 2em;
  margin-bottom: 0.5em;
}

article div.article-header div.subtitle {
  font-weight: bold;
  font-size: 1.1em;
}

article div.article-image {
  text-align: center;
}

article div.article-image img {
  max-width: 100%;
}

article h4 {
  font-size: 1.5em;
  font-weight: bold;
  margin: 1.5em 0 0.5em 0;
  color: #e25600;
}

article h5 {
  font-size: 1.2em;
  font-weight: bold;
  margin-top: 1em;
  margin-bottom: 0em;
  padding-bottom: 0;
}

li.post {
  margin-bottom: 3em;
}

li.post h3 {
  margin-bottom: 0.5em;
}

/* SITEWIDE STYLES */

.intro {
  margin-bottom: 2em;
}

.what-is-this {
  font-size: 0.7em;
}

.dn {
  display: none;
}

/* HEADER - MAIN */

/* header#site-header { background-color:#208cc3; height:90px; } */

/* #f77a00 */

/* TOP BAR */

#top-bar {
  position: relative;
  padding: 0;
  background-color: #000;
  color: #fff;
  z-index: 12;
}

#top-bar a {
  color: #fff;
}

#top-bar #site-logo {
  position: absolute;
  padding: 0.2em 0 0 0;
  width: 252px;
  height: 55px;
  text-align: center;
  background-color: #fff;
  display: inline-block;
}

#top-bar #site-logo:after {
  border-top: 15px solid #fff;
  border-left: 126px solid transparent;
  border-right: 126px solid transparent;
  content: "";
  height: 0;
  left: 0;
  position: absolute;
  top: 55px;
  width: 0;
}

#top-bar #site-logo a {
  display: block;
}

#top-bar #site-logo a img {
  width: 215px;
}

#top-bar #site-logo a:focus {
  outline: 0;
}

#top-bar #top-bar-left {
  padding-left: 0;
}

#top-bar #top-bar-right {
  text-align: right;
  padding: 0.2em 0;
}

#top-bar #top-bar-right div {
  display: inline-block;
}

#top-bar #top-bar-right div.social-links {
  margin-left: 0.5em;
}

#top-bar #top-bar-right div.social-links a {
  margin-left: 0.2em;
}

#top-bar #top-bar-right div.social-links a:focus {
  outline: 0;
}

#top-bar #top-bar-right div.social-links a img {
  max-width: 17px;
  max-height: 17px;
}

/* MAIN NAVIGATION */

nav.navbar {
  min-height: auto;
  margin-bottom: 0;
  border-radius: 0;
  color: #fff;
  z-index: 10;
  background-color: #e25600;
}

nav.navbar #mainmenu ul {
  float: right;
}

#nav-main .nav > li {
  position: relative;
}

#nav-main .nav > li:hover,
#nav-main .nav > li.selected {
  background-color: #f77a00;
}

#nav-main .nav > li:hover a {
  text-decoration: none;
}

#mainmenu {
  margin-top: -10px;
}

#mainmenu .navbar-nav > li {
  text-align: right;
}

#mainmenu .navbar-nav > li a {
  text-transform: uppercase;
  color: #fff;
  font-size: 0.9em;
}

#mainmenu .navbar-nav > li a:hover {
  text-decoration: underline;
  background-color: transparent;
}

#mainmenu .navbar-nav > li .overlay-menu {
  position: absolute;
  display: none;
  background-color: #fff;
  top: 3.3em;
  left: -50%;
  right: -50%;
  width: 205px;
  text-align: left;
  box-shadow: 5px 5px 20px #777;
}

#mainmenu .navbar-nav > li .overlay-menu li {
  padding: 0.5em 1em;
}

#mainmenu .navbar-nav > li:hover .overlay-menu li:hover {
  background-color: #eee;
}

#mainmenu .navbar-nav > li:hover .overlay-menu li a {
  color: #208cc3;
  text-transform: none;
}

/* BREADCRUMBS BAR */

div.breadcrumbs {
  background-color: #eee;
  padding: 0;
}

/* FOOTER - MAIN */

.footer-wrapper {
  color: #fff;
  padding: 1em 0 5em 0;
  background-color: transparent;
}

.footer-wrapper a {
  color: #fff;
}

footer.main-footer .footer-left {
  text-align: left;
}

footer.main-footer .footer-right {
  text-align: right;
}

/* HOME */

#home.page {
  padding-top: 1em;
}

div.upper-background {
  position: relative;
  width: 100%;
}

/* #f77a00 */

div.upper-background {
  background-color: #fff;
}

div.upper-background video {
  position: absolute;
  width: 100%;
}

div.upper-background .upper-background-overlay {
  position: absolute;
  width: 100%;
  height: 100%;
  color: #fff;
  z-index: 5;
  background-color: #000;
  opacity: 0.2;
}

div.upper-background .overlay-text {
  position: absolute;
  text-align: center;
  top: 12em;
  left: 0;
  width: 100%;
  font-size: 2.8em;
  font-weight: bold;
  color: #fff;
  z-index: 6;
  text-shadow: 2px 2px #000000;
}

#home #btn-get-started {
  margin: 1em 0 0 0;
  text-align: center;
}

#home #btn-get-started a.btn {
  font-size: 1.4em;
  padding: 0.5em 1em;
}

#home #btn-get-started a.btn.round {
  border-radius: 12px;
  background-color: #f77a00;
  border: 0;
}

#home h3.home-section-title {
  text-align: center;
  font-variant: small-caps;
  background-color: #eee;
  padding: 0.2em 0;
  margin-bottom: 1em;
}

#home h3.home-section-title:after {
  display: inline-block;
  position: relative;
  top: -0.6em;
  padding: 0 1em;
  background: #fff;
  color: #000;
  font-size: 1.1em;
  padding-bottom: 0;
  margin-bottom: 0;
}

#home .featured-services .post-image {
  position: relative;
  text-align: center;
}

#home .featured-services .post-image img {
  max-height: 150px;
}

#home .featured-posts {
  margin-top: 2em;
  padding-bottom: 2em;
}

#home .featured-posts div.post-listing {
  padding-bottom: 0.5em;
}

/* SAMPLES */

#samples li.post {
  position: relative;
  margin-bottom: 3em;
}

#samples li.post .post-image img {
  max-width: 100%;
  border: 1px solid #999;
  margin-bottom: 1em;
}

#samples li.post h3 {
  margin: 0 0 0.3em 0;
  padding: 0;
}

#samples li.post h4 {
  margin-bottom: 0.2em;
}

#samples .blurb {
  margin-top: 1.5em;
}

/* SERVICES */

#services .standard-rate {
  margin-bottom: 3em;
}

#services .standard-rate span {
  font-size: 1.6em;
  font-weight: bold;
}

#services li.post {
  position: relative;
  margin-bottom: 3em;
}

#services li.post .post-image img {
  max-width: 100%;
  border: 1px solid #999;
  margin-bottom: 1em;
}

#services li.post h3 {
  margin: 0 0 0.3em 0;
  padding: 0;
}

#services li.post h4 {
  margin-bottom: 1.5em;
}

/* TEST-DRIVE */

#test-drive .text {
  float: left;
  width: 65%;
  margin-right: 5%;
}

#test-drive .button {
  float: right;
  width: 30%;
}

#test-drive section {
  margin-bottom: 3em;
}

/* RESPONSIVE MEDIA QUERIES */

@media screen and (min-width: 1600px) {
  div.upper-background {
    height: 900px;
    margin-top: -200px;
  }

  /* #f77a00 */

  div.upper-background-overlay {
    margin-top: 0;
  }
}

@media screen and (min-width: 1430px) and (max-width: 1599px) {
  div.upper-background {
    height: 800px;
    margin-top: -100px;
  }

  /* #f77a00 */

  div.upper-background .overlay-text {
    top: 9em;
  }
}

@media screen and (max-width: 1429px) {
  div.upper-background {
    height: 800px;
    margin-top: -100px;
  }

  /* #f77a00 */

  div.upper-background .overlay-text {
    top: 8em;
  }
}

@media screen and (min-width: 1250px) and (max-width: 1429px) {
  div.upper-background {
    height: 700px;
  }

  /* #f77a00 */

  div.upper-background .overlay-text {
    top: 9em;
    font-size: 2.4em;
  }
}

@media screen and (min-width: 1060px) and (max-width: 1249px) {
  div.upper-background {
    height: 590px;
  }

  /* #f77a00 */

  div.upper-background .overlay-text {
    top: 9em;
    font-size: 2.2em;
  }
}

@media screen and (min-width: 1025px) and (max-width: 1059px) {
  div.upper-background {
    height: 570px;
  }

  /* #f77a00 */

  div.upper-background .overlay-text {
    top: 9em;
    font-size: 2.1em;
  }
}

@media screen and (max-width: 1024px) {
  div.upper-background {
    background: #000 url("/img/header-background.jpg") center top no-repeat;
    background-size: cover;
    height: 500px;
  }

  div.upper-background video {
    display: none;
  }

  div.upper-background .overlay-text {
    top: 9em;
    font-size: 2em;
  }
}

@media screen and (max-width: 991px) {
  div.upper-background .upper-background-overlay {
    font-size: 1.6em;
  }

  #mainmenu .navbar-nav > li .overlay-menu {
    top: 3em;
  }

  #home .featured-services .post-image img {
    max-height: none;
    max-width: 100%;
  }

  .post-listing:not(:last-of-type) {
    margin-bottom: 3em;
  }
}

@media screen and (min-width: 768px) and (max-width: 1024px) {
  div.upper-background .overlay-text {
    top: 12em;
    font-size: 2.1em;
  }
}

@media screen and (min-width: 768px) and (max-width: 991px) {
  #top-bar {
    padding-bottom: 3em;
  }

  #mainmenu {
    font-size: 0.9em;
  }

  nav.navbar #mainmenu ul {
    float: none;
    text-align: center;
  }

  nav.navbar #mainmenu li {
    float: none;
    display: inline-block;
  }

  nav.navbar #mainmenu li a {
    padding-bottom: 0.5em;
  }
}

@media screen and (min-width: 768px) {
  .site-header h1 {
    text-align: left;
  }

  .social-links {
    text-align: right;
  }

  #mainmenu .navbar-nav > li:hover .overlay-menu {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  body {
    font-size: 1.6em;
    line-height: 1.7em;
  }

  #top-bar {
    text-align: center;
    background-color: #000;
  }

  #top-bar #top-bar-left {
    float: none;
    width: auto;
  }

  #top-bar #site-logo {
    position: relative;
    margin: 0 auto;
    margin-bottom: 0;
  }

  #top-bar #top-bar-right {
    float: none;
    margin-top: 1em;
    text-align: center;
    width: auto;
  }

  #top-bar #top-bar-right div {
    display: block;
    text-align: center;
  }

  #top-bar #top-bar-right div.social-links {
    margin: 0;
  }

  #top-bar #top-bar-right div.social-links a {
    margin: 0 0.3em;
  }

  header.main-header p.summary {
    line-height: 1.3em;
  }

  div.upper-background {
    height: 350px;
    background-color: #e25600;
  }

  div.upper-background .upper-background-overlay {
    font-size: 1.3em;
  }

  nav.navbar {
    color: #fff;
    background-color: #e25600;
  }

  .navbar-header {
    text-align: center;
  }

  .navbar-header button {
    float: none;
    margin: 0;
    padding: 0;
    font-size: 1.5em;
  }

  nav.navbar #mainmenu {
    margin: 0;
    padding: 0;
  }

  nav.navbar #mainmenu .row {
    padding: 0 auto;
  }

  nav.navbar #mainmenu ul {
    float: none;
    text-align: center;
    width: 100%;
    margin: 0;
    padding: 0;
  }

  nav.navbar #mainmenu ul li {
    margin: 0;
    padding: 0;
    text-align: center;
    width: 100%;
  }

  footer.main-footer .footer-left {
    text-align: center;
  }

  footer.main-footer .footer-right {
    text-align: center;
  }

  .site-header h1 {
    text-align: center;
  }

  .social-links {
    text-align: center;
  }
}

@media screen and (min-width: 460px) and (max-width: 767px) {
  div.upper-background .overlay-text {
    top: 12em;
    font-size: 1.5em;
  }
}

@media screen and (max-width: 459px) {
  div.upper-background {
    height: auto;
  }

  article {
    width: auto;
  }

  h3.article-title {
    font-size: 1.2em;
  }

  article div.article-header {
    font-size: 1em;
  }

  article h3.article-title {
    font-size: 1.4em;
  }

  article div.article-header div.subtitle {
    font-weight: bold;
    font-size: 1em;
  }

  li.post {
    margin-bottom: 3em;
  }

  header#site-header {
    height: auto;
  }

  div.upper-background {
    height: 280px;
  }

  #home #btn-get-started a.btn {
    font-size: 1em;
  }

  #home .featured-posts h3.article-title {
    margin-bottom: 0.1em;
  }

  #home .featured-posts div.post-listing {
    padding-bottom: 2em;
  }

  div.upper-background .overlay-text {
    top: 13em;
    font-size: 1.1em;
  }

  #test-drive .text {
    float: none;
    width: 100%;
    margin-right: 0;
  }

  #test-drive .button {
    float: none;
    width: 100%;
  }
}

