body {
  font-family: 'Montserrat', sans-serif;
  background: #151515;
  color: #fff; }

.valign-table {
  display: table;
  width: 100%;
  height: 100%; }

.valign-table-cell {
  display: table-cell;
  vertical-align: middle; }

.embed-responsive {
  position: relative;
  display: block;
  height: 0;
  padding: 0;
  overflow: hidden; }

.embed-responsive .embed-responsive-item,
.embed-responsive iframe,
.embed-responsive embed,
.embed-responsive object,
.embed-responsive video {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0; }

.embed-responsive-16by9 {
  padding-bottom: 56.25%;
  border: 1px solid #222; }

.container {
  width: 1170px;
  max-width: 100%; }

.section-content {
  margin-top: 120px;
  padding: 0 0 20px; }

a {
  transition: all 0.5s ease; }
  a:focus {
    text-decoration: none; }

/* Header
====================================================== */
.site-header {
  padding: 20px 0;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  background: #000;
  border-bottom: 1px solid #222;
  z-index: 9000; }
  .site-header a {
    color: #fff; }
  .site-header a:hover, .site-header a:focus {
    text-decoration: none; }

.no-touch .main-nav a:hover {
  opacity: 0.75; }

.top-img {
  width: 50px;
  display: inline-block; }
  .top-img img {
    width: 100%;
    height: auto;
    border-radius: 50%; }

.logo-wrap {
  float: left;
  transition: all 0.5s ease; }
  .logo-wrap .svg-wrap {
    width: 225px;
    display: inline-block; }
    .logo-wrap .svg-wrap img {
      width: 100%;
      height: auto; }

.main-nav {
  float: right; }
  .main-nav ul {
    margin: 20px 0 0 0;
    padding: 0; }
  .main-nav li {
    list-style: none;
    float: left;
    text-transform: uppercase;
    font-size: 1.2em;
    -webkit-transform: translate3d(0, 0, 0) !important; }
    .main-nav li a {
      padding: 10px 20px; }

@media all and (min-width: 768px) {
  .logo-wrap {
    margin-left: 5px; } }

@media all and (max-width: 767px) {
  .site-header {
    padding: 16px 0 0; }
  .logo-wrap {
    float: none;
    text-align: center;
    font-size: 2em; }
    .logo-wrap .svg-wrap {
      width: 140px; }
  .main-nav {
    text-align: center;
    float: none;
    clear: both; }
    .main-nav ul {
      margin: 0; }
    .main-nav li {
      float: none;
      display: inline-block;
      padding: 10px 0;
      font-size: 1em; } }

@media all and (max-width: 320px) {
  .main-nav ul {
    white-space: nowrap; }
  .main-nav li a {
    padding: 10px; } }

/* Admin Bar
====================================================== */
#wpadminbar {
  position: fixed !important; }

@media all and (min-width: 783px) {
  .admin-bar .site-header {
    top: 32px; } }

@media all and (max-width: 782px) {
  .admin-bar .site-header {
    top: 46px; } }

/* Video Sorter Link
====================================================== */
.cat-list {
  text-align: center;
  margin-bottom: 20px; }
  .cat-list li {
    font-size: 80%;
    list-style: none;
    text-transform: uppercase; }
    .cat-list li a {
      opacity: 0.6;
      color: #fff; }
    .cat-list li a:hover, .cat-list li a:focus {
      text-decoration: none; }
  .cat-list li.current-menu-item a {
    opacity: 1; }
  .cat-list ul {
    margin-left: 0;
    padding-left: 0; }

.no-touch .cat-list li a:hover {
  color: #fff;
  opacity: 1;
  text-decoration: none; }

.cat-page-wrap {
  padding-top: 20px;
  padding-bottom: 20px; }
  .cat-page-wrap .container {
    padding-top: 0; }
  .cat-page-wrap .mobile-cat-list-wrap {
    padding: 0 20px; }

.mobile-cat-list-wrap {
  text-align: center;
  display: none;
  margin-bottom: 20px; }
  .mobile-cat-list-wrap .cat-list {
    margin-top: 20px; }

.mobile-cat-list-btn {
  padding-top: 5px;
  padding-bottom: 5px;
  text-transform: uppercase;
  color: #fff;
  border: 1px solid #fff;
  background: none;
  font-size: 1em;
  border-radius: 0;
  opacity: 0.6; }
  .mobile-cat-list-btn:hover {
    cursor: pointer;
    border-color: #fff; }
  .mobile-cat-list-btn:focus {
    outline: 0;
    border-color: #fff; }
  .mobile-cat-list-btn .fa {
    transition: all 0.25s ease; }

.mobile-cat-list-btn-active .fa {
  transform: rotate(90deg); }

@media all and (min-width: 576px) {
  .cat-list {
    margin-top: -10px; }
    .cat-list li {
      display: inline-block;
      margin: 10px 3px; }
      .cat-list li a {
        border: 1px solid #fff;
        padding: 8px 15px; }
  .content-projects .cat-list {
    margin-top: 0; } }

@media all and (min-width: 481px) {
  .mobile-cat-list-wrap {
    padding-left: 3px;
    padding-right: 3px; } }

@media all and (max-width: 575px) {
  .cat-list-desktop {
    display: none; }
  .mobile-cat-list-wrap {
    display: block; }
  .mobile-cat-list-btn {
    width: 100%; }
  .cat-list li {
    font-size: 1.12em;
    margin: 5px; }
  .cat-list a {
    color: #fff !important; }
  .content-projects .cat-list-desktop {
    display: block; }
    .content-projects .cat-list-desktop li {
      margin-top: 15px;
      margin-bottom: 15px; }
  .content-projects .mobile-cat-list-btn {
    display: none; }
  .content-projects .mobile-calt-list-wrap {
    display: none; } }

/* Thumbnails
====================================================== */
.grid-outer {
  width: 50%;
  float: left;
  padding: 5px; }

.grid-inner {
  width: 100%;
  background: #000;
  overflow: hidden;
  height: 100%;
  padding: 56.25% 0 0 0;
  position: relative;
  display: block; }
  .grid-inner .grid-img {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    background-color: #f2f2f2; }
  .grid-inner .grid-hover-tint {
    transition: all 0.5s ease;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 100; }

.grid-label {
  margin: 0;
  -webkit-transform: translate3d(0, 0, 0);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 10px;
  color: #fff;
  font-size: 1.24em;
  line-height: 140%;
  background: -moz-linear-gradient(top, rgba(0, 0, 0, 0.8) 0%, transparent 50%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0.8) 0%, transparent 50%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8) 0%, transparent 50%);
  /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#a6000000', endColorstr='#00000000',GradientType=0 );
  /* IE6-9 */ }

.grid-excerpt {
  position: absolute;
  bottom: -2000px;
  padding: 0 10px 10px;
  -webkit-transform: translate3d(0, 0, 0);
  transition: 0.5s all ease; }
  .grid-excerpt p {
    color: #fff;
    display: inline; }

.no-touch .grid-inner:hover .grid-hover-tint {
  background: rgba(0, 0, 0, 0.5); }

.no-touch .grid-inner:hover .grid-excerpt {
  bottom: 0; }

@media all and (max-width: 767px) {
  .grid-label {
    font-size: 1em !important; }
  .grid-excerpt {
    display: none; } }

@media all and (max-width: 480px) {
  .grid-outer {
    width: 100%;
    padding: 5px 0; } }

/* Interior Pages
====================================================== */
.content p, .content ul, .content ol {
  font-size: 1.12em;
  margin: 20px 0;
  line-height: 160%; }

.content a {
  color: #4fc4f6; }

.content a:focus {
  text-decoration: none; }

.content hr {
  border-color: #222; }

.entry-title {
  margin: 20px 0;
  text-align: center; }

.video-title {
  margin-top: 10px; }

.video-outer {
  margin: 0 0 20px; }

.proj-cat-back {
  text-align: center;
  float: none;
  font-size: 1em;
  text-transform: uppercase;
  margin-bottom: 0; }
  .proj-cat-back a {
    color: #777; }
  .proj-cat-back a:hover, .proj-cat-back a:focus {
    text-decoration: none; }

.no-touch .proj-cat-back a:hover {
  color: #fff; }

.ajax-load-more-wrap.infinite button.alm-load-more-btn {
  background-image: url("../images/spinner.svg") !important; }

.alm-btn-wrap {
  padding: 0; }

@media all and (max-width: 767px) {
  .proj-cat-back {
    margin: 0 0 10px; }
  .section-content .entry-title {
    font-size: 2em;
    margin-top: 0 !important; }
  .section-content p, .section-content ul, .section-content ol {
    font-size: 1em; }
  .section-content h3 {
    font-size: 150%; } }

/* Gallery
====================================================== */
.section-gallery {
  padding: 0 0 40px; }

.content-about .col {
  padding: 0; }

.content-about .gallery-outer {
  margin-top: 24px; }

.content-about .rsDefaultInv {
  background: #000;
  border: 1px solid #222; }
  .content-about .rsDefaultInv .rsOverflow, .content-about .rsDefaultInv .rsSlide, .content-about .rsDefaultInv .rsVideoFrameHolder, .content-about .rsDefaultInv .rsThumbs {
    background: #000; }

@media all and (min-width: 768px) {
  .content-about .gallery-outer {
    padding-left: 20px; } }

/* Contact Page
====================================================== */
.container-contact {
  width: 620px; }
  .container-contact .phone-text {
    font-size: 1.2em;
    text-align: center; }
  .container-contact label {
    font-weight: 400; }
  .container-contact input, .container-contact textarea {
    border-radius: 0;
    -webkit-border-radius: 0;
    width: 1170px;
    max-width: 100%;
    color: #333 !important;
    -webkit-appearance: none; }
  .container-contact .wpcf7-response-output {
    margin: 20px 0 0;
    text-align: center; }
  .container-contact .ajax-loader {
    display: none !important; }
  .container-contact .wpcf7-submit {
    font-size: 1.12em;
    background: none;
    border: 1px solid #fff;
    color: #fff !important;
    transition: 0.5s all ease;
    -webkit-transform: translate3d(0, 0, 0);
    outline: none;
    padding-top: 10px;
    padding-bottom: 10px;
    text-transform: uppercase; }
    .container-contact .wpcf7-submit:hover {
      opacity: 1;
      background: #fff;
      color: #000 !important; }

/* Footer
====================================================== */
.site-footer {
  text-align: center;
  padding: 30px 0 60px;
  margin-top: 10px;
  border-top: 1px solid #222; }
  .site-footer p {
    font-size: 0.9em;
    color: #555; }

.top-return {
  opacity: 0;
  margin-top: 30px; }
  .top-return a {
    color: #555; }
    .top-return a:hover {
      text-decoration: none; }

.no-touch .top-return a:hover {
  color: #fff; }
