/*
* General styles
*/
body {
    font-family: 'Kreon', serif;
    line-height: 1.55;
}
.section {
  margin-top: 80px;
}
.row-no-padding > [class*="col-"] {
    padding-left: 0 !important;
    padding-right: 0 !important;
}
hr {
  border-color: #f35e9b;
  border-width: 2px;
  margin: 0;
}
textarea,
input[type="text"],
input[type="button"],
input[type="submit"] {
   -webkit-border-radius: 0;
      -moz-border-radius: 0;
           border-radius: 0;
}
img {
  max-width: 100%;
}

/*
* Typography
*/
h1,h2, h3, h4, h5, .navbar, .btn-primary, .nav-pills, .main-header__phone  {
    font-family: 'Just Another Hand', cursive;
    font-weight: 400;
}
h2 {
  font-size: 60px;
  color: #f35e9b;
  margin-bottom: 15px;
}
h2.headline-styled:before, h2.headline-styled:after {
  content: "";
  background: url('../img/headline_elements.png') no-repeat;
  width: 55px;
  height: 29px;
  display: inline-block;
  margin: 0 10px;
}
h2.headline-styled:after {
  background-position: center right;
}
h2 a {
  color: #f35e9b;
  position: relative;
}
h2 a:after {
  background: url('../img/headline_underline.png');
  content: "";
  height: 5px;
  width: 100%;
  position: absolute;
  bottom: 5px;
  left: 0;
  -moz-background-size: 100% auto;
    -o-background-size: 100% auto;
       background-size: 100% auto;
  -webkit-transition: 0.3s;
     -moz-transition: 0.3s;
       -o-transition: 0.3s;
          transition: 0.3s;
}
h2 a:hover, h2 a:focus {
  text-decoration: none;
  color: #f35e9b;
}
h2 a:hover:after, h2 a:focus:after {
  opacity: 0;
}
h4 {
  color: #3f393b;
  font-size: 35px;
}
.text-white {
  font-size: 16px;
  color: #fff;
  font-weight: 300;
}
.text-white h4 {
  color: #f35e9b;
}
.text-light {
  color: #fcedc5;
  font-size: 17px;
  background: #3f393b;
  padding: 30px 55px 30px 40px;
}

/*
* Preloader
*/
.preloader {
  position:fixed;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background: #fcedc5;
  -moz-background-size: cover;
    -o-background-size: cover;
       background-size: cover;
  height: 100%;
  z-index:99;
}
.preloader .loader {
  width:50px;
  height:30px;
  position:fixed;
  left:50%;
  top:50%;
  margin:-25px 0 0 -15px;
}
.spinner {
  margin: 0px auto;
  width: 50px;
  height: 30px;
  text-align: center;
  font-size: 10px;
}
.spinner > div {
  background-color: #fff;
  height: 100%;
  width: 6px;
  display: inline-block;
  -webkit-animation: stretchdelay 1.2s infinite ease-in-out;
  -moz-animation: stretchdelay 1.2s infinite ease-in-out;
    -o-animation: stretchdelay 1.2s infinite ease-in-out;
       animation: stretchdelay 1.2s infinite ease-in-out;
}
.spinner .rect2 {
  -webkit-animation-delay: -1.1s;
  -moz-animation-delay: -1.1s;
    -o-animation-delay: -1.1s;
       animation-delay: -1.1s;
}
.spinner .rect3 {
  -webkit-animation-delay: -1.0s;
  -moz-animation-delay: -1.0s;
    -o-animation-delay: -1.0s;
       animation-delay: -1.0s;
}
.spinner .rect4 {
  -webkit-animation-delay: -0.9s;
  -moz-animation-delay: -0.9s;
    -o-animation-delay: -0.9s;
       animation-delay: -0.9s;
}
.spinner .rect5 {
  -webkit-animation-delay: -0.8s;
  -moz-animation-delay: -0.8s;
    -o-animation-delay: -0.8s;
       animation-delay: -0.8s;
}
@-webkit-keyframes stretchdelay {
  0%, 40%, 100% { -webkit-transform: scaleY(0.4) }
  20% { -webkit-transform: scaleY(1.0) }
}
@-moz-keyframes stretchdelay {
  0%, 40%, 100% {
    -moz-transform: scaleY(0.4);
         transform: scaleY(0.4);
    -webkit-transform: scaleY(0.4);
  }  20% {
    -moz-transform: scaleY(1.0);
         transform: scaleY(1.0);
    -webkit-transform: scaleY(1.0);
  }
}
@-o-keyframes stretchdelay {
  0%, 40%, 100% {
    -o-transform: scaleY(0.4);
       transform: scaleY(0.4);
    -webkit-transform: scaleY(0.4);
  }  20% {
    -o-transform: scaleY(1.0);
       transform: scaleY(1.0);
    -webkit-transform: scaleY(1.0);
  }
}
@keyframes stretchdelay {
  0%, 40%, 100% {
    -moz-transform: scaleY(0.4);
      -o-transform: scaleY(0.4);
         transform: scaleY(0.4);
    -webkit-transform: scaleY(0.4);
  }  20% {
    -moz-transform: scaleY(1.0);
      -o-transform: scaleY(1.0);
         transform: scaleY(1.0);
    -webkit-transform: scaleY(1.0);
  }
}

/*
* Elements
*/
.btn-primary {
  font-size: 40px;
  background: #f35e9b;
  -webkit-border-radius: 0;
     -moz-border-radius: 0;
          border-radius: 0;
  border: none;
  height: 54px;
  padding: 4px 25px;
  outline: none;
}
.btn-primary:hover, .btn-primary:focus, .btn-primary:active,.btn-primary:active:focus, .btn-primary:active:hover {
  background: #3f393b;
  outline: none;
}
.btn-small-rounded {
  font-size: 25px;
  letter-spacing: 3px;
  -webkit-border-radius: 15px;
     -moz-border-radius: 15px;
          border-radius: 15px;
  height: auto;
}
.b-elements {
  position: relative;
}
.b-elements:before, .b-elements:after {
  content: "";
  position: absolute;
  top: 0;
  width: 500px;
  height: 200px;
  z-index: -1;
}
.b-elements:before  {
  background: url('../img/our-specals_bg-left.png') no-repeat left top;
  left: 0;
}
.b-elements:after {
  background: url('../img/our-specals_bg-right.png') no-repeat right top;
  right: 0;
}

/*
* Slider
*/
.slider {
  position: relative;
}
.slider .controls span {
    width: 14px;
    height: 34px;
    position: absolute;
    top: 125px;
    background: red;
    z-index: 5;
    background: url('../img/our-specials_arrows.png');
    cursor: pointer;
}
.slider .controls span.prev {
  left: -70px;
  background-position: 0 0;
}
.slider .controls span.prev:hover {
  background-position: 0 -34px;
}
.slider .controls span.next {
  right: -70px;
  background-position: -14px 0;
}
.slider .controls span.next:hover {
  background-position: -14px -34px;
}
.slider ul {
  list-style-type: none;
}

/*
* Navbar
*/
.navbar-brand, .navbar-brand:hover, .navbar-brand:focus  {
  color: #3e393a;
}
.navbar-brand {
    float: none;
    display: inline-block;
    height: auto;
    padding: 0;
    margin-top: 55px;
    position: relative;
}
.main-header .navbar-brand img {
    display: inline-block;
    max-width: 100%;
}
.navbar-brand .fitText {
    padding: 13% 20% 10%;
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    font-size: 113px;
}
.navbar-nav {
    margin: 0;
    width: 100%;
}
.navbar li {
  display: inline-block;
  float: none;
}
.navbar li a, .navbar li a:focus {
  background: none;
  color: #fff;
  font-size: 32px;
  text-transform: uppercase;
  line-height: 1;
  padding: 22px 10px 11px 12px;
}
.navbar li a:hover {
  background: none;
  color: #3f393b;
}
.navbar-toggle {
  border: 2px #f35e9b solid;
  margin: 0;
}
.navbar-toggle .icon-bar {
  width: 36px;
  height: 4px;
  background: #f35e9b;
}
.navbar-toggle .icon-bar+.icon-bar {
  margin-top: 7px;
}
.navbar-inverse {
  border: 0;
  background: transparent;
}
.navbar-inverse .navbar-nav>li>a {
  color: #fff;
}
.navbar-inverse .navbar-nav>li>a:hover {
  color: #f35e9b;
}

/*
* Social Buttons
*/
.social-buttons {
  margin: 0;
  padding: 0;
}
.social-buttons li {
  display: inline-block;
  float: none;
}
.social-buttons li a {
  display: inline-block;
  margin-right: 15px;
}
.social-buttons li a svg {
  height: 30px;
  max-width: 40px;
}
.social-buttons li a path {
  -webkit-transition: 0.3s;
     -moz-transition: 0.3s;
       -o-transition: 0.3s;
          transition: 0.3s;
}
.social-buttons li a:hover path {
  fill: #f35e9b;
}

/*
* Header section
*/
.main-header {
    background: url('../img/header_bg.jpg') no-repeat center center;
    -moz-background-size: cover;
      -o-background-size: cover;
         background-size: cover;
    padding-top: 70px;
    padding-bottom: 120px;
    position: relative;
}
.main-header:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  opacity: 0.4;
  background: #3f393b; /* Old browsers */
  background: -moz-linear-gradient(left,  #3f393b 0%, #3e383b 100%); /* FF3.6-15 */
  background: -webkit-linear-gradient(left,  #3f393b 0%,#3e383b 100%); /* Chrome10-25,Safari5.1-6 */
  background: -webkit-gradient(linear, left top, right top, from(#3f393b), to(#3e383b));
  background: -webkit-linear-gradient(left, #3f393b 0%, #3e383b 100%);
  background: -o-linear-gradient(left, #3f393b 0%, #3e383b 100%);
  background: linear-gradient(to right,  #3f393b 0%,#3e383b 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#3f393b', endColorstr='#3e383b',GradientType=1 ); /* IE6-9 */
}
.main-header .container {
  position: relative;
  z-index: 3;
}
.main-header .navbar-menu {
    background: #f35e9b;
    -webkit-border-radius: 10px;
       -moz-border-radius: 10px;
            border-radius: 10px;
    position: relative;
}
.main-header .navbar-menu:before {
  content: "";
  background: url('../img/menu-el_left.png');
  width: 49px;
  height: 64px;
  position: absolute;
  left: -55px;
  bottom: -27px;
}
.main-header .navbar-menu:after {
  content: "";
  background: url('../img/menu-el_right.png');
  width: 32px;
  height: 44px;
  position: absolute;
  right: -34px;
  top: -22px;
}
.main-header .main-header__phone {
    text-align: right;
    color: #fff;
    font-size: 50px;
    display: inline-block;
}
.main-header .main-header__phone:hover,
.main-header .main-header__phone:focus {
  text-decoration: none;
  cursor: default;
}
.main-header .main-header__scroll {
  background: url('../img/header_scroll-icon.png') no-repeat center center;
  width: 116px;
  height: 39px;
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-left: -58px;
  z-index: 3;
  cursor: pointer;
}

/*
* About Us section
*/
.about-us__inner {
  -webkit-border-radius: 15px;
     -moz-border-radius: 15px;
          border-radius: 15px;
  overflow: hidden;
}
.about-us .about-us__photo {
  width: 100%;
  -moz-background-size: cover;
    -o-background-size: cover;
       background-size: cover;
  background-position: center center;
  min-height: 400px;
}

/*
* Our specials
*/
.our-specials {
  font-size: 20px;
  font-weight: 300;
  color: #21262a;
  margin-top: 60px;
  padding-top: 20px;
}
.our-specials__item .image {
  display: inline-block;
  height: 280px;
  -webkit-border-radius: 10px;
     -moz-border-radius: 10px;
          border-radius: 10px;
  overflow: hidden;
  width: 100%;
  margin-bottom: 15px;
}
.our-specials__item .image img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.our-specials__item .our-specials__item-name {
  margin-bottom: 0;
}
.our-specials__item hr {
  width: 85px;
  margin: 10px auto 5px;
}
.our-specials__item .price {
  font-size: 35px;
}
.our-specials__item .price .currency {
  font-size: 18px;
}
.our-specials__item .price sup {
  font-weight: 300;
  font-size: 18px;
}

/*
* Menu
*/
.menu {
  background: url('../img/menu_bg.jpg') no-repeat center top;
  -moz-background-size: cover;
    -o-background-size: cover;
       background-size: cover;
  padding: 65px 0;
  position: relative;
}
.menu:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 2;
  opacity: 0.4;
  background: #352e2c; /* Old browsers */
  background: -moz-linear-gradient(left,  #352e2c 0%, #4b3735 38%, #4b3735 100%); /* FF3.6-15 */
  background: -webkit-linear-gradient(left,  #352e2c 0%,#4b3735 38%,#4b3735 100%); /* Chrome10-25,Safari5.1-6 */
  background: -webkit-gradient(linear, left top, right top, from(#352e2c), color-stop(38%, #4b3735), to(#4b3735));
  background: -webkit-linear-gradient(left, #352e2c 0%, #4b3735 38%, #4b3735 100%);
  background: -o-linear-gradient(left, #352e2c 0%, #4b3735 38%, #4b3735 100%);
  background: linear-gradient(to right,  #352e2c 0%,#4b3735 38%,#4b3735 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#352e2c', endColorstr='#4b3735',GradientType=1 ); /* IE6-9 */
}
.menu > * {
  position: relative;
  z-index: 2;
}
.menu .content {
  background: #ffffff;
  -webkit-border-bottom-left-radius: 15px;
     -moz-border-radius-bottomleft: 15px;
          border-bottom-left-radius: 15px;
  -webkit-border-bottom-right-radius: 15px;
     -moz-border-radius-bottomright: 15px;
          border-bottom-right-radius: 15px;
  overflow: hidden;
}
.menu .nav-pills {
  background: #3f393b;
  margin: 0;
  padding: 0;
  width: 100%;
  display: table;
}
.menu .nav-pills li {
  display: table-cell;
  float: none;
  text-align: center;
}
.menu .nav-pills li a {
  background: #3f393b;
  font-size: 35px;
  color: #fff;
  display: block;
  padding: 15px 30px 11px;
  -webkit-border-radius: 0;
     -moz-border-radius: 0;
          border-radius: 0;
}
.menu .nav-pills li a:hover, .menu .nav-pills li a:focus, .menu .nav-pills .active a {
  background: #f35e9b;
  text-decoration: none;
}
.menu .nav-pills .active a {
  position: relative;
}
.menu .nav-pills .active a:after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 14px 0 14px;
  border-color: #f35e9b transparent transparent transparent;
  bottom: -10px;
  left: 50%;
  margin-left: -7px;
}
.menu .nav-pills>li+li {
  margin: 0;
}
.menu .tab-pane {
  padding: 40px;
}
.menu .item {
  border: 1px #ebebeb solid;
  color: #636057;
  margin-bottom: 30px;
}
.menu .item .photo {
  width: 100%;
  height: 100px;
}
.menu .item .photo img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.menu .item .info {
  padding: 0;
  display: table;
  width: 100%;
}
.menu .item .info .info_inner {
  display: table-cell;
  vertical-align: middle;
}
.menu .item .info h4 {
  margin: 0;
  color: #3f393b;
  font-size: 20px;
  font-family: 'Kreon';
}
.menu .item .info  p {
  margin: 0;
}
.menu .item .info .price {
  font-size: 20px;
}
.menu .item .info .price .currency {
  font-size: 15px;
}

/*
* Events
*/
.events__event-item {
  display: inline-block;
  background-position: center center;
  -moz-background-size: cover;
    -o-background-size: cover;
       background-size: cover;
  width: 100%;
  height: 500px;
  position: relative;
  -webkit-border-radius: 10px;
     -moz-border-radius: 10px;
          border-radius: 10px;
  overflow: hidden;
}
.events__event-item .date {
    position: absolute;
    background: url(../img/events_date-mask.png) no-repeat;
    width: 152px;
    height: 48px;
    font-size: 20px;
    color: #fff;
    padding: 4px 33px;
    left: 50%;
    margin-left: -76px;
}
.events__event-item .content {
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 30px 40px;
  background: RGBA(63, 57, 59, 0.9);
  color: #fff;
  font-size: 16px;
}
.events__event-item h4 {
  color: #f35e9b;
  margin-top: 0;
}
.events__event-item p:last-child {
  margin-bottom: 0;
}
.events .controls span {
  top: 50%;
  margin-top: -17px;
}

/*
* Follow us
*/
.instafeed .item {
  display: inline-block;
  margin: 6px;
  -webkit-border-radius: 3px;
     -moz-border-radius: 3px;
          border-radius: 3px;
  overflow: hidden;
}


/*
* Contacts
*/
.contacts .content {
  padding: 50px 0;
  position: relative;
}
.contacts .mapscroll-wrap {
    position: absolute !important;
    width: 100% !important;
    height: 100% !important;
    z-index: 1;
}
.contacts iframe {
  width: 100%;
  height: 100%;
}
.contacts .map__info-block {
  -webkit-border-radius: 10px;
     -moz-border-radius: 10px;
          border-radius: 10px;
  overflow: hidden;
  position: relative;
  z-index: 4;
}
.contacts .map__info-block .image {
  text-align: center;
  -moz-background-size: cover;
    -o-background-size: cover;
       background-size: cover;
  background-position: center center;
  color: #fff;
  line-height: 1;
  padding: 35px;
  position: relative;
  overflow: hidden;
}
.contacts .map__info-block .image:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: RGBA(81, 76, 78, 0.05);
  z-index: 2;
}
.contacts .map__info-block .image > * {
  position: relative;
  z-index: 3;
}
.contacts .map__info-block .image h3 {
  font-size: 62px;
  margin: 0;
}
.contacts .map__info-block .image .welcome {
  font-size: 30px;
  font-weight: bold;
}
.contacts .map__info-block .info {
  font-size: 23px;
  background: #fefef9;
  padding: 45px;
}
.contacts .map__info-block .info .headline {
  font-size: 18px;
  display: inline-block;
  margin-top: 10px;
}

/*
* Footer
*/
.footer .subscribe {
  font-size: 22px;
  line-height: 26px;
  padding: 70px 0 200px;
  background: url('../img//footer_bg.jpg') no-repeat center center;
  -moz-background-size: cover;
    -o-background-size: cover;
       background-size: cover;
  position: relative;
  color: #fff;
  font-weight: 300;
}
.footer .subscribe .subscribe__headline {
  margin-bottom: 0;
}
.footer .subscribe:after {
  content: "";
  position: absolute;
  z-index: 2;
  width: 100%;
  height: 100%;
  background: RGBA(63, 57, 59, 0.6);
  top: 0;
  left: 0;
}
.subscribe * {
  position: relative;
  z-index: 3;
}
.subscribe__form .form-inner {
  width: 100%;
  position: relative;
  -webkit-border-radius: 10px;
     -moz-border-radius: 10px;
          border-radius: 10px;
  overflow: hidden;
  margin-top: 30px;
}
.subscribe__form .input {
  width: 100%;
  border: 0;
  outline: 0;
  color: #000;
  padding: 16px 180px 13px 20px;
  height: 55px;
}
.subscribe__form button {
  position: absolute;
  right: 0;
  top: 0;
  height: 55px;
}
.subscribe__form .form-group {
  width: 100%;
  margin: 0;
}
.footer__info {
  position: relative;
  background: #3f393b;
  padding: 70px 0 30px 0;
  color: #fff;
}
.footer__info .circle {
    height: 60px;
    position: absolute;
    width: 100%;
    top: -60px;
    overflow: hidden;
}
.footer__info .circle:before {
  content: "";
  position: absolute;
  width: 110%;
  height: 120px;
  background: #3f393b;
  left: -5%;
  -webkit-border-radius: 100%;
     -moz-border-radius: 100%;
          border-radius: 100%;
  top: 0;
  z-index: 2;
}
.footer__info > * {
  position: relative;
  z-index: 3;
}
.footer__info .navbar-brand {
  position: absolute;
  width: 340px;
  top: -150px;
  margin: 0;
  left: 50%;
  margin-left: -170px;
}
.footer__info .copyright {
  font-size: 14px;
}
.footer__info.b-elements:before, .footer__info.b-elements:after {
  opacity: 0.1;
  z-index: 0;
}

/*
Tablet
 */
@media (max-width: 990px) {
  /* Utils */
  .clearfix-sm {
    clear: both;
  }
  /* Elemnts */
  .b-elements:before, .b-elements:after {
    display: none;
  }
  .text-light {
    padding: 30px;
  }
  .social-buttons {
    text-align: center;
  }
  /* Header */
  .main-header .main-header__phone {
    text-align: center;
    width: 100%;
  }
  /* Footer */
  .footer .info .background {
    opacity: 0.1;
  }
}

/*
Navbar customization
*/
@media (max-width: 767px) {
  .main-header .col-sm-12 {
    position: static;
  }
  .main-header .social-buttons {
    text-align: left;
  }
  .navbar-collapse {
    position: absolute;
    width: 100%;
    z-index: 5;
    padding: 0;
    left: 0;
    margin-top: 10px;
  }
  .navbar {
    position: static;
  }
  .main-header .navbar-nav {
    -webkit-border-radius: 0;
       -moz-border-radius: 0;
            border-radius: 0;
  }
  .navbar li {
    display: block;
    width: 100%;
  }
  .navbar li a {
    border-bottom: 1px #fcedc5 solid;
  }
  .navbar li:last-child a {
    border-bottom: 0;
  }
  .navbar.navbar-inverse li a {
    border: none;
    font-size: 22px;
    padding: 10px;
  }
}

/*
Mobile
 */
@media (max-width: 480px) {
  /* Typography */
  h2 {
    font-size: 45px;
  }
  /* Header fixes */
  .main-header {
    padding-top: 50px;
  }
  /* Menu fixes */
  .menu .nav-pills li {
    display: inline-block;
    width: 100%;
    border-bottom: 1px #fcedc5 solid;
  }
  .menu .nav-pills li.active {
    border-color: transparent;
  }
  .menu .nav-pills li a {
    font-size: 25px;
    padding: 10px 30px 6px;
  }
  .menu .nav-pills .active a:after {
    display: none;
  }
  .menu .tab-pane {
    padding: 0;
  }
  .menu .item {
    border: 0;
    border-bottom: 1px #ebebeb solid;
    margin-bottom: 0;
  }
  .menu .item:last-child {
    border-bottom: 0;
  }
  .menu .item .info .info_inner {
    padding: 10px 10px 10px 0;
  }
  .menu .item .info .price {
    width: 100%;
    text-align: right;
    display: inline-block;
  }
  /* Contacts fixes */
  .contacts .mapscroll-wrap {
    position: relative !important;
    height: 300px !important;
  }
  .contacts .info-block {
    -webkit-border-radius: 0;
       -moz-border-radius: 0;
            border-radius: 0;
  }
  .contacts .info-block .info {
    background: #fff;
  }
  .contacts .content {
    padding: 0;
  }
  .contacts .map__info-block {
    margin-bottom: 10px;
  }
  /* Footer */
  .subscribe__form .input {
    text-align: center;
    padding: 10px 20px;
  }
  .subscribe__form button {
    position: static;
    width: 100%;
    top: 0;
  }
  h2.headline-styled:before, h2.headline-styled:after {
    display: none;
  }
}