@import url(animate.css);
@import url(linecons.css);
@import url(//maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css);
@import url(//fonts.googleapis.com/css?family=Changa+One|Roboto:400,700);
/*========================================================
                      Main Styles
=========================================================*/
body {
  background: #fbfbfb;
  color: #787878;
  font: 400 14px/20px "Roboto", sans-serif;
  -webkit-text-size-adjust: none;
}

img {
  max-width: 100%;
  height: auto;
}

h1, h2, h3, h4, h5, h6 {
  color: #383838;
}

h1, h2, h4, h6 {
  text-transform: uppercase;
}

h1, h2, h3, h4 {
  font-family: "Changa One", cursive;
}

h1 {
  font-size: 100px;
  line-height: 80px;
}

h2 {
  font-size: 60px;
  line-height: 55px;
  letter-spacing: .6px;
  margin-left: -3px;
}
@media (min-width: 980px) and (max-width: 1199px) {
  h2 {
    font-size: 50px;
    line-height: 50px;
  }
}
@media (min-width: 768px) and (max-width: 979px) {
  h2 {
    font-size: 36px;
    line-height: 35px;
  }
}
@media (max-width: 767px) {
  h2 {
    font-size: 40px;
    line-height: 45px;
  }
}
@media (max-width: 479px) {
  h2 {
    font-size: 34px;
    line-height: 36px;
  }
}

h3 {
  font-size: 36px;
  line-height: 36px;
  letter-spacing: .9px;
}
@media (min-width: 768px) and (max-width: 979px) {
  h3 {
    font-size: 26px;
    line-height: 26px;
  }
}

h4 {
  font-size: 24px;
  line-height: 24px;
  letter-spacing: .6px;
}
h4 span {
  display: block;
  font-size: 100px;
  line-height: 96px;
  letter-spacing: -4px;
}
.grid_2 h4 {
  letter-spacing: 0;
}
@media (min-width: 980px) and (max-width: 1199px) {
  h4 {
    font-size: 20px;
    line-height: 20px;
    letter-spacing: 0;
  }
  h4 span {
    font-size: 80px;
    line-height: 70px;
  }
}

h5 {
  font-size: 24px;
  line-height: 28px;
  letter-spacing: 1.8px;
}

h6 {
  font-weight: 700;
  font-size: 14px;
}

p a:hover, .copyright a:hover {
  text-decoration: underline;
}

time {
  display: block;
}

a {
  font: inherit;
  color: inherit;
  text-decoration: none;
  -moz-transition: 0.3s all ease;
  -o-transition: 0.3s all ease;
  -webkit-transition: 0.3s all ease;
  transition: 0.3s all ease;
}
a:active {
  background: transparent;
}
a:focus {
  outline: none;
}

a[href^="tel:"] {
  color: inherit;
  text-decoration: none;
}

strong {
  font-weight: 700;
}

.fa {
  line-height: inherit;
}

[class*='fa-']:before {
  font-family: "FontAwesome";
}

.center {
  text-align: center;
}

.right {
  text-align: right;
}

.mg-add {
  margin-top: 5px;
}

.oh {
  overflow: hidden;
}

.page {
  overflow: hidden;
  min-height: 500px;
}
.lt-ie9 .page {
  min-width: 1200px;
}

.default {
  color: #787878;
}

.primary {
  color: #1dccc5;
}

.secondary {
  color: #383838;
}

/*========================================================
                      Main Layout
==========================================================*/
* + p {
  margin-top: 40px;
}

* + .booking-form {
  margin-top: 38px;
}

* + .link {
  margin-top: 25px;
}

h2 + h4 {
  margin-top: 24px;
}

h2 + p {
  margin-top: 26px;
}

h5 + p {
  margin-top: 25px;
}

p + p {
  margin-top: 20px;
}

.row + .row {
  margin-top: 63px;
}

/*=======================================================
                       Components
=========================================================*/
/*==================     Brand     ======================*/
.brand {
  text-transform: uppercase;
}
.brand_name {
  display: inline-block;
  overflow: hidden;
  margin-left: -5px;
}
.brand_slogan {
  color: #383838;
  font-weight: 700;
  display: inline-block;
}
.brand_name + .brand_slogan {
  margin-top: 40px;
  margin-left: 4px;
  letter-spacing: 1.4px;
}

/*==================  Marked List  ======================*/
.marked-list {
  font-family: "Changa One", cursive;
  font-size: 24px;
  line-height: 36px;
  text-transform: uppercase;
  letter-spacing: 1.2px;
}
.marked-list li {
  position: relative;
  padding-left: 0px;
}
.marked-list li:before {
  content: "\f0da";
  position: absolute;
  left: -37px;
  top: 2px;
  font-weight: 400;
  font-size: 37px;
  font-family: "FontAwesome";
  color: #383838;
  opacity: 0;
  -moz-transition: 0.3s all ease;
  -o-transition: 0.3s all ease;
  -webkit-transition: 0.3s all ease;
  transition: 0.3s all ease;
}
.lt-ie9 .marked-list li:before {
  display: none;
}
.marked-list li + li {
  margin-top: 12px;
}
.marked-list li:hover:before {
  left: -27px;
  opacity: 1;
}
.lt-ie9 .marked-list li:hover:before {
  display: block;
}
.marked-list a:hover {
  color: #787878;
}
@media (max-width: 479px) {
  .marked-list li:hover:before {
    left: -20px;
  }
}

/*==================     Icons     ======================*/
.flaticon-small56,
.flaticon-small57,
.flaticon-blockade,
.flaticon-user12 {
  display: inline-block;
  font-size: 50px;
  width: 60px;
  height: 56px;
  line-height: 56px;
  color: #383838;
}

.flaticon-small57 {
  font-size: 44px;
}

.flaticon-blockade {
  font-size: 44px;
}

.flaticon-user12 {
  font-size: 38px;
}

/*==================     Links     ======================*/
.link {
  display: inline-block;
  position: relative;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.4px;
  color: #1dccc5;
}
.link:before {
  position: absolute;
  left: 100%;
  top: 0;
  font-size: 18px;
  padding-left: 5px;
  -moz-transition: 0.3s all ease;
  -o-transition: 0.3s all ease;
  -webkit-transition: 0.3s all ease;
  transition: 0.3s all ease;
}
.link:hover:before {
  padding-left: 8px;
}

/*==================    Buttons    ======================*/
.btn {
  display: inline-block;
  padding: 14px 12px 14px 12px;
  line-height: 24px;
  color: #FFF;
  background: #1dccc5;
  font-weight: 400;
  font-size: 24px;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 1.8px;
}
.btn:hover {
  background: #383838;
}

/*==================     ToTop     ======================*/
.toTop {
  width: 40px;
  height: 40px;
  font-size: 24px;
  line-height: 40px;
  color: #fff;
  background: #383838;
  position: fixed;
  right: 66px;
  bottom: 180px;
  display: none;
  overflow: hidden;
  text-align: center;
  text-decoration: none;
  z-index: 20;
  border-radius: 4%;
  -moz-border-radius: 4%;
  -webkit-border-radius: 4%;
  -webkit-box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.15);
  -moz-box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.15);
  box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.15);
}
.toTop:hover {
  color: #fff;
  background: #1dccc5;
  text-decoration: none;
}

@media only screen and (max-width: 1399px) {
  .toTop {
    display: none !important;
  }
}
/*==================  GOOGLE MAP  ======================*/
.map {
  color: #383838;
}
.map_model {
  height: 370px;
}
.map_model img {
  max-width: none !important;
}
@media (max-width: 767px) {
  .map_model {
    height: 250px;
  }
}
@media (max-width: 479px) {
  .map_model {
    height: 200px;
  }
}
.map_locations {
  display: none;
}

/*==================     Subscribe Form     ======================*/
.subscribe-form {
  position: relative;
}
.subscribe-form label {
  display: block;
  position: relative;
  padding: 15px 10px 15px;
  width: 100%;
  background: white;
  border: none;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.subscribe-form input {
  outline: none;
  background-color: transparent;
  border: none;
  -webkit-appearance: none;
  border-radius: 0;
  vertical-align: baseline;
  box-shadow: none;
  color: #6c6c6c;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  font-size: 18px;
  line-height: 22px;
  height: 22px;
}
@media (max-width: 1199px) {
  .subscribe-form [class*='grid_'], .subscribe-form .row {
    float: none;
    width: 100%;
    margin: 0;
  }
  .subscribe-form [class*='grid_'] + [class*='grid_'] {
    margin-top: 20px !important;
  }
  .subscribe-form .btn {
    display: block;
  }
}

.error, .success {
  position: absolute;
  top: 2px;
  right: 5px;
  font-size: 10px;
  line-height: 14px;
  -moz-transition: 0.3s all ease;
  -o-transition: 0.3s all ease;
  -webkit-transition: 0.3s all ease;
  transition: 0.3s all ease;
}

label.invalid .error {
  height: 21px;
}

.error {
  overflow: hidden;
  height: 0;
  color: #f00;
}

.success {
  display: none;
  color: #0f0;
}

@media (max-width: 479px) {
  .subscribe-form label {
    width: 100%;
  }
}
/*========================================================
                     HEADER  Section
==========================================================*/
header {
	padding-top: 5px;
	padding-right: 0px;
	padding-left: 0px;
	padding-bottom: 20px;
	background: white;
}
@media (max-width: 767px) {
  header {
    text-align: center;
  }
}

.header_panel:before, .header_panel:after {
  display: table;
  content: "";
  line-height: 0;
}
.header_panel:after {
  clear: both;
}

/*========================================================
                     CONTENT  Styles
=========================================================*/
main {
  display: block;
  background: white;
}

/*==================      Well     ======================*/
.well {
  padding-top: 321px;
  padding-bottom: 104px;
}
@media (max-width: 479px) {
  .well {
    padding-top: 120px;
  }
}

.well2 {
  padding-top: 81px;
  padding-bottom: 545px;
}
@media (max-width: 979px) {
  .well2 {
    text-align: center;
    padding-bottom: 200px;
  }
  .well2 .row, .well2 [class*='grid_'] {
    float: none;
    width: 100%;
    margin: 0;
  }
  .well2 [class*='grid_'] + [class*='grid_'] {
    margin-top: 20px;
  }
}
@media (max-width: 767px) {
  .well2 {
    padding-bottom: 460px;
  }
}

.well3 {
  padding-top: 90px;
  padding-bottom: 78px;
}

.well4 {
  position: relative;
  top: -32px;
}
.well4 h2 {
  text-transform: none;
  letter-spacing: 0;
}

.well5 {
  padding-top: 41px;
  box-sizing: border-box;
  padding-right: 30px;
  padding-bottom: 89px;
}
@media (max-width: 479px) {
  .well5 {
    padding-bottom: 40px;
  }
}

.well6 {
  padding-top: 64px;
  padding-bottom: 97px;
}

/*==================  Backgrounds  ======================*/
.bg-image1 {
  position: relative;
  z-index: 0;
}
.bg-image1:before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 1050px;
  right: -30px;
  z-index: -1;
  background: url(../images/page-1_img01.jpg) no-repeat center center;
  -webkit-background-size: cover;
  background-size: cover;
}
.bg-image1 *:not(.btn) {
  color: #FFF;
}
@media (min-width: 768px) and (max-width: 1199px) {
  .bg-image1:before {
    right: -20px;
  }
}
@media (max-width: 767px) {
  .bg-image1:before {
    right: 50%;
    margin-right: -525px;
  }
}

.bg-image2 {
  position: relative;
  z-index: 0;
}
.bg-image2:before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: -50px;
  width: 1050px;
  z-index: -1;
  background: url(../images/page-1_img02.jpg) no-repeat right bottom;
}
@media (min-width: 768px) and (max-width: 979px) {
  .bg-image2:before {
    display: none;
  }
}
@media (max-width: 767px) {
  .bg-image2:before {
    right: 50%;
    margin-right: -460px;
  }
}

.bg-image3, .bg-image4 {
  position: relative;
  z-index: 0;
}
.bg-image3:before, .bg-image4:before {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  width: 1050px;
  z-index: -1;
}

.bg-image3:before {
  background: url(../images/page-1_img03.jpg) no-repeat right bottom;
}
@media (min-width: 980px) and (max-width: 1199px) {
  .bg-image3:before {
    right: -50px;
  }
}

.bg-image4:before {
  background: url(../images/page-1_img04.jpg) no-repeat right bottom;
}
@media (min-width: 980px) and (max-width: 1199px) {
  .bg-image4:before {
    right: -100px;
  }
}

.bg-primary {
  position: relative;
  z-index: 0;
}
.bg-primary *:not(.btn) {
  color: #FFF;
}
.bg-primary .btn {
  color: #1dccc5;
  background: #FFF;
}
.bg-primary .btn:hover {
  background: #383838;
  color: #FFF;
}
.bg-primary:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 1050px;
  background: #1dccc5;
  z-index: -1;
}
.bg-primary:first-child:before {
  left: auto;
  right: 0;
}
.bg-primary .marked-list li:before {
  color: #FFF;
}
.bg-primary .marked-list a:hover {
  color: #6EF1EC;
}
@media (max-width: 767px) {
  .bg-primary:before {
    left: 50%;
    margin-left: -525px;
  }
  .bg-primary:first-child:before {
    left: auto;
    right: 50%;
    margin-right: -525px;
  }
}

/*==================      Box      ======================*/
.box:before, .box:after {
  display: table;
  content: "";
  line-height: 0;
}
.box:after {
  clear: both;
}
.box_aside {
  float: left;
}
.box_cnt__no-flow {
  overflow: hidden;
}
@media (min-width: 768px) and (max-width: 979px) {
  .box {
    text-align: center;
  }
  .box_aside {
    float: none;
    margin-bottom: 15px;
  }
}

/*========================================================
                     FOOTER  Section
=========================================================*/
footer {
  padding: 88px 0 86px;
}
footer h6 {
  color: #C7C7C7;
}
footer .brand_slogan, footer .brand_name {
  color: #787878;
}
footer .brand_name + .brand_slogan {
  margin-top: 58px;
}
@media (max-width: 767px) {
  footer {
    text-align: center;
  }
  footer .brand_name, footer .brand_slogan {
    display: block;
    margin: 0;
  }
  footer .brand_name + .brand_slogan {
    margin-top: 5px;
    margin-left: 0;
  }
}
