@font-face {
  font-family: 'ingram_monoregular';
  src: url('fonts/ingram-mono-regular-webfont.woff2') format('woff2'),
       url('fonts/ingram-mono-regular-webfont.woff') format('woff');
  font-weight: normal;
  font-style: normal;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  /* scroll-padding-top: 125px; */
  overflow-x: hidden;
}

body {
  background-color: #e4d1b1;
  color: #101010;
  font-family: 'ingram_monoregular';
  letter-spacing: 1px;
  scroll-behavior: smooth;
  overflow-x: hidden;
  line-height: 1.4;
}

body a {
  color: #325b42;
  cursor: pointer;
}

body a:visited {
  color: #101010;
  cursor: pointer;
}

body a:hover {
  cursor: pointer;
}

/* -------------------------------------------------------
   LAYOUT: Header / Footer overlays (subtle on-page animation)
-------------------------------------------------------- */

.site-header,
#site-footer {
  position: absolute;
  left: 0;
  width: 100%;
  z-index: 10;
  background: transparent;

  opacity: 0;
  transition: transform 0.8s ease, opacity 0.8s ease;
  pointer-events: none;
}

/* Subtle offsets (NOT off-screen) */
.site-header {
  top: 0;
  transform: translateY(-14px);
}

#site-footer {
  bottom: 0;
  transform: translateY(14px);
}

/* Becomes visible after JS adds .show */
.site-header.show,
#site-footer.show {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

/* Shared bar padding */
.main-navigation,
#site-footer {
  padding: 24px 40px;
}

.nav-inner,
.footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}

.footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.footer-center {
  text-align: center;
  flex: 1;
}

.footer-left,
.footer-right {
  flex: 1;
}

.footer-center a {
  position: relative;
  text-decoration: none;
  color: inherit;
  font-size: 16px;
  letter-spacing: 0.05em;
}

.footer-center a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-color: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.25s ease;
}

.footer-center a:hover::after {
  transform: scaleX(1);
}


/* Link styling */
.nav-left a,
.footer-left a,
.nav-right a,
.footer-right a {
  position: relative;
  text-decoration: none;
  color: inherit;
  font-size: 16px;
  letter-spacing: 0.05em;
  padding-bottom: 2px;
}

/* Underline effect */
.nav-left a::after,
.nav-right a::after,
.footer-left a::after,
.footer-right a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-color: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.25s ease;
}

/* Hover state */
.nav-left a:hover::after,
.nav-right a:hover::after,
.footer-left a:hover::after,
.footer-right a:hover::after {
  transform: scaleX(1);
}

.nav-left a:hover,
.footer-left a:hover,
.nav-right a:hover,
.footer-right a:hover {
  cursor: pointer;
}

/* -------------------------------------------------------
   HERO
-------------------------------------------------------- */

#container {
  width: 100%;
}

#hero {
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Desktop: logo scales down smoothly */
.hero-logo {
  width: 33.333%;
  min-width: 240px;

  transform: scale(3); /* start big */
  transform-origin: center center;
  transition: transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}

.hero-logo.shrink {
  transform: scale(1);
}

.hero-logo img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}

/* -------------------------------------------------------
   RESERVATION EMBED
-------------------------------------------------------- */

.reservation-embed iframe {
  max-width: 100%;
  border: 0;
}

/* -------------------------------------------------------
   MOBILE
-------------------------------------------------------- */

@media (max-width: 768px) {

  /* Slightly softer + faster on mobile */
  .site-header,
  #site-footer {
    transition: transform 0.6s ease, opacity 0.6s ease;
  }

  .site-header {
    transform: translateY(-10px);
  }

  #site-footer {
    transform: translateY(10px);
  }

  /* Smaller padding */
  .main-navigation,
  #site-footer {
    padding: 10px 12px;
  }

  /* Smaller typography */
  .nav-left a,
  .nav-right a,
  .footer-left a,
  .footer-right a,
    .nav-left,
    .footer-center a {
    font-size: 12px;
    letter-spacing: 0.04em;
  }

  /* Poster-like fullscreen positioning */
  .nav-inner,
  .footer-inner {
    position: relative;
    height: 100vh;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
  }

  /* “Lunch, Dinner & Drinks” */
  .nav-left {
    position: absolute;
    top: 30%;
    transform: translateY(-50%);
    text-align: center;
    width: 100%;
  }

  /* Hide Instagram on mobile */
  .nav-right {
    display: none;
  }

  /* Address */
  .footer-left {
    position: absolute;
    top: 70%;
    transform: translateY(-50%);
    text-align: center;
    width: 100%;
  }


    .footer-center {
    position: absolute;
    top: 80%;
    transform: translateY(-50%);
    text-align: center;
    width: 100%;
  }

  /* Hide reservation embed on intro screen */
  .footer-right {
    display: none;
  }

  /* Disable logo scaling animation on mobile */
  .hero-logo {
    width: 100%;
    min-width: 0;
    transform: none !important;
    transition: none !important;
    will-change: auto;
  }

  .hero-logo.shrink {
    transform: none !important;
  }

  /* Responsive iframes if you show them later */
  .reservation-embed iframe {
    width: 100%;
    max-width: 100%;
  }
}
