/* -------------------- GENERIC -------------------- */

html, body {
  margin: 0; padding: 0;
  background-color: #F8F8F8;
  font-family: 'Open Sans', sans-serif;
  color: #393939;
  height: 100%
}

.map_overlay {
   background:transparent;
   position:relative; 
   width:100%;
   height:500px; /* your iframe height */
   top:500px;  /* your iframe height */
   margin-top:-500px;  /* your iframe height */
}

section { margin: 65px 0; }

.container {
  margin: 0 auto;
  width: 96%;
  max-width: 940px;
}

.hide_from_desktop { display: none; }

h2 { font-family: 'lora', serif; font-weight: 700; font-size: 24pt; }
h3 { font-family: 'lora', serif; font-weight: 700; font-size: 20pt; }
p { font-family: 'Open Sans', sans-serif; font-size: 12pt; /*margin: 22px 0;*/ }

.spacer { margin: 0 0 22px 0; }
.underlined { border-bottom: solid 2px orange; padding-bottom: 6px;}

hr {
    border: 0;
    height: 1px;
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.75), rgba(0, 0, 0, 0));
}

button {
  background-color: orange;
  border: none;
  width: auto;
  padding: 14px;
  color: #393939;
  font-size: 12pt;
}

a button:hover { color: #fff; }

blockquote { margin: 0; }

blockquote p.says {
  font-size:16px;
  text-align:left;
  font-style: italic;
  padding:0 0 0 20px;
  position:relative;
}

blockquote p.says:before, blockquote p.says:after {
  content: ' ”';
  font-size: 40px;
  vertical-align:top;
  line-height:0.8
}

blockquote p.says:before {
  content: '“';
  position:absolute;
  left: 0;
  top:-2px;
}

.full_width {
  width: 100%;
}

img { border-style: none; }


/* ---------- HERO ---------- */

.hero {
  margin: 0 auto;
  width: 100%;
  max-width: 1920px;
  height: auto;
  padding: 110px 0;
  background-image: url("../images/horses.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: 10%;
  text-align: center;
  border-bottom: 3px solid orange;
} 

.hero img { 
  margin: 0 0 45px 0;
  width: 100%;
  max-width: 498px;
}

.hero h1 {
  margin: 0 0 25px 0;
  font-family: 'lora', serif; font-weight: 700; font-size: 24pt;
  color: #fff;
}


/* ---------- NAVIGATION ---------- */

ul {
  margin: 0;
  color: #fff;
  text-align: right;
}

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

li a {
  border: none;
  text-decoration: none;
  display: inline-block;
  list-style: none;
  color: #393939;
  background-color: #F8F8F8;
  padding: 25px 14px 14px 14px;
}

li a:link { color: #393939; }
li a:visited { color: #393939; }
li a:hover { color: orange; }
li a:active { color: #393939; }

.active_link, .active_link:hover {
  background-color: orange;
  color: #393939;
}


/* ---------- FACILITIES ---------- */

.facilities_homepage_col_1,.facilities_homepage_col_2,.facilities_homepage_col_3 { display: inline-block; vertical-align: top; }
.facilities_homepage_col_1 { width: 32%; margin: 0 2% 0 0; }
.facilities_homepage_col_2 { width: 32%; margin: 0; }
.facilities_homepage_col_3 { width: 32%; margin: 0 0 0 2%; }


/* ---------- HORSES ---------- */

.horses_col_1,.horses_col_2 { display: inline-block; }
.horses_col_1 { width: 64%; vertical-align: middle; margin: 0 2% 0 0; }
.horses_col_2 { width: 32%; vertical-align: middle; margin: 0 0 0 2%; }


/* ---------- ABOUT SARAH ---------- */

.about_container {
  margin: 0 auto;
  padding: 40px 0;
  max-width: 1020px; 
  background-color: #eee;
  margin-bottom: 1em;
  background-color: rgba(0,0,0,.02);
}

.about_col_1 { width: 64%; display: inline-block; vertical-align: middle; margin: 0 2% 0 0; }
.about_col_2 { width: 32%; display: inline-block; vertical-align: middle; margin: 0 0 0 2%; }


/* ---------- TESTIMONIALS ---------- */

.testimonial_col_1 { width: 47%; display: inline-block; vertical-align: top; margin: 0 3% 0 0;}
.testimonial_col_2 { width: 47%; display: inline-block; vertical-align: top; margin: 0 0 0 3%;}


/* ---------- FACILITIES ---------- */

.facilities_row { width: 100%; display: block; }
.facilities_col_1 { width: 54%; display: inline-block; vertical-align: middle; margin: 0 3% 0 0; }
.facilities_col_2 { width: 40%; display: inline-block; vertical-align: middle; margin: 0 0 0 3%; }


/* ---------- HERD MEMBERS ---------- */

.herd_members_row { width: 100%; display: block; }
.herd_members_col_1 { width: 54%; display: inline-block; vertical-align: middle; margin: 0 3% 0 0; }
.herd_members_col_2 { width: 40%; display: inline-block; vertical-align: middle; margin: 0 0 0 3%; }


.herd_members_testimonial_row {
  margin: 0 auto;
  padding: 40px 0;
  max-width: 1020px; 
  background-color: #eee;
  margin-bottom: 1em;
  background-color: rgba(0,0,0,.02);
}

.herd_members_testimonial_col_1 { width: 100%; display: inline-block; vertical-align: middle; margin: 0;}

.quote_name { text-align: right; }

/* ---------- CONTACT  ---------- */

.contact_row { width: 100%; display: block; }
.contact_col_1 { width: 31.33%; display: inline-block; vertical-align: top; margin: 0 3% 0 0; }
.contact_col_2 { width: 31.33%; display: inline-block; vertical-align: top; margin: 0 0 0 0; }
.contact_col_3 { width: 31.33%; display: inline-block; vertical-align: top; margin: 0 0 0 3%; }

.email_address { text-decoration: none; color: #393939; }


/* ---------- FOOTER ---------- */

footer {
  padding: 50px 0;
  background-color: #393939;
  color: #fff;
  border-top: 3px solid orange;
}

footer a {
  text-decoration: none;
  color: #fff;
}

footer p { font-family: 'Open Sans', sans-serif; font-size: 11pt; }

.footer_col_1 { width: 48%; display: inline-block; vertical-align: top; margin: 0 2% 0 0; text-align: left; }
.footer_col_2 { width: 48%; display: inline-block; vertical-align: top; margin: 0 0 0 2%; text-align: right; }


/* ---------- SPACING OVERIDE ON FACILITIES AND HERD_MEMBERS PAGES ---------- */

.facilities_row h3 { margin-top: 0 !important; }
.facilities_row p { margin-bottom: 0 !important; }

.herd_members_row h3 { margin-top: 0 !important; }
.herd_members_row p { margin-bottom: 0 !important; }


/* ---------- RESPONSIVE >500 ---------- */

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

  .hide_under_500 { display: none; }

  .h2_resize_to_fit { font-size: 18pt !important; }

  ul {
    margin: 0;
    padding: 0;
    color: #fff;
    text-align: center;
  }

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

  li a { margin: 0; padding: 0; }

  a { margin: 0;  padding: 0; }

  .active_link, .not_active_link {
    width: 100%;
    padding: 6px 0; margin: 0 0 4px 0;
  }

  .hero { border: none; margin: 0; padding: 35px 0; }

  .hero img {
    width: 90%;
  }

}


/* ---------- RESPONSIVE 650-500 ---------- */

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

  section { margin: 50px 0; }

  h3 {margin-bottom: 22px; }

  .horses_col_1 { width: 100%; display: block; vertical-align: top; margin: 0; }

  .facilities_homepage_col_1,.facilities_homepage_col_2,.facilities_homepage_col_3 { display: block; vertical-align: top; }
  .facilities_homepage_col_1 { width: 100%; }
  .facilities_homepage_col_2 { width: 100%; margin: 0; }
  .facilities_homepage_col_3 { width: 100%; }

  .about_col_1 { width: 100%; display: block; vertical-align: top; margin: 0; }
  .about_col_2 { width: 100%; display: block; vertical-align: middle; margin: 0;}

  .testimonial_col_1 { width: 100%; display: block; vertical-align: top; margin: 0; }
  .testimonial_col_2 { width: 100%; display: block; vertical-align: top; margin: 0; }

  .herd_members_col_1 { width: 100%; display: block; vertical-align: top; margin: 0; }
  .herd_members_col_2 { width: 100%; display: block; vertical-align: top; margin: 0; }

  .facilities_col_1 { width: 100%; display: block; vertical-align: top; margin: 0; }
  .facilities_col_2 { width: 100%; display: block; vertical-align: top; margin: 0; }

  .contact_col_1 { width: 100%; display: block; vertical-align: top; margin: 0; }
  .contact_col_2 { width: 100%; display: block; vertical-align: top; margin: 0; }
  .contact_col_3 { width: 100%; display: block; vertical-align: top; margin: 0; }

  .hide_from_mobile { display: none; }
  .hide_from_desktop { display: block; }

  .footer_col_1 { width: 100%; display: block; vertical-align: top; margin: 0; text-align: left; }
  .footer_col_1 p { margin: 0; }
  
  .footer_col_2 { width: 100%; display: block; vertical-align: top; margin: 0; text-align: left; }

  .responsive_container {
    width: 100%
  }

}