html{
    font-family:sans-serif;
}
body{
    text-align: center;
    background-color: white;
}
#body_header{
    width: auto;
    /*position: relative;*/
}

#back{
    position: absolute;
    top: 2vw; /*1.5cm;*/
    left:3%; /*1cm;*/
    background-color: white;
    border: none;

}

#back:hover{
    color: rgb(183, 181, 181);
}

#back i{
    font-size: 3vw;
}

#direct-reservation{
    position: absolute;
    left: auto;
    top: 1.5vw; /*1.5cm;*/
    left:10vw; /*1cm;*/
    padding: 1.5vw;
    background-color: #3f0000;
    color: #f1f1f1;
    border: none;
    pointer-events: auto;
    opacity: 85%;
    display: flex;
    gap: 1rem;
    flex-direction: column;
    justify-content: center;
    align-items: center;

}

#direct-reservation:hover{
    background-color: #777;
    opacity: 90%;
}

.takeaway{
  color:#3f0000;
  position: absolute;
  top: 1%; /*1.5cm;*/
  right:15%; /*1cm;*/
  padding: 1.5vw;
  display: flex;
  gap: 1rem;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.takeaway:hover{
  color:#bbb;
}

#lang-container{
  position: absolute;
  top: 3%;
  right: 2%;
  display: flex;
  gap: 10px;
}

#lang-container a{
  font-size: 15px;
  color: black;
  text-decoration: underline;
}

#lan-de:hover{
  color: #666;
}
#lan-en:hover{
  color: #666;
}

#body_header p{
    position: relative;
    text-align: center;
    font-family: 'Courier New', Courier, monospace;
    margin: 0%;
    font-size: 2vw;

}

#body_header img{
    height: 15%;
    width: 20%;
    max-width: 100%;
    margin: 0cm;
    align-self: center;
}

#slogan{
  font-size: small;
  margin: 15px;
}

/* Responsive styles */
@media (max-width: 768px) {
  #body_header {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }


  #direct-reservation,
  #lang-container,
  .takeaway {
    position: static;
    margin: 10px 0;
    padding: 5px;
  }

  #direct-reservation {
    flex-direction: row;
    font-size: 4vw;
    width: auto;
    margin: 0 auto;

  }

  #lang-container {
    justify-content: center;
  }

  #body_header img {
    width: 50%;
    padding: 5px;
  }
}

  div.scrollmenu {
    background-color: #333;
    overflow: auto;
    overflow-x: auto;
    white-space: nowrap;
    width: auto;
    margin: 0%;
    display: flex;
    padding: 10px 0;
    scroll-behavior: smooth;

  }

div.scrollmenu a {
    display: inline-block;
    color: white;
    text-align: center;
    padding: 14px;
    text-decoration: none;
    width: 15%;
    padding: 12px 20px;
    text-decoration: none;
    flex-shrink: 0;
    min-width: max-content;
    white-space: nowrap;

  }

div.scrollmenu a:hover {
    background-color: #777;
  }


    /* Para móviles: scroll horizontal visible */
    .scrollmenu::-webkit-scrollbar {
        height: 6px;
      }

      .scrollmenu::-webkit-scrollbar-thumb {
        background-color: #888;
        border-radius: 4px;
      }

      .scrollmenu::-webkit-scrollbar-track {
        background-color: #333;
      }

      /* Media queries: centrar y hacer más grande en pantallas grandes */
      @media (min-width: 768px) {
        .scrollmenu {
          justify-content: center;
        }
        .scrollmenu a {
            font-size: 18px;
            padding: 14px 30px;
    }
}

.carousel.vertical {
  overflow: hidden;
  height: 450px;
  width: 100%;
}

.carousel.vertical .carousel-track {
  display: flex;
  flex-direction: column;
  transition: transform 0.5s ease-in-out;
}

.carousel.vertical .carousel-track img {
  height: 150px;
  width: 100%;
  object-fit: cover;
  margin: 5px 0;
  border-radius: 8px;

}

/* Columnas */
.column {
  float: left;
  padding: 10px;
  box-sizing: border-box;
}

.left, .right {
  width: 30%;
  background-color: #333;
}

.middle {
  width: 40%;
  background-color: white;
  display: flex;
  flex-direction: column;
  max-width: 100%;
  height: 450px;
  /*align-items: center;*/
  justify-content:center;
}

.row:after {
  content: "";
  display: table;
  clear: both;
}

/* Responsive */
@media screen and (max-width: 600px) {
  .column {
    width: 100%;
  }

  .carousel.vertical {
    height: 300px;
  }

  .carousel.vertical .carousel-track img {
    height: 100px;
  }
}

#qr-img{
 margin-top: 5%;
 max-width: 200px;
 max-height: 200px;
 min-width: 120px;
 min-height: 120px;
 left: 50%;
}

#reser{
  background-color: #3f0000;
  width: 33.33%;
  margin-left: 33.33%;
  opacity: 85%;
  margin-top: 5%;
  padding: 1.5vw;
  color: #f1f1f1;
  border: none;
  pointer-events: auto;
  display: flex;
  gap: 1rem;
  flex-direction: column;
  justify-content: center;
  align-items: center;

}

#reser:hover{
    background-color: #777;
    opacity: 90%;
}

.reservations{
    background-color: #777;

}

.col1{
  background-color: #3f0000;
}
.col2{
  background-color: black;
}
.col1{
  background-color: white;
}
#notes{
  margin-top: 5%;
}
 #notes a{
  color: #3f0000;
 }
 #notes a:hover{
  color: #9e9d9d;
 }
  #footer-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    background-color: rgb(182, 0, 18);
    opacity: 0.9;
    padding: 20px;
    gap: 10px;
  }

  #footer-container div {
    flex: 1 1 30%;
    /*min-width: 250px;  Se asegura de que no se compriman demasiado */
    padding: 10px;
    box-sizing: border-box;
    color: black;
  }

  #footer-container h3 {
    color: black;
    margin-bottom: 10px;
  }

  #footer-container li {
    list-style-type: none;
    margin-bottom: 8px;
  }

  #footer-container a {
    color: rgb(26, 24, 24);
    text-decoration: none;
  }

  #footer-container a:hover {
    color: rgb(183, 181, 181);
  }

  #footer-container a:active {
    color: rgb(255, 255, 255);
  }

  #column3 i {
    font-size: 24px;
    margin-right: 10px;
  }

  /* 🔁 Responsivo en pantallas pequeñas */
  @media (max-width: 768px) {
    #footer-container {
      flex-direction: column;
      align-items: center; /* ✅ centra todo en pantallas pequeñas */
      text-align: center;  /* ✅ centra también los textos y enlaces */
    }

    #footer-container div {
      width: 100%;
    }

    #footer-container ul {
      padding: 0;   /* quita indentación por defecto */
    }

    #footer-container li {
      margin: 5px 0; /* da un poco de espacio vertical */
    }
  }
.copy-right{
    background: black;
    text-align: center;


}
.copy-right-sec{
    padding: 0.5cm;
    background: black;
    color: #fff;
    text-align: center;




}
.copy-right-sec a{
	color: #fcd462;
    font-weight: 500;
}

a{
  text-decoration:none;
}
@media (min-width: 1420px) {

  #slogan{
    font-size: large;
  }
}
@media (min-width: 1920px) {
  html {
    font-size: 2rem;
  }

  button{
    font-size: 1vw;
  }
  #lang-container a{
    font-size: 1vw;
  }
  .scrollmenu a{
    font-size: 1vw;
  }

  #column3 i{
    font-size: 1rem;
  }
  .carousel.vertical {
  overflow: hidden;
  height: 90vh;
  width: 100%;
}
  .carousel.vertical .carousel-track img {
  height: 30vh;
  width: 100%;
  object-fit: cover;
  margin: 5px 0;
  border-radius: 8px;

}
 .middle{
  height: 90vh;
 }

#qr-img{
 max-width: 20vw;
 max-height: 20vw;
 min-width: 12vw;
 min-height: 12vw;
 left: 50%;
}

#slogan{
  font-size: larger;
}
}
