/*This is my gateway CSS using Eric Meyer's reset at the top of my page */


/* http://meyerweb.com/eric/tools/css/reset/
    v2.0 | 20110126
    License: none (public domain)
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}

/* This CSS was created by Kael Skyhawk Hauptmann */

/* This is the beginning of website CSS */

@font-face {
  font-family:'Playfair';
  src: url('../fonts/playfair/playfair-bold.eot');
  src: url('../fonts/playfair/playfair-bold.eot?#iefix') format('embedded-opentype'),
    url('../fonts/playfair/playfair-bold.woff2') format('woff2'),
    url('../fonts/playfair/playfair-bold.woff') format('woff'),
    url('../fonts/playfair/playfair-bold.svg#Playfair 144pt Bold') format('svg');
  font-weight: 700;
  font-style: normal;
  font-stretch: normal;
  unicode-range: U+0020-2212;

  font-family:'Oswald';
  src: url('../fonts/oswald/oswald-light.eot');
  src: url('../fonts/oswald/oswald-light.eot?#iefix') format('embedded-opentype'),
    url('../fonts/oswald/oswald-light.woff2') format('woff2'),
    url('../fonts/oswald/oswald-light.woff') format('woff'),
    url('../fonts/oswald/oswald-light.svg#Oswald Light') format('svg');
  font-weight: 300;
  font-style: normal;
  font-stretch: normal;
  unicode-range: U+0020-02DC;
}

body {
  font-family: "Oswald", Tahoma, Verdana, Arial, sans-serif;
  background-color: #fff;
}

main {
  margin: 0 auto;
  padding-top: 50px;
}

h1 {
	font-family:'Playfair', Garamond, Georgia, 'Times New Roman', serif;
	font-size: 3em;
  color:#332220;
  text-align: center;
}

h3, h4 {
  text-align: center;
  font-size: .9em;
  letter-spacing: .5px;
}

p {
  line-height: 2em;
  letter-spacing: 0.025em;
}

/* SECTION HEADERS */

footer {
  background-color: #E0A36D;
  padding: 40px 20px;
  }

.h-services {
  display: flex;
  -webkit-display: flex;
  -moz-display: flex;
  -o-display: flex;
  -ms-display: flex;
  justify-content: center;
  align-items: center;
  padding: 200px 0 100px;
  clear: both;
}

.h-box {
  width: 280px;
	box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  border: 2px solid #332220;
  padding: 20px;
}

.h-line {
  width: 130px;
  border-bottom: 2px solid #332220;
  margin: 1px 30px 0;
}

.bg-color {
  background-color: #B69577;
  border-top: 2px solid #332220;
  border-bottom: 2px solid #332220;
}

#services,
#gallery,
#about,
#contact {
  margin-top: -50px;
}


/* HOME / HERO SECTION */

header {
  background-color: rgba(255, 255, 255, 0.15);
  background-blend-mode: overlay;
  background-image: url("../assets/index_hero.jpg");
  background-size: cover;
  border-bottom: 2px solid #332220;
  height: 900px;
  background-position: center center;
}

#heroLogo {
  margin: 0 auto;
  display: block;
  text-align: center;
  transition: all 350ms ease-out;
  -webkit-transition: all 350ms ease-out;
  -moz-transition: all 350ms ease-out;
  -o-transition: all 350ms ease-out;
  -ms-transition: all 350ms ease-out;
}

/* NAVIGATION BAR */

#topNav {
  position: sticky;
  position: -webkit-sticky;
  position: -moz-sticky;
  position: -o-sticky;
  position: -ms-sticky;
  top: 0px;
  /* overflow: hidden; */
  z-index: 2;
  background-color: #fff;
  transition: all 100ms ease-out;
  -webkit-transition: all 100ms ease-out;
  -moz-transition: all 100ms ease-out;
  -o-transition: all 100ms ease-out;
  -ms-transition: all 100ms ease-out;
}

nav {
  background-color: #E0A36D;
  padding: 10px 0;
  transition: box-shadow 500ms ease;
  -webkit-transition: box-shadow 500ms ease;
  -moz-transition: box-shadow 500ms ease;
  -o-transition: box-shadow 500ms ease;
  -ms-transition: box-shadow 500ms ease;
  text-align: center;
}

nav li {
  display: inline-block;
  list-style: none;
}

.nav-text {
  width: 70px;
  padding: 10px 20px;
}

#navBox {
  transition: all 300ms ease;
  -webkit-transition: all 300ms ease;
  -moz-transition: all 300ms ease;
  -o-transition: all 300ms ease;
  -ms-transition: all 300ms ease;
}

nav li a {
  text-decoration: none;
  text-align: center;
  font-size: .9em;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 2px;
  padding: 5px 0;
  border-top: 2px solid #E0A36D;
  border-bottom: 2px solid #E0A36D;
  border-radius: 4px;
  transition: all 150ms ease;
  -webkit-transition: all 150ms ease;
  -moz-transition: all 150ms ease;
  -o-transition: all 150ms ease;
  -ms-transition: all 150ms ease;
}

.navActive {
  color: #332220;
}

nav li a:hover{
  color: #8B7E73 !important;
  border-color: #8B7E73;
}

#logoBG {
  border-radius: 8px;
  background-color: #E0A36D;
  background: url(../assets/nav_logo_bg.jpg);
  background-size: cover;
  z-index: 3;
  height: 103px;
  padding: 8px 20px;
  position: sticky;
  position: -webkit-sticky;
  position: -moz-sticky;
  position: -o-sticky;
  position: -ms-sticky;
  margin-left: auto;
  margin-right: auto;
  left: 0;
  right: 0;
  top: 5px;
  transition: all 300ms ease-out 100ms;
  -webkit-transition: all 300ms ease-out 100ms;
  -moz-transition: all 300ms ease-out 100ms;
  -o-transition: all 300ms ease-out 100ms;
  -ms-transition: all 300ms ease-out 100ms;
}

#logoBG:hover {
  filter: brightness(110%);
}

#navLogo {
  transition: all 300ms ease-out 100ms;
  -webkit-transition: all 300ms ease-out 100ms;
  -moz-transition: all 300ms ease-out 100ms;
  -o-transition: all 300ms ease-out 100ms;
  -ms-transition: all 300ms ease-out 100ms;
}

#nav-logo-responsive {
  width: 150px;
  display: none;
  margin: 0 auto;
  padding: 10px 0;
}

/* SERVICES SECTION */

.icon-box {
  display: flex;
  -webkit-display: flex;
  -moz-display: flex;
  -o-display: flex;
  -ms-display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  padding: 10px 30px;
}

.iconCircle {
  border-radius: 50%;
  background-color: #fff;
  margin: 10px 30px;
  display: flex;
  -webkit-display: flex;
  -moz-display: flex;
  -o-display: flex;
  -ms-display: flex;
  justify-content: center;
  align-items: center;
  width: 100px;
  height: 100px;
  border: 2px solid #332220;
  transition: all 200ms ease-out;
  -webkit-transition: all 200ms ease-out;
  -moz-transition: all 200ms ease-out;
  -o-transition: all 200ms ease-out;
  -ms-transition: all 200ms ease-out;
}

.iconCircle h3 {
padding: 10px 0;
}

.icon-center {
  display: flex;
  -webkit-display: flex;
  -moz-display: flex;
  -o-display: flex;
  -ms-display: flex;
  align-items: center;
  flex-direction: column;
}

.p-services {
  max-width: 600px;
  margin: 0 auto;
  padding: 70px 30px 170px;
}

.p-services p{
  padding: 20px 0;
}

#pServices,
#pAbout {
  transition: all 500ms ease-out;
  -webkit-transition: all 500ms ease-out;
  -moz-transition: all 500ms ease-out;
  -o-transition: all 500ms ease-out;
  -ms-transition: all 500ms ease-out;
}

#pAbout p:not(:first-child) {
    padding-top: 20px;
}

.p-services a{
  color: #B69577;
  text-decoration: none;
}

#arrow-align {
  position: relative;
  top: -3px;
  font-weight: bold;
  -webkit-text-stroke: .5px #B69577;;
}

#table_1 {
  padding-top: 70px;
}

/* GALLERY SECTION */

.gallery-container {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 20px;
}

.grid-wrapper > div {
	display: flex;
	justify-content: center;
	align-items: center;
  border: solid 2px #332220;
  overflow: hidden;
}
.grid-wrapper > div > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
  transition: all .2s ease-in-out;
	-webkit-transition: all .2s ease-in-out;
	-moz-transition: all .2s ease-in-out;
	-o-transition: all .2s ease-in-out;
	-ms-transition: all .2s ease-in-out;
}

.grid-wrapper > div > img:hover {
  transform: scale(1.05);
  -webkit-transform: scale(1.05);
  -moz-transform: scale(1.05);
  -o-transform: scale(1.05);
  -ms-transform: scale(1.05);
  cursor: pointer;
}

.grid-wrapper {
	display: grid;
	grid-gap: 20px;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	grid-auto-rows: 200px;
	grid-auto-flow: dense;
}
.grid-wrapper .wide {
	grid-column: span 2;
}
.grid-wrapper .tall {
	grid-row: span 2;
}
.grid-wrapper .big {
	grid-column: span 2;
	grid-row: span 2;
}

/* MODAL BACKGROUND */

.gallery-modal {
  display: none;
  position: fixed;
  z-index: 4;
  padding-top: 100px;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: #332220;
}

/* MODAL CONTENT */

.modal-content {
  position: relative;
  background-color: #fefefe;
  margin: auto;
  padding: 0;
  width: 90%;
  max-width: 1000px;
}

.modal-buttons {
  position: absolute;
  margin-left: auto;
  margin-right: auto;
  left: 0;
  right: 0;
  top: 0;
  text-align: center;
  color: #E0A36D;
  margin: -10px auto 0;
  padding-bottom: 30px;
  font-weight: bold;
  user-select: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -o-user-select: none;
  -ms-user-select: none;
}

/* NEXT & PREVIOUS BUTTONS */
.prev,
.next {
  font-size: 3em;
  cursor: pointer;
}

/* CLOSE BUTTON */

.close {
  font-size: 5em;
  padding: 0 5px;
  margin: 10px 5px 0;
  position: relative;
  top: 7px;
  cursor: pointer;
}

.close:hover,
.close:focus,
.prev:hover,
.prev:focus,
.next:hover,
.next:focus {
  color: #8B7E73;
}

.gallerySlides {
  display: none;
  transition: all .9s ease-in-out;
	-webkit-transition: all .9s ease-in-out;
	-moz-transition: all .9s ease-in-out;
	-o-transition: all .9s ease-in-out;
	-ms-transition: all .9s ease-in-out;
}

.gallerySlides img{
  width: 100%;
}

.gallery-table {
  max-width: 500px;
  margin: 0 auto;
  padding: 170px 0 170px;
}

/* ABOUT SECTION */

#aboutPortrait {
  margin: 0 auto 70px;
  max-width: 200px;
}

#aboutPortrait img {
  width:100%;
  border: 2px solid #332220;
  transition: all 300ms ease-in-out;
  -webkit-transition: all 300ms ease-in-out;
  -moz-transition: all 300ms ease-in-out;
  -o-transition: all 300ms ease-in-out;
  -ms-transition: all 300ms ease-in-out;
}

.p-about {
  max-width: 600px;
  margin: 0 auto;
  padding: 20px 30px 70px;
}

/* CONTACT SECTION */

.contact {
  padding: 0 30px;
}

.contact .h-services {
  padding-bottom: 0;
}


.contact .h-box {
  width: 200px;
  z-index: 1;
  background-color: #fff;
}

.contact h1 {
  font-size: 2.5em;
}

#contactForm {
  position: relative;
  top: -42px;
  max-width: 400px;
  border: 2px solid #332220;
  margin: 0 auto;
  transition: all 300ms ease-in-out;
  -webkit-transition: all 300ms ease-in-out;
  -moz-transition: all 300ms ease-in-out;
  -o-transition: all 300ms ease-in-out;
  -ms-transition: all 300ms ease-in-out;
}

form {
  padding: 55px 20px 0;
  outline: none;
}

input,
textarea {
  width: 100%;
  font-family: "Oswald", Tahoma, Verdana, Arial, sans-serif;
  letter-spacing: 0.025em;
  padding: 20px 0 10px;
  border: none;
  border-bottom: 1px solid #332220;
}

textarea {
  resize: none;
  overflow: hidden;
  height: 20px;
}

#submit {
  border: none;
  margin: 40px 0 30px;
  padding: 15px 10px;
  color: #8B7E73;
  background-color: rgb(139, 126, 115, 0.2);
  transition: all .2s ease-in;
  -webkit-transition: all .2s ease-in;
  -moz-transition: all .2s ease-in;
  -o-transition: all .2s ease-in;
  -ms-transition: all .2s ease-in;
}

#submit:hover {
  cursor: pointer;
  background-color: rgb(139, 126, 115, .5);
  color: #332220;
  /* border: 2px solid #332220; */
  /* padding: 13px 8px; */
}

*:focus {
  outline: none;
}

::placeholder {
  color: #8B7E73;
  opacity: 1; /* Firefox */
}

::-ms-input-placeholder {
  color: #8B7E73; /* Edge 12 -18 */
}

#contact-info h1 {
  padding: 20px;
}

#phone-icon{
  position: relative;
  top: 14px;
  left: 30px;
}

#email-icon {
  position: relative;
  top: 28px;
  left: 21px;
}

#contact-info .icon-box {
  padding: 20px;
  align-items: initial;
}

#contact-info .icon-box-padding {
  padding: 10px 0;
  margin: 0 auto;
}

#contact-info .icon-box-padding:first-child {
  padding-top: 15px;

}

#contact-info h3 {
  font-size: 1em;
  line-height: 1.5em;
  padding: 0 30px;
  transition: all 300ms ease-in-out;
  -webkit-transition: all 300ms ease-in-out;
  -moz-transition: all 300ms ease-in-out;
  -o-transition: all 300ms ease-in-out;
  -ms-transition: all 300ms ease-in-out;
}

#contact-info h3 a {
  text-decoration: none;
  color: #332220;
}

#contact-info h3 a:hover,
.p-services a:hover {
  color: #8B7E73;
}

.contact-table {
  max-width: 200px;
  margin: 0 auto;
  padding: 170px 0;
}

@media screen and (max-width: 768px) {

  .iconCircle{
    transform: scale(1.0) !important;
  }

  #pServices {
    font-size: 1em !important;
  }

  #aboutPortrait img {
    transform: scale(1.0) !important;
  }

  #pAbout {
    font-size: 1em !important;
  }

  #contactForm {
    transform: scale(1.0) !important;
  }
  #contact-info h3 {
    font-size: 1em !important;
  }
}

@media screen and (max-width: 716px) {

  .bg-color .icon-box {
    width: 400px;
    margin: auto;
  }
}

@media screen and (max-width: 694px) {
  .nav-text {
    padding: 10px 10px;
  }
}

@media screen and (max-width: 670px) {
  .h-box {
    width: 220px;
  }

  .h-line {
    width: 80px;
  }

}

@media screen and (max-width: 640px) {
  #logoBG {
    display: none !important;
  }
  #nav-logo-responsive {
    display: block;
  }
  #navBox {
    display: none;
  }
  #topNav {
    padding-top: 0 !important;
  }
  nav li {
    display: block;
    margin: 0 auto;
  }

  #services, #gallery, #about, #contact {
    padding-top: 70px;
  }
}

@media screen and (max-width: 620px) {

  header {
    height: 400px;
  }

  #heroLogo {
    width: 300px !important;
    padding-top: 130px !important;
  }
}

@media screen and (max-width: 552px) {

  .bg-color .icon-box {
    width: inherit;
    margin: auto;
  }
}