@font-face {
  font-family: "libre_franklinregular";
  src: url("fonts/librefranklin-regular.woff2") format("woff2"),
    url("fonts/librefranklin-regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: "libre_franklinextralight";
  src: url("fonts/librefranklin-extralight.woff2") format("woff2"),
    url("fonts/librefranklin-extralight.woff") format("woff");
  font-weight: normal;
  font-style: normal;
}

body {
  font-family: "libre_franklinregular";
}
a,
img,
button,
div,
a:active,
img:active,
button:active,
div:active,
a:focus {
  outline: none;
}
a,
input,
span,
small,
button {
  transition: all 0.2s ease 0s;
  -moz-transition: all 0.2s ease 0s;
  -webkit-transition: all 0.2s ease 0s;
  -o-transition: all 0.2s ease 0s;
}
h1,
h2,
h3,
h4,
h5,
h6,
p {
  font-family: libre_franklinextralight;
}
h3 {
  font-size: 18px;
  line-height: 29px;
}
h4 {
  font-size: 16px;
  line-height: 32px;
}
p {
  line-height: 27px;
}
a {
  color: #c4525a;
}
a:hover {
  color: #222;
}
.btn {
  border-radius: 4px;
  -moz-border-radius: 4px;
  -webkit-border-radius: 4px;
  font-size: 13px;
  font-weight: bold;
  padding: 19px 40px;
  text-transform: uppercase;
}
.red-btn {
  background-color: #e11f2c;
  border-color: #e11f2c;
  color: #fff;
  margin: 0 10px;
}
.btn-default:hover {
  background-color: #e11f2c;
  border-color: #e11f2c;
  color: #fff;
}
.black-btn,
.red-btn:hover,
.wpcf7-submit:hover {
  background-color: #000;
  border-color: #000;
  color: #fff;
  margin: 0 10px;
}
.nopadding {
  padding: 0 !important;
  margin: 0 !important;
}
.center {
  text-align: center;
}
.col-top {
  vertical-align: top;
}
.col-middle {
  vertical-align: middle;
}
.col-bottom {
  vertical-align: bottom;
}

.header {
  padding: 30px 0;
}
.logo img {
  margin: 0 5px 0 0;
}
.logo span {
  display: none;
  font-size: 30px;
  letter-spacing: 2px;
  text-transform: uppercase;
  vertical-align: middle;
}
.nav.navbar-navd:last-child {
  display: none;
}
.navbar-collapse.collapse {
  text-align: center;
}
.navbar-nav, .navbar-nav>li {
  float: none;
}
.navbar-nav>li {
  display: inline-block;
}
.navbar {
  margin: 0;
}
.navbar-default {
  background: none;
  border: none;
}
.navbar-default .navbar-nav > li > a {
  color: #222;
  font-family: arial;
  font-size: 14px;
  margin: 0 3px;
  text-transform: uppercase;
}
.navbar-default .navbar-nav > li > a:hover,
.navbar-default .navbar-nav > li.current_page_item > a {
  border-bottom: 2px solid #fada00;
  color: #f15a24 !important;
}
.navbar-collapse {
  border: none;
  padding: 0;
}

.banner {
  position: relative;
}
.banner-buttons {
  position: absolute;
  text-align: center;
  top: 40%;
  width: 100%;
  display: none;
}
.banner-buttons h1 {
  color: #000;
  font-family: "libre_franklinregular";
  font-size: 57px;
  font-weight: bold;
  margin: 0 0 10%;
  background-color: #fcb03b;
  color: #fff;
  display: inline;
  margin: 0 auto;
  opacity: 0.75;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=75)";
  filter: alpha(opacity=75);
  padding: 16px 50px;
  text-transform: uppercase;
}
.nivo-caption {
  display: none !important;
  background: #fff !important;
  color: #000 !important;
  font-size: 33px;
  font-weight: lighter;
  margin: 0 0 19%;
  padding: 8px 0 2px !important;
  text-align: center;
}
.theme-default .nivo-controlNav a.nivo-control {
  background-color: #7f7f7f;
  background-image: none !important;
  width: 15px;
  height: 15px;
  border-radius: 100%;
  -moz-border-radius: 100%;
  -webkit-border-radius: 100%;
  opacity: 0.7;
  filter: alpha(opacity=70);
  margin: 0 10px !important;
}
.theme-default .nivo-controlNav a.active {
  background-color: #e11f2c !important;
  background-image: none !important;
  width: 15px;
  height: 15px;
  border-radius: 100%;
  -moz-border-radius: 100%;
  -webkit-border-radius: 100%;
  opacity: 1;
  filter: alpha(opacity=100);
  margin: 0 10px;
}
.nivo-controlNav {
  bottom: 10%;
  position: absolute;
}

.below-banner {
  margin: 40px 0;
  text-align: center;
}
.below-banner h1 {
  margin: 5px 0 35px;
}
.below-banner p {
  color: #888888;
  font-size: 19px;
  line-height: 34px;
}

.services-one {
  background-color: #f8f8f8;
}
.services-one h2,
.services-two h2 {
  font-size: 25px;
  line-height: 40px;
  margin: 25px 0 15px;
  text-transform: uppercase;
}
.services-one p,
.services-two p {
  color: #7a7a7a;
}
.services-one .col-sm-6 img {
  height: auto;
  width: 100%;
}
.services-two {
  margin: 65px 0;
}
.services-two .col-sm-6 {
  vertical-align: middle;
}

.home-threecols {
  background-color: #f8f8f8;
  margin: 50px 0;
  padding: 40px 0;
  text-align: center;
}
.home-threecols i {
  font-size: 75px;
}

.home-gallery {
  background-color: #f8f8f8;
  margin: 40px 0;
  padding: 30px 0;
}
.gallery-left {
  vertical-align: middle;
}
.gallery-right a {
  display: inline-block;
  padding: 8px;
  opacity: 0.5;
  filter: alpha(opacity=50);
}
.gallery-right a:hover {
  opacity: 1;
  filter: alpha(opacity=100);
}

.home-gallery.about-gallery {
  margin: 0 0 40px;
}
.home-gallery.about-gallery p {
  font-size: 15px;
  line-height: 33px;
}

/*.home-testimonials { background-color: #f8f8f8; margin: 40px 0; padding: 40px 0; }
.home-testimonials .icon { color: #f9d831; font-size: 27px; margin: 10px 0; text-align: center; width: 100%; }
.home-testimonials span { margin: 20px 0 0; }*/

#wpcf7-f21-p6-o1,
#wpcf7-f37-p14-o1 {
  margin: 30px 0 0;
}
#wpcf7-f21-p6-o1 input[type="text"],
#wpcf7-f21-p6-o1 input[type="email"],
#wpcf7-f21-p6-o1 textarea,
#wpcf7-f37-p14-o1 input[type="text"],
#wpcf7-f37-p14-o1 input[type="email"],
#wpcf7-f37-p14-o1 textarea {
  background-color: #f8f8f8;
  border: none;
  -moz-border-radius: 4px;
  -webkit-border-radius: 4px;
  border-radius: 4px;
  margin: 5px 0 17px;
  padding: 10px 20px;
}
#wpcf7-f21-p6-o1 textarea,
#wpcf7-f37-p14-o1 textarea {
  height: 140px;
  margin: 5px 0 0;
}
.wpcf7-submit {
  background-color: #e11f2c;
  border: none;
  border-radius: 3px;
  -moz-border-radius: 3px;
  -webkit-border-radius: 3px;
  color: #fff;
  font-family: sans-serif;
  font-size: 14px;
  letter-spacing: 1px;
  padding: 15px 70px 12px;
  text-transform: uppercase;
}
#wpcf7-f21-p6-o1 div.wpcf7-response-output,
#wpcf7-f21-p6-o1 div.wpcf7-response-output {
  padding: 30px 0 !important;
}

#wpcf7-f37-p14-o1 p,
#wpcf7-f37-p14-o1 label,
#wpcf7-f37-p14-o1 span,
#wpcf7-f37-p14-o1 input,
#wpcf7-f37-p14-o1 textarea {
  width: 100%;
}
#wpcf7-f37-p14-o1 input {
  margin: 0 !important;
}
#wpcf7-f37-p14-o1 input[value="Submit"] {
  display: block;
  margin: 0 auto !important;
  width: auto;
}

footer {
  background-color: #f8f8f8;
  margin: 45px 0 0;
  padding: 30px 0;
}
.footer_about,
.footer_nav,
.footer_comm,
.footer_contact {
  padding: 0;
}
.footer_about li {
  border-bottom: 1px solid #d4d4d4;
  color: #7a7a7a;
  list-style: none;
  margin: 0 0 11px;
  padding: 0 0 5px;
}
.footer_nav li,
.footer_comm li,
.footer_contact li {
  list-style: none;
  margin: 0 0 17px;
}
/*.footer_nav li a { color: #c4525a; } .footer_nav li a:hover { color: #222; }
.footer_comm li a span.name { color: #a5a5a5; display: block; font-size: 12px; }
.footer_comm li a span.title { color: #222; font-size: 14px; }*/
.footer_contact {
  line-height: 22px;
}
.footer_contact li {
  color: #7a7a7a;
  margin: 0 0 20px;
}
.footer_contact li span {
  color: #222;
  font-weight: bold;
}
.footer_contact li small,
.contact ul li small,
.footerCols div small {
  display: inline-block;
  width: 73px;
}

.below-footer {
  padding: 8px 0;
}
.below-footer ul {
  margin: 0;
  padding: 0;
  text-align: right;
}
.below-footer ul li {
  display: inline-block;
}
.below-footer .col-xs-8 {
  color: #8a898d;
  vertical-align: middle;
}
.below-footer .col-xs-4 i {
  color: #c4525a;
  font-size: 18px;
  margin: 7px;
}
.below-footer .col-xs-4 i:hover {
  color: #222;
}
.footerCols div {
  margin: 10px 0 30px;
}
.footerCols div span {
  color: #222;
  display: block;
  font-weight: bold;
  margin: 0 0 9px;
}

.subPages h1 {
  margin: 7px 7px 20px;
}

.box {
  border: 1px solid #ececee;
  border-radius: 5px;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  margin: 10px;
  padding: 50px 0;
  text-align: center;
}
.box h3 {
  color: #111;
  font-size: 26px;
}
.box span {
  color: #f9dc1e;
  font-size: 37px;
  font-weight: lighter;
}
.box span small {
  color: #888888;
  font-size: 16px;
}
.box hr {
  width: 80%;
}
.box ul {
  padding: 0;
}
.box ul li {
  color: #888888;
  list-style: none;
  padding: 6px;
}

.callAction {
  background-color: #f9dc1e;
  margin: 40px 0;
  padding: 60px 0;
}
.callAction h1 {
  line-height: 50px;
}
.callAction p {
  font-size: 18px;
  line-height: 33px;
  margin: 0 0 20px;
}
.callAction button {
  background-color: #f9dc1e;
  border: 1px solid;
}

.sale {
  margin: 35px 0 0;
}

.sale2 {
  margin: 70px 0 80px;
}
.box2 {
  text-align: center;
}
.box2 i {
  font-size: 100px;
}
.box2 p {
  font-size: 19px;
  line-height: 32px;
  margin: 20px 0 0;
}

.services-panel {
  border-bottom: 1px solid #ececee;
}
.services .accordion-toggle {
  display: block;
  padding: 30px 0;
}
.services .accordion-toggle:after {
  font-family: FontAwesome;
  content: "\f107";
  float: left;
  color: #f9dc1e;
  margin: 0 20px 0 0;
}
.services .accordion-toggle.collapsed:after {
  content: "\f105";
}
.accordion-toggle {
  color: #666;
  font-size: 21px;
}
.accordion-toggle:hover,
.accordion-toggle:focus,
.accordion-toggle:active {
  color: #222;
  text-decoration: none;
}
.panel-collapse p {
  font-size: 17px;
  line-height: 35px;
  padding: 0 0 11px;
}

.parallax {
  /* background-attachment: fixed; */
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  /* opacity: 0.7;
  filter: alpha(opacity=70); */
  position: relative;
}
.about {
  background-image: url("/wp-content/uploads/haches-beach-min.jpg");
  min-height: 400px;
}
.service {
  /* background-image: url("/wp-content/themes/cs-ltd-theme/images/banner-2021-5-darker-min.jpg"); */
  background-image: url("http://www.haches.co/wp-content/uploads/ENVIRONMENT.jpeg");
  min-height: 400px;
}
.newspage {
  background-image: url("images/news-bg.jpg");
  min-height: 400px;
}
.caption {
  color: #000;
  margin: 110px 0 0;
  text-align: center;
}

.caption h1 {
  color: #fff;
  font-size: 60px;
  margin: 0 0 25px;
}
.caption span {
  color: #fff;
  font-size: 20px;
  line-height: 36px;
}

.mission {
  padding: 50px 0;
}
.mission p {
  font-size: 16px;
  line-height: 32px;
}

.staff span {
  color: #999;
}

.post-att {
  margin: 20px 0;
}
.post-att span {
  color: #888;
  font-size: 12px;
  font-style: italic;
  margin: 0 20px 0 0;
}
.post img {
  width: 100%;
}

.contact h2 {
  font-size: 34px;
  margin: 30px 0;
}
.contact ul {
  padding: 0;
}
.contact ul li {
  color: #979797;
  font-family: libre_franklinregular;
  font-size: 17px;
  list-style: none;
  padding: 30px 0 0;
}
.contact ul li span {
  color: #222;
  margin: 0 5px 0 0;
}
.contact ul li small {
  font-size: 12px;
  line-height: 28px;
  padding: 0 5px 0 10px;
}

.contact-details .address {
  color: #979797;
  display: block;
  font-size: 14px;
  padding: 9px 0 0 13px;
}

/* columns of same height styles */
.row-full-height {
  height: 100%;
}
.col-full-height {
  height: 100%;
  vertical-align: middle;
}
.row-same-height {
  display: table;
  width: 100%; /* fix overflow */
  table-layout: fixed;
}
.col-xs-height {
  display: table-cell;
  float: none !important;
}
.mission1 {
  width: 118px;
  height: 118px;
  background: url(http://www.haches.co/wp-content/uploads/haches-icon1.png) no-repeat;
  display: block;
  background-size: 100%;
  margin: 0 auto;
}
.mission2 {
  width: 186px;
  height: 118px;
  background: url(http://www.haches.co/wp-content/uploads/haches-icon2.png) no-repeat;
  display: block;
  background-size: 100%;
  margin: 25px auto 0;
}

@media (min-width: 768px) {
  .col-sm-height {
    display: table-cell;
    float: none !important;
  }
}

@media (min-width: 992px) {
  .col-md-height {
    display: table-cell;
    float: none !important;
  }
}

@media (min-width: 1200px) {
  .col-lg-height {
    display: table-cell;
    float: none !important;
  }
}

@media only screen and (max-width: 1200px) {
  .banner-buttons h1 {
    font-size: 43px;
  }
  .nivo-caption {
    font-size: 25px;
  }
}

@media only screen and (max-width: 1199px) {
  .home-gallery .col-sm-5 {
    width: 50%;
  }
  .home-contact .col-sm-10.col-sm-offset-1 {
    margin: 0;
    width: 100%;
  }
  footer .col-sm-5.col-sm-offset-1 {
    margin: 0 0 0 2%;
    width: 48%;
  }
}

@media only screen and (max-width: 991px) {
  .services-one .col-sm-6 {
    vertical-align: middle;
  }
  .services-two .col-sm-6 {
    margin: 0;
    vertical-align: middle;
    width: 50%;
  }
  .services-one .col-sm-6 img {
    height: auto;
    vertical-align: middle;
    width: 100%;
  }
  .services-two .col-sm-6 img {
    height: auto;
    vertical-align: middle;
    width: 100%;
  }
  .gallery-right a {
    padding: 2%;
    width: 46%;
  }
  .gallery-right a img {
    height: auto;
    width: 100%;
  }
  .home-contact .col-sm-10.col-sm-offset-1 .col-sm-6 {
    width: 100%;
  }
  .services-two h2 {
    font-size: 19px;
    line-height: 35px;
    margin: 0 0 15px;
  }
  footer .col-sm-6 {
    width: 100%;
  }
  footer .col-sm-5.col-sm-offset-1 {
    margin: 20px 0 0;
    width: 100%;
  }
}

@media only screen and (max-width: 767px) {
  .navbar-header button {
    position: absolute;
    right: 8px;
    top: -50px;
  }
  .nav.navbar-nav {
    margin: 0;
    width: 100%;
  }
  .navbar-default .navbar-nav > li > a {
    border-bottom: 1px solid #e7e7e7;
    padding: 15px 16px;
  }
  .header {
    padding: 35px 20px 0;
  }
  .navbar-collapse {
    margin: 25px 0 0;
  }
  .banner-buttons h1 {
    font-size: 30px;
  }
  .nivo-caption {
    font-size: 18px;
  }
  .col-xs-height {
    display: inline-block !important;
  }
  .services-one .col-sm-5,
  .services-two .col-sm-5 {
    width: 100%;
  }
  .services-one {
    padding: 20px 20px 30px;
  }
  .home-threecols .col-sm-4 {
    margin: 20px 0px 50px;
  }
  .home-gallery .col-sm-5 {
    width: 100%;
  }
  .home-gallery .row-same-height {
    margin: 0 3%;
    text-align: center;
    width: 94%;
  }
  .below-banner h1 {
    font-size: 26px;
    margin: 5px 0 25px;
  }
  .below-banner p {
    font-size: 15px;
    line-height: 31px;
  }
  .services-one h2,
  .services-two h2 {
    font-size: 21px;
    line-height: 30px;
  }
  .services-two {
    margin: 40px 0 65px;
  }
  .footer_about {
    margin: 0 0 45px;
  }
  .services-two .col-sm-6 {
    width: 100%;
  }
  .contact .col-sm-6.pull-right {
    width: 100%;
  }
}

@media only screen and (max-width: 550px) {
  .nivo-caption {
    bottom: -20px !important;
  }
}

@media only screen and (max-width: 475px) {
  .footerCols div {
    margin: 0 0 20px;
    width: 100%;
  }
}

@media only screen and (max-width: 430px) {
  #wpcf7-f21-p6-o1 input[type="text"],
  #wpcf7-f21-p6-o1 input[type="email"],
  #wpcf7-f21-p6-o1 textarea,
  #wpcf7-f37-p14-o1 input[type="text"],
  #wpcf7-f37-p14-o1 input[type="email"],
  #wpcf7-f37-p14-o1 textarea {
    width: 100%;
  }
}
