:root {
  --beer-yellow: #ffbd59;
}

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

body {
  background: #FFBD59;
  font-family: "Bungee", sans-serif;
  color: #111;

  min-height: 100vh;
  display: flex;
  flex-direction: column;
  /* let page scroll vertically if needed */
  overflow-x: hidden;
}

/* ---------------------------------------- */
/*  HEADER – Foam-hugging logo               */
/* ---------------------------------------- */
header {
  display: flex;
  justify-content: center;
  padding-top: clamp(0.2vh, 1vh, 1vh);  /* much tighter on mobile */
}

#logo {
  width: clamp(140px, 30vw, 320px);
  height: auto;
  filter: drop-shadow(0 0 10px rgba(0,0,0,.15));
  pointer-events: none;
}

/* ---------------------------------------- */
/*  MAIN – COMING SOON stacking block        */
/* ---------------------------------------- */
main {
  flex: 0 1 auto; /* don't grow, just take needed space */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start; /* start from top instead of center */
  text-align: center;
  padding: clamp(0.5vh, 2vh, 4vh) 1rem 0;   /* minimal top padding, no bottom */
  width: 100%;
}

.contact-wrapper {
  text-align: center;
  width: 100%;
  margin: 0 auto clamp(0.5vh, 1vh, 2vh) auto;
  display: grid;
  place-items: center;
  max-width: 100vw;
}

.contact {
  font-size: clamp(1rem, 2.8vw, 1.4rem);
  font-weight: 200;
  display: block;
  text-align: center;
  width: 100%;
  margin: 0;
}

.coming-soon {
  font-size: clamp(3rem, 9vw + 1vh, 6rem);
  margin-top: clamp(0.5vh, 2vh, 4vh);
  margin-bottom: clamp(0.3rem, 0.8rem, 1.2rem);
  text-transform: uppercase;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}

.brewing-text {
  grid-column: 2;
  text-align: center;
}

.typing-dots {
  grid-column: 3;
  display: inline-block;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  width: 1.5em;
  text-align: left;
}

.typing-dots::after {
  content: "";
  animation: typingDots 2s infinite;
}

@keyframes typingDots {
  0% { content: ""; }
  25% { content: "."; }
  50% { content: ".."; }
  75% { content: "..."; }
  100% { content: ""; }
}

.tagline {
  font-size: clamp(1.2rem, 4.5vw + 0.5vh, 2.5rem);
  margin-bottom: clamp(0.5rem, 1.5rem, 2.5rem);
}



.email-container {
  display: flex;
  align-items: center;
  position: relative;
  width: auto;
  justify-content: center;
  text-align: center;
  gap: 0;
  letter-spacing: 0;
  white-space: nowrap;
}

.email-domain {
  white-space: nowrap;
  position: relative;
  overflow: visible;
  width: auto;
  text-align: left;
  flex-shrink: 0;
  margin: 0;
  padding: 0;
}

.contact-label {
  white-space: nowrap;
  flex-shrink: 0;
  margin-right: 8px;
}

.email-prefix {
  white-space: nowrap;
  flex-shrink: 0;
  margin: 0;
  padding: 0;
  text-align: left;
}

/* Animation for domain switching */
.domain-enter {
  animation: slideInUp 0.5s ease-out;
}

.domain-exit {
  animation: slideOutDown 0.5s ease-out;
}

@keyframes slideInUp {
  from {
    transform: translateY(100%);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes slideOutDown {
  from {
    transform: translateY(0);
    opacity: 1;
  }
  to {
    transform: translateY(-100%);
    opacity: 0;
  }
}

/* ----------- NEW: Social icon ------------ */
.social-icons {
  margin-top: clamp(1rem, 1.5rem, 2rem);
}

.social-icons img {
  width: clamp(32px, 4vw, 40px);
  height: auto;
  cursor: pointer;
  filter: drop-shadow(0 0 5px rgba(0,0,0,.2));
  transition: transform 0.2s ease;
}

.social-icons img:hover {
  transform: scale(1.1);
}

/* ---------------------------------------- */
/*  FOOTER – brewery badges pinned bottom    */
/* ---------------------------------------- */
footer {
  flex: 0 0 auto;
  display: flex;
  justify-content: center;
  padding: clamp(4px, 8px, 12px) 0 clamp(8px, 16px, 20px); /* tighter on mobile */
}

.bottom-images {
  display: flex;
  gap: 12px;
  pointer-events: none;
  align-items: center;
}

.bottom-images img {
  width: clamp(64px, 10vw, 100px);
  height: auto;
}

.footer-divider {
  width: 2px;
  height: clamp(40px, 6vw, 70px);
  background-color: #000000;
}

/* ---------------------------------------- */
/*  Bubbles                                 */
/* ---------------------------------------- */
.bubble {
  position: fixed;
  bottom: -40px;
  width: 16px;
  pointer-events: none;
  z-index: 5;
  animation: bubbleUp var(--dur) linear forwards;
}

@keyframes bubbleUp {
  0%   { transform: translateY(0) scale(1);     opacity: 1;   }
  80%  { transform: translateY(calc(-80vh)) scale(1.15); opacity: .8; }
  100% { transform: translateY(calc(-100vh)) scale(1.2); opacity: 0; }
}
