* { box-sizing: border-box; }

body {
  background-color: #EAEAEA;
  color: #666666;
  font-family: Arial, Helvetica, sans-serif;
}

header {
  background-color: #002171;
  color: #FFFFFF;
  text-align: center;
}
header a {
  text-decoration: none;
}
  header a:link{
    text-decoration: none;
    color: #FFFFFF;
}
header a:visited{
  color: #FFFFFF;
}
header a:hover{
  color: lightblue;
}

nav {
  font-weight: bold;
  padding: 0;
  font-size: 120%;
  text-align: center;
}

nav li {
  border-bottom: 1px solid darkblue;
}

nav ul {
  list-style-type: none;
  font-size: 1.2em;
  padding: 0px;
  margin: 0px;
}

nav a{
  text-decoration: none;
}
nav a:link{
  color: #5C7FA3;
}
nav a:visited{
  color: #344873
}
nav a:hover{
  color: #A52A2A;
}


main {
  background-color: #ffffff;
  padding: 1px 20px 20px 30px;
  overflow: auto;
  display: block;
}

h1 {
  font-family: Georgia, "Times New Roman", sans-serif;
  margin-top: 0px;
  margin-bottom: 0px;
  padding-top: 0.5em;
  padding-bottom: 0.5em;
  letter-spacing: 0.25em;
}

h2 {
  font-family: Georgia, "Times New Roman", sans-serif;
  color:#1976D2;
  text-shadow: 1px 1px 1px #CCCCCC;
}

h3 {
  font-family: Georgia, "Times New Roman", sans-serif;
  color: #000033;
}

main ul {
  list-style-image: url(./marker.gif);
}

dt {
  color: #002171;
  font-weight: bold;
}

form { display: flex;
 flex-flow: column nowrap; }
 input, textarea { margin-bottom: .5em; }


footer {
  background-color: #FFFFFF;
  font-size: 75%;
  font-style: italic;
  text-align: center;
  font-weight: bold;
  padding: 2em;
  margin-right: auto;
  width: 100%;
}

.resort {
  color: #1976D2;
  font-weight: bold;
}

#contact {
  font-size: 90%;
}

table {
    margin: auto;
    border: 2px solid #3399CC;
    border-collapse: collapse;
  }
  tr:nth-of-type(odd) {
    background-color: #F5FAFC;
  }
  th{
    border: 2px solid #3399CC;
    padding: 0.5em;
  }
  td {
    border: 2px solid #3399CC;
    padding: 0.5em;
    text-align: center;
  }

  footer {
    grid-row: auto;
    grid-column: 1 / 5;
  }

 .text {
   text-align: left;
 }

#wrapper {
  background-color: #90C7E3;
  border: 1px solid #000033;
  background-image: linear-gradient(to bottom, #ffffff, #90C7E3);
}

#homehero {
  height: 300px;
  background-image: url(./coast2.jpg);
  background-size: 100% 100%;
  background-repeat: no-repeat;
}

#yurthero {
  height: 300px;
  background-image: url(./yurt.jpg);
  background-size: 100% 100%;
  background-repeat: no-repeat;
}

#trailhero {
  height: 300px;
  background-image: url(./trail.jpg);
  background-size: 100% 100%;
  background-repeat: no-repeat;
}

@media (min-width: 600px) {
  nav ul {
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-around;
  }
  nav li {
    border-bottom: none;
  }

  section {
    padding-left: 2em;
    padding-right: 2em;
  }

  .content main {
    display: grid;
   grid-template-rows: auto;
   grid-template-columns: 1fr 1fr 1fr; }

  h2 {
  grid-row: 1 / 2;
  grid-column: 1 / 5;
  }

  section {
    grid-row: 2 / 3;
    grid-column: auto;
  }

  #special {
    grid-row: auto;
    grid-column: 1 / 5;
  }

}

@media (min-width: 1024px) {
  nav ul {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    padding-top: 1em;
  }
  nav ul li {
    text-align: left;
    padding-left: 1em;
  }

  form {
   display: grid;
   grid-template-rows: auto;
   grid-template-columns: 6em 1fr;
   grid-gap: 1em;
   gap: 1em;
   font-family: Arial, sans-serif;
   width: 60%;
   min-width: 20em;
   padding: 2em;
 }

  #wrapper {
     margin: auto;
     width: 80%;
     border: 1px solid darkblue;
     box-shadow: 3px 3px 3px;
     display: grid;
     grid-template-columns:
    180px auto auto;
     grid-template-rows: auto
    auto auto auto; }
    
    header { grid-row: 1 / 2; grid-column: 1 / 3; }
     nav { grid-row: 2 / 5; grid-column: 1 / 2; }
     div { grid-row: 2 /3; grid-column: 2 / 3; }
     main { grid-row: 3 / 4; grid-column: 2 / 3; }
     footer { grid-row: 4 / 5; grid-column: 2 / 3;}
     }
