@import url("https://fonts.googleapis.com/css2?family=Mouse+Memoirs&family=Open+Sans:ital,wght@0,400;0,700;1,400&display=swap");
#wrapper,
body,
footer,
html,
main,
nav {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  overflow: auto;
  height: 100%;
  margin: 0;
  padding: 0;
  font-size: 16px;
  margin-right: 0;
  width: 100vw;
  overflow-x: hidden;
}

body {
  background-color: #BBE5FF;
  font-family: "Open Sans", sans-serif;
  font-weight: normal;
  text-decoration: none;
  height: 100%;
  color: #000000;
  margin: 0;
  padding: 0;
}

a:link {
  text-decoration: none;
}

footer a:link,
main a:link {
  text-decoration: underline;
  color: #0000ff;
}

footer a:hover,
main a:hover {
  text-decoration: none;
  color: #0000aa;
}

footer a:visited,
main a:visited {
  text-decoration: underline;
  color: #000000;
}

footer a:active,
main a:active {
  text-decoration: none;
  color: #0000ff;
}

.special,
h1,
h2,
h3,
h4,
h5 {
  font-family: "Mouse Memoirs", sans-serif;
  color: #f03450;
  text-align: center;
  margin: 0;
  letter-spacing: 0.025em;
  text-shadow: 0 0 5px white;
}

h1 {
  font-size: 3.25rem;
  margin: 0 0.5rem 1rem;
  color: #3a6396;
  text-shadow: 2px 2px 1px white, -2px 2px 1px white, 2px -2px 1px white, -2px -2px 1px white;
}

@media all and (max-width: 870px) {
  h1 {
    font-size: 2.5rem;
  }
}

h2 {
  font-size: 2.5rem;
  margin: 0 0.0rem 0.75rem;
  text-align: left;
  color: #3a6396;
  text-shadow: 2px 2px 1px white, -2px 2px 1px white, 2px -2px 1px white, -2px -2px 1px white;
}

@media all and (max-width: 870px) {
  h2 {
    font-size: 2.25rem;
  }
}

.special,
h3 {
  text-align: left;
  font-size: 2rem;
  border-bottom: 2px solid #9399ba;
}

h4 {
  font-size: 1.5rem;
  color: #76173A;
}

#wrapper {
  max-width: 100%;
  margin: 0 auto;
  padding: 0;
  border: none;
  background-color: #FFEC83;
  position: relative;
  min-height: 100%;
  display: flex;
  flex-direction: column;
}

header {
  text-align: center;
  position: relative;
  background-color: white;
  display: flex;
  background-color: white;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
}

@media all and (min-height: 1024px) and (min-width: 1200px) {
  header {
    height: 400px;
  }
}

header .header-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

header .header-bg img {
  width: 100%;
  position: relative;
  filter: opacity(0.4) brightness(1) blur(2px);
}

@media all and (min-height: 1024px) and (min-width: 1600px) {
  header .header-bg img {
    top: -15%;
  }
}

@media all and (min-height: 1024px) and (min-width: 1920px) {
  header .header-bg img {
    top: -33%;
  }
}

@media all and (max-height: 800px) {
  header .header-bg img {
    top: -75%;
  }
}

header a {
  margin: 0 auto;
  position: relative;
  padding: 2em;
  z-index: 10;
}

@media all and (max-width: 670px) {
  header a {
    padding: 1em;
  }
}

@media all and (max-height: 800px) and (min-width: 671px) {
  header a {
    padding: 0.5em;
  }
}

header .header-logo {
  display: block;
  max-width: 100%;
  margin: 0 auto;
  filter: drop-shadow(0px 0px 2px white);
}

@media all and (max-height: 800px) {
  header .header-logo {
    width: auto;
    max-height: 120px;
  }
}

/*
nav {
  font-family: "Mouse Memoirs", sans-serif;
  // margin          : 1em 0 0;
  // background-color: #FFEC83;
  // position   : relative;
  // min-height : 100%;
  width      : 100%;
  max-width  : 1024px;
  margin     : 0 auto;
  padding    : 0 1.0em;
  @media all and (max-width: 870px) {
    padding  : 0.5em;
    // margin   : 0;
    font-size: 0.9em;
  }

  ul {
    display        : flex;
    // flex-direction : column;
    list-style-type: none;
    font-size      : 1.5em;
    padding        : 0;
    gap            : 0.25em 0.5em;
    // width          : 100px; // flex-direction : row;
    // width          : 100%;
    @media all and (max-width: 870px) {
      // flex-direction: row;
      width  : 100%;
      padding: 0;
      margin : 0;
    }
  }

  li {
    padding: 0;
    display: block;
    flex   : 1;
  }

  a,
  a:active,
  a:link,
  a:visited {
    background-color: #f44336;
    color           : #ffeb3b;
    display         : block;
    text-align      : center;
    padding         : 0.5rem;
    text-decoration : none;
    box-shadow      : 2px 2px 10px -8px black;
    // background-color: #ff4100;
    // background-color: #fffff5;
    background-color: #3a6396;
    box-shadow      : 0 0 10px -7px black;
    color           : white;
    // text-shadow     : 1px 1px 2px black, 1px -1px 2px black, -1px 1px 2px black, -1px -1px 2px black;
    text-decoration : none;
    @media all and (min-width: 777px) {
      font-size     : 1.1em;
      letter-spacing: 0.05em;
    }

    &:hover {
      background-color: #3a6396;
      box-shadow      : 0 0 10px -7px black;
      background-color: #fffff5;
      color           : #3a6396;
      color           : #3a6396;
      text-shadow     : none;
    }
    @media all and (max-width: 540px) {
      span {
        display: none;
      }
    }
  }
}

*/
@media (max-width: 670px) {
  nav {
    position: fixed;
    top: 0;
    z-index: 20;
  }
  .wetter {
    background: transparent;
    margin-left: 1.5em;
  }
  #menuToggle {
    display: block;
    position: absolute;
    top: 15px;
    left: 15px;
    z-index: 1;
    -webkit-user-select: none;
    user-select: none;
  }
  #menuToggle a {
    text-decoration: none;
    color: #232323;
    transition: color 0.3s ease;
  }
  #menuToggle a:hover {
    color: tomato;
  }
  #menuToggle input {
    display: block;
    width: 40px;
    height: 32px;
    position: absolute;
    top: -7px;
    right: -5px;
    cursor: pointer;
    opacity: 0;
    z-index: 2;
    -webkit-touch-callout: none;
  }
  #menuToggle input:checked ~ span.toggle {
    opacity: 1;
    transform: rotate(45deg) translate(-2px, 2px);
    background: #3f51b5;
    box-shadow: 1px 1px 2px rgba(255, 255, 255, 0), -1px 1px 2px rgba(255, 255, 255, 0), 1px -1px 2px rgba(255, 255, 255, 0), -1px -1px 2px rgba(255, 255, 255, 0);
  }
  #menuToggle input:checked ~ span.toggle:nth-last-child(3) {
    opacity: 0;
    transform: rotate(0deg) scale(0.2, 0.2);
  }
  #menuToggle input:checked ~ span.toggle:nth-last-child(2) {
    transform: rotate(-45deg) translate(0, -2px);
  }
  #menuToggle input:checked ~ #menu {
    transform: none;
    box-shadow: 0 0 20px -5px;
  }
  #menuToggle span.toggle {
    display: block;
    width: 42px;
    height: 7px;
    margin-bottom: 6px;
    position: relative;
    background: #232323;
    box-shadow: 1px 1px 1px white, -1px 1px 1px white, 1px -1px 1px white, -1px -1px 1px white;
    border-radius: 3px;
    z-index: 1;
    transform-origin: 4px 0;
    transition: transform 0.5s cubic-bezier(0.77, 0.2, 0.05, 1), background 0.5s cubic-bezier(0.77, 0.2, 0.05, 1), opacity 0.55s ease, box-shadow 0.5s cubic-bezier(0.77, 0.2, 0.05, 1);
  }
  #menuToggle span.toggle:first-child {
    transform-origin: 0 0;
  }
  #menuToggle span.toggle:nth-last-child(2) {
    transform-origin: 0 100%;
  }
  #menu {
    position: absolute;
    height: 100vh;
    line-height: 2em;
    width: 300px;
    margin: -100px 0 0 -50px;
    padding: 125px 50px 50px;
    background: #ededed;
    list-style-type: none;
    -webkit-font-smoothing: antialiased;
    transform-origin: 0 0;
    transform: translate(-100%, 0);
    transition: transform 0.5s cubic-bezier(0.77, 0.2, 0.05, 1);
  }
  #menu h4 {
    padding: 0;
    margin: 0;
    font-size: 1.5em;
  }
  #menu ul {
    margin-top: 0.5em;
    list-style-type: none;
    padding-left: 0;
    padding-inline-start: 0;
  }
  #menu li {
    padding: 0;
    font-size: 22px;
  }
  #menu li a {
    padding: 5px 0 5px 40px;
    display: block;
  }
}

@media (min-width: 671px) {
  nav {
    font-family: "Mouse Memoirs", sans-serif;
    width: 100%;
    max-width: 1024px;
    margin: 0 auto;
    padding: 0 1.0em;
  }
  nav .wetter {
    float: right;
    /* max-height: 3em; */
    top: -17px;
    height: 68px;
    background-color: #cfe2d1;
    background-color: transparent;
    right: -34px;
    position: absolute;
    filter: drop-shadow(-1px 0px 0px #cfe2d1aa) drop-shadow(1px 0px 0px #cfe2d1aa) drop-shadow(0px 1px 0px #cfe2d1aa) drop-shadow(0px -1px 0px #cfe2d1aa);
  }
}

@media all and (min-width: 671px) and (max-width: 870px) {
  nav {
    padding: 0.5em;
    font-size: 0.9em;
  }
}

@media (min-width: 671px) {
  nav #menu {
    width: calc(100% - 1em);
    position: relative;
    left: 1em;
    overflow: hidden;
  }
  nav input {
    display: none;
  }
  nav ul {
    display: flex;
    list-style-type: none;
    font-size: 1.5em;
    padding: 0;
    gap: 0.25em 0.5em;
  }
}

@media all and (min-width: 671px) and (max-width: 870px) {
  nav ul {
    width: 100%;
    padding: 0;
    margin: 0;
  }
}

@media all and (min-width: 671px) and (max-height: 800px) {
  nav ul {
    margin: 0.5em;
  }
}

@media (min-width: 671px) {
  nav li {
    padding: 0;
    display: block;
    flex: 1;
  }
  nav li a,
  nav li a:active,
  nav li a:link,
  nav li a:visited {
    background-color: #f44336;
    color: #ffeb3b;
    display: block;
    text-align: center;
    padding: 0.5rem;
    text-decoration: none;
    box-shadow: 2px 2px 10px -8px black;
    background-color: #3a6396;
    box-shadow: 0 0 10px -7px black;
    color: white;
    text-decoration: none;
  }
}

@media all and (min-width: 671px) and (min-width: 777px) {
  nav li a,
  nav li a:active,
  nav li a:link,
  nav li a:visited {
    font-size: 1.1em;
    letter-spacing: 0.05em;
  }
}

@media (min-width: 671px) {
  nav li a:hover,
  nav li a:active:hover,
  nav li a:link:hover,
  nav li a:visited:hover {
    background-color: #3a6396;
    box-shadow: 0 0 10px -7px black;
    background-color: #fffff5;
    color: #3a6396;
    text-shadow: none;
  }
  nav li a.active,
  nav li a:active.active,
  nav li a:link.active,
  nav li a:visited.active {
    background-color: #d05743;
    box-shadow: 0 0 10px -7px black;
    color: #fffff5;
    text-shadow: none;
  }
}

main {
  background-color: white;
  background-color: #FFEC83;
  min-height: 100%;
  width: 100%;
  max-width: 1024px;
  padding-bottom: 1.5em;
  display: flex;
  flex-direction: column;
  margin: 0 auto;
  flex: 1;
  padding: 0.25em 1.25em 3em;
}

@media all and (min-width: 871px) {
  main {
    padding: 0.25em 2.0em 3em;
    font-size: 1.2em;
  }
}

main img {
  margin: 0.5em;
  max-width: calc(100% - 0.5em);
  box-sizing: border-box;
}

@media all and (min-width: 500px) {
  main img.startbeach {
    float: right;
  }
}

main img.left, main img.right {
  margin-top: 0;
}

main em,
main i {
  color: #5d2b7c;
  /* padding-right: 0.25em; */
}

main .city-list,
main .population {
  display: grid;
  gap: 0.25em 1em;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  list-style-type: none;
  padding: 0;
}

@media all and (max-width: 1024px) {
  main .city-list,
  main .population {
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    font-size: 0.8em;
  }
}

main .city-list em,
main .population em {
  padding-left: 0.25em;
  letter-spacing: 0.025em;
}

main .city-list li,
main .population li {
  display: inline-block;
}

main .city-list li span,
main .population li span {
  display: inline-block;
  width: 120px;
}

main .city-list {
  grid-template-columns: repeat(auto-fill, minmax(310px, 1fr));
}

main strong {
  color: deeppink;
  font-weight: bold;
}

.special {
  border-bottom: none;
}

.left {
  float: left;
  margin-left: 0;
}

.right {
  float: right;
  margin-right: 0;
}

.gallery-sights {
  float: left;
  clear: both;
}

.gallery-sights img {
  margin: 0;
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 0.5em;
  margin-bottom: 1em;
}

@media all and (max-width: 600px) {
  .gallery-grid {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  }
}

.gallery-grid img {
  margin: 0;
  height: 100%;
  width: 100%;
  max-width: 100%;
}

#sights {
  display: flex;
  flex-direction: column;
  gap: 1em;
  margin-top: 2em;
}

#sights p {
  margin-top: 0.5em;
}

#sights > div {
  clear: both;
}

@media all and (max-width: 480px) {
  #sights h2 {
    text-align: center;
  }
}

#sights img {
  float: right;
  margin-top: 0.5em;
  box-shadow: 0 0 6px -2px;
  border-radius: 5px;
  border: 1px solid white;
  box-sizing: content-box;
  height: auto;
}

@media all and (max-width: 480px) {
  #sights img {
    float: none;
    width: 100%;
    margin: 1em 0 0.5em;
  }
}

#sights h3 {
  text-align: left;
}

#hotels {
  display: flex;
  gap: 1em;
}

#hotels .gallery {
  flex: 1;
  min-width: 181px;
  max-width: 181px;
  display: flex;
  flex-direction: column;
  gap: 2em;
}

@media all and (max-width: 870px) {
  #hotels .gallery {
    min-width: 120px;
  }
}

@media all and (max-width: 400px) {
  #hotels .gallery {
    min-width: 80px;
  }
}

#hotels .gallery img {
  margin: 0;
  max-width: 100%;
  height: auto;
}

.hotels-item {
  flex: 1;
  clear: both;
  padding-top: 0.5em;
  border-top: 2px solid #9399ba;
}

.hotels-item > div {
  display: flex;
  justify-content: space-between;
}

@media all and (max-width: 600px) {
  .hotels-item > div {
    display: block;
  }
}

.hotels h3 {
  text-align: left;
  border-bottom: none;
}

.hotels p {
  margin-top: 0.5em;
}

.hotels img {
  margin-right: 0;
  order: 2;
}

@media all and (max-width: 600px) {
  .hotels img {
    width: 100%;
    max-width: 100%;
    height: auto;
    margin-left: 0;
  }
}

#isaleft img {
  margin-bottom: 15px;
  clear: both;
}

.info-figures {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  width: max-content;
  max-width: 100%;
}

.info-figures .info-govener {
  flex: 1;
  margin: 0 auto;
  width: max-content;
}

.info-figures .info-map {
  margin: 0.25em 0 0;
  height: auto;
  width: 100%;
  flex: 1;
}

@media all and (max-width: 870px) {
  .info-figures .info-map {
    margin: 0 auto;
    max-width: 100%;
    width: auto;
    max-height: 590px;
    text-align: center;
  }
}

@media all and (max-width: 870px) {
  .info-figures > div.mobile-only {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    width: 100%;
    gap: 0.5em;
  }
}

@media all and (min-width: 871px) {
  .info-figures > div.desktop-only {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    flex: 1;
  }
}

.info-figures figure {
  flex: 1;
  box-sizing: border-box;
  text-align: center;
  margin: 0.25em 0 1em;
}

@media all and (max-width: 870px) {
  .info-figures figure {
    max-width: 100%;
  }
}

.info-figures figure img {
  margin: 0;
  max-width: 100%;
}

.info-figures figure figcaption {
  font-size: 0.7em;
}

.info-figures figcaption {
  font-weight: normal;
  font-style: italic;
}

.info-list p {
  margin-top: 0.25em;
}

footer {
  color: #000000;
  /* min-width: 780px; */
  /* max-width: 780px; */
  position: absolute;
  /* float: left; */
  font-size: 0.8em;
  color: #333;
  padding-top: 1em;
  font-style: italic;
  text-align: center;
  /* padding-top: 5px; */
  background-color: #FFEC83;
  bottom: 20px;
  width: 100%;
}

footer a:visited {
  color: 0;
  text-decoration: underline;
}

footer a:active {
  color: #000000;
  text-decoration: underline;
}

footer a:link {
  color: #000000;
  text-decoration: underline;
}

footer a:hover {
  text-decoration: none;
  color: #6699CC;
}

@media all and (min-width: 871px) {
  .mobile-only {
    display: none !important;
  }
}

@media all and (max-width: 871px) {
  .desktop-only {
    display: none !important;
  }
}
