/*
Theme Name: Base thema
Theme URI: https://foldedpaper.nl
Author: Stan van Folded Paper
Author URI: https://foldedpaper.nl
Description: Website voor Notable - experience notable gastronomy
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: https://foldedpaper.nl
*/
*, *::before, *::after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
}

ul[role=list], ol[role=list] {
  list-style: none;
}

html:focus-within {
  scroll-behavior: smooth;
}

a:not([class]) {
  text-decoration-skip-ink: auto;
}

img, picture, svg, video, canvas {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  font-style: italic;
  background-repeat: no-repeat;
  background-size: cover;
}

input, button, textarea, select {
  font: inherit;
}

@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
    transition: none;
  }
}
body, html {
  height: 100%;
  scroll-behavior: smooth;
}

.logo {
  position: absolute;
  top: 24px;
  left: 48px;
  z-index: 999;
}

.right-navigation {
  position: absolute;
  top: 64px;
  right: 48px;
  z-index: 999;
}
.right-navigation ul li {
  display: inline-block;
  margin: 0 16px;
}

.bx-controls-direction {
  margin-top: 32px !important;
}

.bx-viewport {
  touch-action: pan-y;
}

.bx-wrapper .bx-controls-direction a {
  position: relative !important;
  top: 0%;
  margin-top: 32px;
}

.trp-language-switcher > div {
  padding: none;
  border: none;
  background-color: transparent;
}

.language-switcher a {
  pointer-events: auto !important;
  cursor: pointer !important;
  z-index: 999 !important; /* Zorgt ervoor dat de link niet verborgen is */
}

h1 {
  color: white;
}

h2, h3, h4 {
  color: #BD451D;
}

p {
  margin-top: 16px;
  color: #DB957D;
  line-height: 1.3em;
}

a {
  color: #BD451D;
  text-decoration: none;
}

.buttonspacer {
  margin-right: 24px;
}

.button {
  transition: 0.1s ease-in;
  margin-top: 24px;
  background: #1D1010;
  border: 3px solid #BD451D;
  display: inline-block;
  padding: 16px;
  position: relative;
  cursor: pointer;
}
.button .bottomleft {
  left: -7px;
  bottom: -7px;
}
.button .bottomright {
  right: -7px;
  bottom: -7px;
}
.button .topleft {
  left: -7px;
  top: -7px;
}
.button .topright {
  right: -7px;
  top: -7px;
}
.button .diamond {
  width: 12px;
  height: 12px;
  position: absolute;
  background-color: #1D1010;
  border: solid 3px #BD451D;
  transform: rotate(45deg);
}
.button a {
  padding: 24px;
  text-align: center;
}

.button:hover {
  background-color: white;
  transition: 0.1s ease-in;
}

html {
  height: 100%;
}

body {
  background-color: #1D1010;
  font-family: "matrix-ii", serif, Arial, sans-serif;
  height: 100%;
  font-size: 16px;
}

html, body {
  height: auto;
  min-height: 100%;
  overflow: visible;
}

.fade-in-section {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

section {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
section .left-content, section .right-content {
  width: 47.5%;
  display: inline-block;
  align-content: center;
}

.slider .slide {
  margin-top: 32px;
}
.slider .slide .slide-heading {
  position: relative;
}
@keyframes fillBorder {
  0% {
    transform: rotate(60deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.bx-viewport {
  height: auto !important;
}

footer {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  background-color: #FEF7F7;
}

.social {
  background-color: white;
  padding: 16px;
}
.social a {
  display: block;
  text-align: center;
  margin-left: 0;
}

.top-menu-scrolled {
  width: 100%;
  background-color: rgba(29, 16, 16, 0.8);
  position: fixed;
  z-index: 999;
  height: 105px;
  transition: 0.3s ease-in;
}
.top-menu-scrolled .logo {
  top: 16px;
  width: 52px !important;
  transition: 0.1s ease-in;
}
.top-menu-scrolled .right-navigation {
  top: 48px;
  transition: 0.1s ease-in;
}

.mobile-menu-icon {
  display: none;
}

.mobile-menu {
  display: none;
}

.mobile-site-logo {
  display: none;
}

.top-menu {
  z-index: 3;
  display: flex;
  justify-content: space-between;
  position: fixed;
}
.top-menu li {
  display: inline-block;
  margin: 0 16px;
}
.top-menu .site-logo {
  position: fixed;
  left: 5%;
  margin-top: 24px;
  width: 64px;
  transition: 0.1s ease-in;
}
.top-menu .menu-right {
  margin-top: 64px;
  position: fixed;
  right: 5%;
  transition: 0.1s ease-in;
}
.top-menu a {
  transition: 0.1s ease-in;
}
.top-menu a:hover {
  color: white;
  transition: 0.1s ease-in;
}

.image-container {
  border: solid 3px #BE9E9E;
  max-width: 100%;
  overflow: hidden;
}
.image-container img {
  width: 100%;
  height: auto;
  transition: 0.3s ease-in;
}

.image-container:hover img {
  transform: scale(1.1);
  transition: 0.3s ease-in;
}

.notable-intro {
  height: 90vh;
  position: relative;
  border-bottom: solid 3px #BD451D;
  box-shadow: 0 12px 144px 0 #0A0707;
}
.notable-intro h1 {
  font-family: "matrix-ii-display-inline-ext", sans-serif;
  font-weight: 800;
  font-size: 72px;
  z-index: 1;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.notable-intro h2 {
  z-index: 1;
  font-size: 16px;
  color: white;
  position: absolute;
  bottom: 48px;
  left: 50%;
  transform: translateX(-50%);
}
.notable-intro h2 span {
  color: #BD451D;
}
.notable-intro .intro-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background: linear-gradient(180deg, rgb(10, 7, 7) 5%, rgba(10, 7, 7, 0) 100%);
  opacity: 1;
}
.notable-intro .intro-container {
  z-index: -1;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.notable-intro .hero-image {
  width: 100%;
  height: 100%;
  z-index: -1;
  background-image: url("assets/img/intro.webp");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  overflow: hidden;
}
.notable-intro .scroll-down {
  position: absolute;
  width: 64px;
  height: 64px;
  bottom: -32px;
  left: 50%;
  transform: translateX(-50%);
}

.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 96px 5%;
}

.footer-container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 48px 5%;
}

.button-container {
  width: 50%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
.button-container .button {
  width: 260px;
  text-align: center;
}

#banner-reserveren {
  position: relative;
  overflow: hidden;
}
#banner-reserveren p {
  margin-top: 24px;
  font-size: 16px;
  text-align: center;
}
#banner-reserveren .container {
  z-index: 1;
}
#banner-reserveren .reserveren-afbeelding {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: -1;
  background-image: url("assets/img/intro.webp");
  background-size: cover;
  background-repeat: no-repeat;
/*   background-attachment: fixed; */
  background-position: center center;
  overflow: hidden;
}
#banner-reserveren .reserveren-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background: linear-gradient(0deg, rgb(29, 16, 16) 20%, rgba(29, 16, 16, 0) 100%);
  opacity: 1;
}

footer {
  background-color: #FEF7F7;
}

@media only screen and (max-width: 720px) {
  .top-menu {
    display: none;
  }
  .top-menu-scrolled {
    display: none;
  }
  .mobile-site-logo {
    z-index: 999;
    position: fixed;
    top: 28px;
    left: 24px;
    width: 64px;
    transition: 0.1s ease-in;
    display: block;
  }
  .mobile-menu-icon {
    display: block;
    position: fixed;
    z-index: 999;
    top: 24px;
    right: 24px;
    transition: 0.1s ease-in;
    margin-top: 24px;
    background: #1D1010;
    border: 3px solid #BD451D;
    display: inline-block;
    padding: 8px 16px 18px 16px;
    cursor: pointer;
  }
  .mobile-menu-icon span {
    color: white;
    display: block;
    line-height: 8px;
    font-weight: bold;
  }
  .mobile-menu-icon .bottomleft {
    left: -7px;
    bottom: -7px;
  }
  .mobile-menu-icon .bottomright {
    right: -7px;
    bottom: -7px;
  }
  .mobile-menu-icon .topleft {
    left: -7px;
    top: -7px;
  }
  .mobile-menu-icon .topright {
    right: -7px;
    top: -7px;
  }
  .mobile-menu-icon .diamond {
    width: 12px;
    height: 12px;
    position: absolute;
    background-color: #1D1010;
    border: solid 3px #BD451D;
    transform: rotate(45deg);
  }
  .mobile-menu-show {
    display: block;
  }
  .mobile-menu {
    background-color: #BD451D;
    padding: 24px;
    right: 24px;
    top: 120px;
    position: fixed;
    z-index: 999;
    border-radius: 8px;
    transition: 0.1s ease-in;
  }
  .mobile-menu .diamond {
    width: 12px;
    height: 12px;
    position: absolute;
    background-color: #BD451D;
    border: solid 3px #BD451D;
    transform: rotate(45deg);
    top: -6px;
    right: 26px;
  }
  .mobile-menu li {
    text-decoration: none;
    list-style: none;
    text-align: right;
    padding: 8px;
  }
  .mobile-menu a {
    color: white;
    text-align: right;
    text-decoration: none;
  }
}
@media only screen and (max-width: 640px) {
  #masthead {
    display: none;
  }
  #trp-floater-ls.trp-bottom-left {
    display: none !important;
  }
  body {
    -webkit-text-size-adjust: none;
  }
  .notable-intro h2 {
    font-size: 12px;
  }
  .slider .slide p {
    font-size: 16px;
  }
  .left-content, .right-content {
    width: 100% !important;
    display: flex;
    flex: flex-wrap;
  }
  #menu .left-content {
    order: 2;
  }
  #menu .right-content {
    order: 1;
    margin-bottom: 24px;
  }
  #wijn .left-content {
    order: 1;
    margin-bottom: 24px;
  }
  #wijn .right-content {
    order: 2;
  }
  #banner-reserveren .button {
    padding: 16px 10px;
  }
  #banner-reserveren p {
    text-align: left;
    font-size: 16px;
  }
  #banner-reserveren .button-container {
    width: 100%;
  }
  #banner-reserveren .button-container a {
    font-size: 14px;
  }
  #contact .left-content {
    order: 2;
  }
  #contact .right-content {
    order: 1;
    margin-bottom: 24px;
  }
  .adres {
    margin-bottom: 24px;
  }
  .social a {
    display: block;
    text-align: left;
    margin-left: 16px;
  }
}
