html {
 scroll-behavior: smooth;
}
  
/* width */
::-webkit-scrollbar {
 width: 5px;
}

/* Track */
::-webkit-scrollbar-track {
background: #26282f;
 border-radius: 100px;
}

/* Handle */
::-webkit-scrollbar-thumb {
 background: #535866;
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
 background: #83889c;
}


/* Reset and Normnalize */
* {
     margin:0;
     padding:0;
     text-decoration:none;
     box-sizing:border-box;
     list-style:none;
     line-height:1.5;
     letter-spacing:.5px;
     font-size:100%;
     border:none;
     border-radius:0;
     outline:none;
     -webkit-tap-highlight-color: rgba(0,0,0,0);
     transition:0.3s;
     font-weight: 100;
   }

 /* Structure */
 body {
   font-family: 'Ubuntu', sans-serif;
   background-color: #f6f6f6;
   max-width: 1400px;
   margin: 0 auto;
 }

 h1,h2,h3,h4,h5,h6 {font-family:'Ubuntu', sans-serif;}
 h1,h2 {font-size:2em;margin-bottom:1em;}
 h3,h4 {font-size:1.5em;margin-bottom:.8em;}
 h5,h6 {font-size:1.25em;margin-bottom:.8em;}
 p {font-size: 1em;margin-bottom:.8em;line-height: 1.8em;}

 a,a:hover {
   color: #fff;
 }

 header {
   background-color: #ffffff;
   font-family: 'Ubuntu', sans-serif;
   position: relative;
   box-shadow: 0px 8px 10px -9px #26282f;
 }

 main {
   background-color: #fff;
 }

 footer {
   font-family:'Ubuntu', sans-serif;
   background-color: #1f2533;
   color: #ccd1dd;
 }

 /* Custom */

 .footer-nav {
  float: left;
  width: 70%;
}

.footer-nav a {
  color: #ccd1dd;
  padding:0 10px 12px 10px;
  line-height:44px;
  border-bottom: 2px solid #282e3a;
  font-size:14px;
}

.footer-nav a:hover,.footer-nav .active {
  color: #fff;
  border-color:#ffcc33;
}

.footer-about {
  float: right;
  width: 30%;
  text-align: right;
}

.footer-about p {
  font-size:14px;
}

.signal .ripple{
  border-radius: 50%;
  background-color: #fef1c7;
  position: absolute;
  transform: scale(0);
  animation: ripple 0.6s linear;
 }

 section {
   position: relative;
   margin-bottom: 100px;
 }

 section.dark {
   background-color:#1f2533;
   padding:60px;
   color: #fff;
 }

 section.dark .section-icon {
  height:120px;
  width: auto;
  right:20px;
  top:-60px;
}

.hero {
  padding: 0;
  background-color:#1f2533;
  color: #fff;
}

.cfx::after {
  content: "";
  clear: both;
  display: table;
}

#logo {
  width:auto;
  height:50px;
  fill:#1f2533;
  vertical-align: middle;
}
 

/* Form */

.reservation {
  background-color: #fff;
}

#regForm {
  background-color: #fff;
  min-width: 300px;
}

input, select {
  padding: 10px;
  width: 100%;
  font-size: 17px;
  border-bottom: 2px solid #fdb529;
}

/* Mark input boxes that gets an error on validation: */
input.invalid {
  background-color:#ffc4d1;
  border-color: #ff335f;
}

/* Hide all steps by default: */
.tab {
  display: none;
}

button {
  background-color: #ffcc33;
  color: #1f2533;
  border: none;
  padding: 10px 20px;
  font-size: 14px;
  cursor: pointer;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  margin:20px 0;
}

#prevBtn {
  background-color: #83889c;
  color: #fff;
}

/* Make circles that indicate the steps of the form: */
.step {
  height: 50px;
  width: 50px;
  margin: 0 14px;
  background-color: #ffcc33;
  color: #1f2533;
  border: none;
  border-radius: 50%;
  display: inline-block;
  padding: 11px;
  font-family: 'Ubuntu', sans-serif;
  font-weight: 600;
  font-size: 18px;
}

.step.active {
  background-color: #1f2533;
  color: #fff;
}

/* Mark the steps that are finished and valid: */
.step.finish {
  color: #fff;
  background-color: #83889c;
}

 @keyframes ripple{
  to{
    transform: scale(2.5);
    opacity: 0;
  }
 }



 @media only screen and (min-width: 768px) {

  header,footer {padding:2em 4em;}
  main {padding:8em 4em;}

   .topnav {
     overflow: hidden;
   }

   .topnav a {
     font-size: 16px;
     float: left;
     display: block;
     color: #1f1f1f;
     padding: 0 6px;
     margin: 0 8px;
     height: 58px;
     line-height: 58px;
     text-transform: uppercase;
   }

   .topnav a:not(:first-child):hover {
     border-bottom: 3px solid #ffcc33;
     padding-bottom: 5px;
     padding-top: 5px;
   }

   .topnav #toggler {
     display: none;
     padding:0;
     cursor: pointer;
   }

   #brand {
     margin-left:0;
     padding-left:0;
     padding-right: 50px;
   }
   
   header {
     background-image: url('slant.svg');
     background-repeat: no-repeat;
     background-position: 800px center;
     background-size: cover;
     font-weight: 600;
   }

   main section {
     padding-right:35%;
   }

   .footer-nav li {
     float: left;
     margin-right: 10px;
   }

   .section-icon {
    position: absolute;
    height:240px;
    width:auto;
    top:-20px;
    right: 0;
  }

  .hero-image, .hero-title {
    height:280px;
  }

  .hero-image {
    width:30%;
    float:left;
    overflow:hidden;
    text-align: center;
  }
  
  .hero-image img{
    width:auto;
    height:100%;
  }
  
  .hero-image p {
    padding-top:70px;
  }

  .hero-image a {
    font-size:18px;
    display: block;
    padding:5px 0;
    text-align: right;
  }
  
  .hero-title {
    padding:40px;
    width:70%;
    float:right;
    overflow:hidden;
    background-position: center;
    background-size: cover;
  }
  
  .hero-title h2 {
    width:70%;
    font-size: 1.4em;
  }
  
  .hero-title h3 {
    width:70%;
    font-size: 1.1em;
  }

  .photogrid {
    line-height:0;
    padding:0;
  }

  .photogrid img {
    width:33.333%;
    height:auto;
  }

 }

 @media only screen and (max-width: 768px) {

  header,main,footer {padding:2em;}

   .topnav {
     overflow: hidden;
   }

   .topnav a {
     font-size: 25px;
     float: left;
     display: block;
     color: #1f1f1f;
   }

   .topnav a:not(:first-child) {display: none;}

   .topnav #toggler {
     float: right;
     display: block;
     margin-top: 5px;
     cursor: pointer;
   }

   .topnav.responsive {position: relative;}

   .topnav.responsive #toggler {
     position: absolute;
     right: 0;
     top: 0;
   }

   .topnav.responsive a {
     float: none;
     display: block;
     text-align: left;
   }

   .topnav.responsive a:not(:first-child):hover {
     margin-left: .3em;
   }

   .topnav.responsive a:not(:first-child){
     padding: .5em 0;
     border-bottom: 1px solid #dadfeb;
   }

   .topnav.responsive a:last-of-type {
     border: none;
   }

   .bar1, .bar2, .bar3 {
     width: 35px;
     height: 5px;
     background-color: #fff;
     margin: 6px 0;
   }

   .change .bar1 {
     -webkit-transform: rotate(-45deg) translate(-9px, 6px);
     transform: rotate(-45deg) translate(-9px, 6px);
     background-color: #1f2533;
   }

   .change .bar2 {opacity: 0;}

   .change .bar3 {
     -webkit-transform: rotate(45deg) translate(-8px, -8px);
     transform: rotate(45deg) translate(-8px, -8px);
     background-color: #1f2533;
   }

   header {
     background-image: url('./slant.svg');
     background-repeat: no-repeat;
     background-size: cover;
     background-position: 120px center;
   }

   main section {
    width:100%;
  }

  .section-icon {
    display: block;
    margin: 0 auto;
    margin-bottom:30px;
    height:120px;
    width: auto;
  }

   .footer-about,.footer-nav {
    width: 100%;
    float: none;
    text-align: left;
    margin-bottom: 30px;
  }
  
  .footer-nav a {
    display: block;
    padding:8px;
    line-height:30px;
  }
  
  .hero-image, .hero-title {
    width: 100%;
    overflow: hidden;
  }
 
  .hero-image img {
    height: auto;
    width:100%;
    margin:0;
    padding:0;
  }

  .hero-image p {
    padding-top:20px;
  }

  .hero-image a {
    font-size:18px;
    display: block;
    padding:5px 0;
    text-align: left;
  }

  .hero-image {
    text-align: center;
    height:180px;
  }

  .hero-title {
    padding:40px;
    background-position: center;
    background-size: cover;
  }

  .empty {
    height:5px;
    padding:0;
    margin:0;
    background-image:none!important;
    background-color: #FDB529;
  }
  
  .photogrid {
    line-height:0;
    padding:0;
  }

  .photogrid img {
    width:50%;
    height:auto;
  }


 }