body {
  font-family: 'Open Sans', sans-serif;
  font-size: 16px;
  line-height: 1.5;
  position: relative;
}
a,
button,
input,
select,
textarea {
  text-decoration: none !important;
}
a,
button {
  transition: all ease-in-out 300ms;
}
a {
  color: #A28449;
}
a:hover {
  color: #7b633a;
}
blockquote p,
.display-1 p,
p.display-1 {
  font-family: 'Cormorant Infant', serif;
  font-size: 32px;
  color: #5a5858;
  line-height: 1.5;
}
blockquote p .quote-footer,
.display-1 p .quote-footer,
p.display-1 .quote-footer {
  text-align: right;
  display: block;
}
.skiplink {
  background: #333;
  display: block;
  border-bottom: 1px solid #efc56a;
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 5px;
  color: #efc56b;
  padding: 5px 30px;
}
.back-to-top {
  border-radius: 5px;
  text-align: center;
  background: #000;
  color: #fff;
  display: none;
  width: 40px;
  height: 40px;
  line-height: 40px;
  font-size: 12px;
  position: fixed;
  right: 20px;
  bottom: 20px;
  opacity: 0.4;
  transition: all 0.5s ease;
  cursor: pointer;
  z-index: 9999;
}
.back-to-top i {
  position: relative;
  top: 2px;
}
.back-to-top:hover {
  opacity: 1;
}
.hiding {
  opacity: 0;
}
.visible {
  opacity: 1;
}
#nav-icon4 {
  display: inline-block;
  vertical-align: middle;
  width: 35px;
  height: 24px;
  position: relative;
  margin: 0;
  transform: rotate(0deg);
  transition: 0.5s ease-in-out;
  cursor: pointer;
}
#nav-icon4 span {
  display: block;
  position: absolute;
  height: 4px;
  width: 100%;
  background: #757575;
  border-radius: 0px;
  opacity: 1;
  left: 0;
  transform: rotate(0deg);
  transition: 0.25s ease-in-out;
}
#nav-icon4 span:nth-child(1) {
  top: 0px;
  transform-origin: left center;
}
#nav-icon4 span:nth-child(2) {
  top: 10px;
  transform-origin: left center;
}
#nav-icon4 span:nth-child(3) {
  top: 20px;
  transform-origin: left center;
}
#nav-icon4.open span:nth-child(1) {
  transform: rotate(45deg);
  top: -3px;
  left: 8px;
}
#nav-icon4.open span:nth-child(2) {
  width: 0%;
  opacity: 0;
}
#nav-icon4.open span:nth-child(3) {
  transform: rotate(-45deg);
  top: 22px;
  left: 8px;
}
.nav-menu {
  position: fixed;
  top: 0;
  right: 0;
  z-index: -1;
  overflow: hidden;
  transition: all ease-in-out 300ms;
}
.nav-menu.open {
  z-index: 991;
}
.toggler {
  background: none;
  padding: 2px 10px;
  margin: 0;
  border: 0;
  position: absolute;
  top: 40px;
  right: 55px;
  z-index: 992;
  display: block;
}
.toggler.active-menu {
  position: fixed;
}
.toggler span {
  display: inline-block;
  margin-right: 5px;
  font-size: 24px;
  font-weight: 700;
  text-transform: uppercase;
  color: #757575;
  vertical-align: middle;
}
.toggler.active-menu span {
  color: #bb9d69;
}
.nav-menu .inner {
  max-width: 570px;
  width: 100vw;
  position: relative;
  z-index: 990;
  background: #fff;
  min-height: 100vh;
  transform: translateX(570px);
  transition: all ease-in-out 500ms;
}
.nav-menu.open .inner {
  transform: translateY(0);
}
.nav-menu ul {
  margin-bottom: 0;
  padding: 90px 15px 15px 90px;
  list-style: none;
}
.nav-menu ul li {
  display: block;
  margin-bottom: 20px;
}
.nav-menu ul li a {
  display: inline-block;
  color: #bb9d69 !important;
  font-size: 50px;
  text-transform: uppercase;
  font-family: 'Open Sans Condensed', sans-serif;
  font-weight: 300;
  line-height: 1;
}
.nav-menu ul li a:hover {
  color: #836e4a !important;
}
.nav-menu ul li.current a {
  color: #333 !important;
}
.section {
  position: relative;
  overflow: hidden;
  background-color: #f0f0f0;
}
.home-section {
  background-color: #333;
  padding-top: 120px;
  padding-bottom: 90px;
}
.image-frame,
.photo-border {
  max-width: 100%;
  width: 360px;
  border: 1px solid #b1876a;
  padding: 10px;
}
.image-frame.auto,
.photo-border.auto {
  width: 100%;
}
.image-frame.mobile-only {
  width: 100%;
  min-width: 100%;
}
.image-frame img,
.photo-border img {
  display: block;
  width: 100%;
  height: auto;
}
.home-section .image-frame {
  margin-bottom: 40px;
}
.highlight {
  color: #fff;
  padding-top: 35px;
  padding-bottom: 15px;
}
.highlight p {
  color: #fff;
}
.title-box .title-top {
  font-size: 16px;
  color: #fff;
  line-height: 1.12;
  margin-bottom: 40px;
  letter-spacing: 5px;
  text-transform: uppercase;
}
.passion-section.no-bg .title-top {
  color: #000;
}
.title-box .title-main {
  font-size: 68px;
  line-height: 1.12em;
  text-transform: uppercase;
  color: #B38114;
  font-family: 'Open Sans Condensed', sans-serif;
  font-weight: 300;
  padding-top: 20px;
  padding-bottom: 20px;
  margin-bottom: 40px;
  position: relative;
}
.title-box .title-main.dir-right:before {
  content: '';
  height: 1px;
  width: 2000rem;
  background-color: #B38114;
  position: absolute;
  top: 0;
  left: 0 !important;
  right: initial;
  z-index: 1;
}
.title-box .title-main.dir-right:after {
  content: '';
  height: 1px;
  width: 2000rem;
  background-color: #B38114;
  position: absolute;
  bottom: 0;
  left: 0 !important;
  right: initial;
  z-index: 1;
}
.hightlight p {
  padding: 0 24px 0 0;
}
.highlight .left-padding {
  padding-left: 24px;
}
.btn {
  font-family: 'Open Sans Condensed', sans-serif;
  font-weight: 700;
  text-transform: uppercase;
  padding: 10px 15px;
  border: 1px solid transparent;
  border-radius: 0;
  letter-spacing: 1px;
}
.btn-primary {
  color: #efc56b !important;
  border-color: #c3ac83 !important;
  background-color: #000 !important;
}
.btn-primary:hover {
  background-color: #efc56b !important;
  color: #524227 !important;
  border-color: #c3ac83 !important;
}
.btn-solid {
  background-color: #000 !important;
}
.quote-section-alternative {
  padding-top: 75px;
  padding-bottom: 25px;
}
.quote-section {
  padding-top: 100px;
  padding-bottom: 85px;
}
.quote-section h2 {
  margin-top: 0;
}
.quote-section a:not(.btn) {
  color: #7b633a;
  text-decoration: underline !important;
}
.quote-section a:not(.btn):hover {
  color: #bb9d69;
}
.content-section {
  padding-top: 75px;
  padding-bottom: 85px;
}
.content-section h2 {
  margin-top: 0;
}
.floating-bg {
  position: relative;
}
.floating-bg .bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 2000rem;
  height: 100%;
  z-index: 1;
  background-color: #1c1c1c;
}
.floating-bg .row {
  position: relative;
  z-index: 9;
}
.project-section {
  padding: 130px 60px 80px;
}
.title-box .title-main.dir-left:before {
  content: '';
  height: 1px;
  width: 2000rem;
  background-color: #c59775;
  position: absolute;
  top: 0;
  right: 0 !important;
  left: initial;
  z-index: 1;
}
.title-box .title-main.dir-left:after {
  content: '';
  height: 1px;
  width: 2000rem;
  background-color: #c59775;
  position: absolute;
  bottom: 0;
  right: 0 !important;
  left: initial;
  z-index: 1;
}
.title-box-right > img {
  width: 100%;
  height: auto;
  margin: 0;
  padding-bottom: 2rem;
}
.project-bg {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 3;
  width: 100%;
  height: 100%;
  background-size: auto;
  background-repeat: no-repeat;
  background-position: top right;
}
.project-bg-half {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 3;
  width: 50%;
  height: 100%;
  background-size: auto;
  background-repeat: no-repeat;
  background-position: top right;
}
.project-bg-full {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 3;
  width: 100%;
  height: 100%;
  background-size: auto;
  background-repeat: no-repeat;
  background-position: top right;
}
.bg-repeating {
  position: relative;
  background-size: auto;
  background-repeat: repeat;
  background-position: center center;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  min-height:400px;
}
.cl-logo{
  width: 80%;
  max-width: 80%;
  height: auto;
  margin: auto;
}
.project-bg-half.project-bg-left {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
  width: 50%;
  height: 100%;
  background-size: auto;
  background-repeat: no-repeat;
  background-position: top left;
}
.project-bg-full.project-bg-left {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
.project-section .image-frame {
  margin-bottom: 40px;
}
.passion-section {
  background-color: #323232;
  padding: 60px 60px 45px;
}
.passion-section.no-pad{
  padding: 0;
}
.passion-section p {
  color: #fff;
}
.passion-section.no-bg,
.project-section.no-bg {
  background-color: transparent;
}
.passion-section.no-bg p,
.project-section.no-bg p {
  color: #000;
}
.passion-content {
  color: #efc56b;
}
.passion-content .yellow-title {
  font-weight: 700;
  font-size: 16px;
  line-height: 1.12;
  margin-bottom: 5px;
  color: #efc56b;
}
.passion-content .green-dog-logo {
  display: block;
  margin: 0 auto 40px;
}
.passion-content .image-frame {
  margin-top: 25px;
  margin-left: auto;
  margin-right: auto;
}
.catering p,
.display-2 p,
p.display-2,
.display-2 ul,
ul.display-2,
.display-2 ol,
ol.display-2 {
  font-family: 'Cormorant Infant', serif;
  font-size: 24px;
  margin-bottom: 40px;
  color: #5a5858;
  line-height: 1.5;
}
.signame {
  letter-spacing: 6px;
  font-size: 16px;
  color: #333;
}
.consultation-section {
  padding-top: 75px;
  padding-bottom: 50px;
}
.cs-heading h2 {
  color: #cacaca;
  font-size: 72px;
  line-height: 0.9;
  text-transform: uppercase;
  font-family: 'Open Sans Condensed', sans-serif;
  font-weight: 300;
  margin-bottom: 25px;
}
.cs-heading p {
  color: #232323;
  font-size: 16px;
  text-transform: uppercase;
  margin-bottom: 45px;
}
.cta p {
  font-size: 24px;
  line-height: 1.5;
  color: #5a5858;
  font-family: 'Cormorant Infant', serif;
}
.gallery {
  margin-bottom: 30px;
}
.g-img {
  margin-bottom: 30px;
  position: relative;
}
.footer-section {
  padding-top: 60px;
  padding-bottom: 90px;
  background-color: #000;
  color: #fff;
}
.footer-section .footer-lead {
  letter-spacing: 6px;
  font-size: 16px;
  margin-bottom: 45px;
  text-transform: uppercase;
  color: #fff;
}
.footer-section a {
  color: #efc56b !important;
}
.footer-section a:hover {
  color: #7b633a !important;
}
.footer-section p {
  line-height: 1.6;
  margin-bottom: 30px;
  color: #fff;
}
.footer-main-content {
  padding-top: 20px;
  padding-bottom: 20px;
}
.footer-links {
  display: block;
  list-style: none;
  padding: 0;
  margin-bottom: 30px;
}
.footer-links li {
  display: block;
  margin-bottom: 15px;
}
.footer-links li a {
  font-size: 40px;
  line-height: 1.12;
  color: #bb9d69 !important;
  font-family: 'Open Sans Condensed', sans-serif;
  font-weight: 300;
  text-transform: uppercase;
}
.footer-links li a:hover {
  color: #7b633a !important;
}
.spacer-1 {
  margin: 0 0 1rem;
}
.spacer-2 {
  margin: 0 0 2rem;
}
.spacer-3 {
  margin: 0 0 3rem;
}
.pad-1 {
  margin: 3rem auto 3rem;
}
.pad-2 {
  margin: 4rem auto 4rem;
}
.pad-3 {
  margin: 5rem auto 5rem;
}
.m-auto {
  margin-left: auto;
  margin-right: auto;
}
.light {
  background: #fff;
}
.light blockquote p,
.light .display-1 p,
.light p.display-1 {
  color: #5a5858;
}
.light .title-box .title-top {
  color: #5a5858;
}
.light a:not(.btn) {
  color: #7b633a;
  text-decoration: underline !important;
}
.light a:not(.btn):hover {
  color: #bb9d69;
}
.dark {
  background: #333;
  color: #fff;
}
.dark blockquote p,
.dark .display-1 p,
.dark p.display-1 {
  color: #efc56b;
}
.dark p {
  color: #fff;
}
.dark a:not(.btn) {
  color: #efc56b;
  text-decoration: underline !important;
}
.dark a:not(.btn):hover {
  color: #bb9d69;
}
.dark h3 {
  color: #fff;
}
.dark h2 {
  color: #efc56b;
}
h2 {
  font-size: 72px;
  line-height: 1.12;
  text-transform: uppercase;
  color: #A28449;
  font-family: 'Open Sans Condensed', sans-serif;
  font-weight: 300;
  padding-top: 20px;
  padding-bottom: 20px;
  margin-bottom: 50px;
  margin-top: 50px;
  position: relative;
}
h2:before {
  content: '';
  height: 1px;
  width: 100%;
  background-color: #c59775;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
h2:after {
  content: '';
  height: 1px;
  width: 100%;
  background-color: #c59775;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
}
h3,
.h3 {
  text-transform: uppercase;
  font-weight: bold;
  color: #5a5858;
  margin-bottom: 28px;
  line-height: 1.5;
}
p {
  color: #5a5858;
  line-height: 2;
}
.mobile-only {
  display: none;
}
.blog-thumb {
  width: 100%;
  min-width: 100%;
  max-width: 100%;
}
.blog-title {
  font-weight:bold;
  font-size:larger;
}
.blog-container {
  margin-bottom: 50px;
}
/* home page image strip */
.flex-gallery-container{
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: center;
  align-items: stretch;
  height: 400px;
}
.flex-gallery-item{
  background-position: center center;
  background-size: cover;
}
.flex-gallery-item.fg-item-top,
.flex-gallery-item.fg-item-bottom{
  width: 25%;
  min-width: 25%;
  max-width: 25%;
}
.flex-gallery-item.fg-item-top{}
.flex-gallery-item.fg-item-middle{
  width: 50%;
  min-width: 50%;
  max-width: 50%;
}
.gap-section{
  padding: 1rem 0;
}
@media (min-width: 992px) {
  .container {
    width: 100%;
  }
  .cs-heading {
    text-align: right;
  }
  .g-img-1 {
    margin-top: -368px;
    z-index: 9;
  }
  .g-img-2 {
    margin-top: -150px;
  }
  .g-img-3 {
    margin-top: -600px;
  }
  .g-img-4 {
    margin-top: -120px;
  }
  .g-img-5 {
    margin-top: -225px;
  }
  .g-img-6 {
    margin-top: -253px;
  }
}
@media (min-width: 1200px) {
  .g-img-1 {
    margin-top: -368px;
    z-index: 9;
  }
  .g-img-2 {
    margin-top: -225px;
  }
  .g-img-3 {
    margin-top: -700px;
  }
  .g-img-4 {
    margin-top: -169px;
  }
  .g-img-5 {
    margin-top: -230px;
  }
  .g-img-6 {
    margin-top: -335px;
  }
}
@media (max-width: 991px) {
  .container {
    width: 100%;
  }
  .project-bg {
    display: none;
  }
  .passion-content {
    padding-top: 40px;
  }
  .footer-section .image-frame {
    margin-bottom: 30px;
  }
  .footer-links li a {
    font-size: 23px;
  }
}
@media (max-width: 767px) {
  .container {
    width: 100%;
  }
  iframe {
    width: 100%;
    height: 400px;
  }
  .title-box .title-main {
    font-size: 55px;
  }
  h2 {
    font-size: 42px;
  }
  blockquote p {
    font-size: 24px;
  }
  .consultation-section {
    padding-top: 34px;
    padding-bottom: 34px;
  }
  .project-section,
  .passion-section {
    padding: 60px 20px 60px;
  }
  .home-section {
    padding-bottom: 60px;
  }
  .quote-section {
    padding-top: 60px;
    padding-bottom: 45px;
  }
  .content-section {
    padding-top: 60px;
    padding-bottom: 45px;
  }
  .catering p,
  .display-2 p,
  p.display-2,
  .display-2 ul,
  ul.display-2,
  .display-2 ol,
  ol.display-2 {
    font-size: 17px;
    margin-bottom: 20px;
  }
  .home-section .image-frame {
    margin-left: auto;
    margin-right: auto;
  }
  .project-section .image-frame {
    margin-left: auto;
    margin-right: auto;
  }
  .toggler {
    top: 20px;
    right: 20px;
  }
  .nav-menu ul {
    padding: 100px 15px 15px 20px;
  }
  .nav-menu ul li a {
    font-size: 35px;
  }
  .nav-menu ul li {
    margin-bottom: 20px;
  }
  .cs-heading h2 {
    font-size: 40px;
  }
}
@media (max-width: 834px) {
  .container {
    width: 100%;
  }
  .mobile-only {
    display: block;
  }
  .project-bg-half {
    display: none;
  }
}
@media screen and (max-width:768px){
  .mobile-reverse-flow{
    flex-direction: column-reverse;
  }
  .cl-logo{
    margin-top: 2rem;
  }
}
@media screen and (max-width:736px){
  .flex-gallery-container{
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    height: auto;
  }
  .flex-gallery-item.fg-item-top,
  .flex-gallery-item.fg-item-middle,
  .flex-gallery-item.fg-item-bottom{
    width: 100%;
    min-width: 100%;
    max-width: 100%;
  }
  .flex-gallery-item.fg-item-top,
  .flex-gallery-item.fg-item-bottom{
    height: 90vw;
  }
  .flex-gallery-item.fg-item-middle{
    height: 60vw;
  }
}
@media (min-width: 576px) {
  .container {
    width: 100%;
    max-width: 1140px;
  }
}
@media (max-width: 414px) {
  .container {
    width: 100%;
  }
  .hightlight p {
    padding: 0 12px 0 0;
  }
  .highlight .left-padding {
    padding-left: 12px;
  }
}
