    body {
      margin: 0;
      padding: 0;
      min-height: 100vh;
      background: linear-gradient(-45deg, #b1d3dc, #fdfdfd, #9abac7, #f7f9fc);
      background-size: 600% 600%;
      animation: backgroundFlow 30s ease infinite;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      text-align: center;
      font-family: 'Inter', sans-serif;
      color: #1f2937;
    }

    @keyframes backgroundFlow {
      0%   { background-position: 0% 50%; }
      50%  { background-position: 75% 50%; }
      100% { background-position: 0% 50%; }
    }

.logo {
  min-width: 200px;
  max-width: 200px;
  margin-bottom: 12px;
  filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.1));
  animation: fadeInUp 10s ease-out forwards;
}

.logo-b {
     animation: float 6s ease-in-out infinite;
}

.intention {

  max-width: 100%;
}

@keyframes logoEntrance {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}


    @keyframes float {
      0%, 100% { transform: translateY(0); }
      50%      { transform: translateY(-5px); }
    }

    @keyframes fadeInUp {
      from { opacity: 0; transform: translateY(10px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    .tagline {
      margin-top: 2.5rem;
      font-size: 1rem;
      opacity: 0;
      animation: fadeInUp 7.5s ease-out forwards;
      animation-delay: 15s;
      color: #374151;
      letter-spacing: 0.05em;
      display: ;
    }

    .bg-overlay {
      position: fixed;
      inset: 0;
      background: radial-gradient(circle at center, rgba(255,255,255,0.05), transparent 95%);
      z-index: 0;
      pointer-events: none;
    }
    
    /* Button Container */
.button-group::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 200px;
  height: 300px;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 80%);
  filter: blur(40px);
  animation: dissolveAura 12s ease-in-out infinite;
  z-index: -1;
  border-radius: 50%;
}

@keyframes dissolveAura {
  0% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 0.2;
  }
  50% {
    transform: translate(-50%, -50%) scale(1.1);
    opacity: 0.05;
  }
  100% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 0.15;
  }
}

.button-group {
  position: relative; /* Needed for the ::before glow */
  display: flex;
  gap: 1.5rem;
  justify-content: center;
  margin-bottom: 2.5rem;
  margin-top: 1.5rem;
  flex-wrap: wrap;
  z-index: 1;
}


    /* Buttons */
    .button {
    padding: .5rem 1rem .5rem 1rem;
    font-size: 1rem;
    font-family: 'Playfair Display', serif;
    border-radius: 3px;
    transition: all 0.5s ease;
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.05);
    text-decoration: none;
    display: inline-block;
    min-width: 50px;
    }

    .button-primary {
    background-color: #5a7b7f;
    color: #ffffff;
    border: 1px solid rgba(65, 87, 93, .35);
    max-width: 100px;
    }

    .button-primary:hover {
    background-color: #668a92;
    transform: translateY(-1px);
    box-shadow: 0 8px 16px rgba(29, 123, 127, 0.2);
    }

    .button-secondary {
    background-color: #ffffff;
    color: #41575d;
    border: 1px solid rgba(90, 143, 153, .35);
    max-width: 100px;
    
    }

    .button-secondary:hover {
    background-color: #f1f5f9;
    transform: translateY(-1px);
    box-shadow: 0 8px 16px rgba(71, 85, 105, 0.1);
    }
    
    .button-secondary2 {
    background-color: #5a7b7f;
    color: #ffffff;
    border: 1px solid rgba(65, 87, 93, .35);
    max-width: 100px;
    }

    .button-secondary2:hover {
    background-color: #668a92;
    transform: translateY(-1px);
    box-shadow: 0 8px 16px rgba(29, 123, 127, 0.2);
    }
    
    .button-secondary2,
.button-secondary {
  opacity: 0;
  pointer-events: none;
  transition: opacity 2s ease;
}

.button-secondary2.show,
.button-secondary.show {
  opacity: 1;
  pointer-events: auto;
}
    .request {
    position: absolute;
    top: 0;
    right: 0;
    margin: 10px 10px 0 0;
    padding: 10px;
    font-family: 'Playfair Display', serif;
    border-radius: 3px;
    box-shadow: 0 8px 16px rgba(71, 85, 105, 0.1);
    color: #5e7f88;
    opacity: 0;
    animation: fadeInUp 7.5s ease-out forwards;
    animation-delay: 25s;
    text-decoration: none;
    display: ;
    }
    
    .pre-echo {
    position: absolute;
    bottom: 0;
    left: 0;
    margin: 0 0 10px 10px;
    padding: 10px;
    font-family: 'Playfair Display', serif;
    border-radius: 3px;
    box-shadow: 0 8px 16px rgba(71, 85, 105, 0.1);
    color: #5e7f88;
    opacity: 0;
    animation: fadeInUp 7.5s ease-out forwards;
    animation-delay: 25s;
    text-decoration: none;
    display: ;
    }
    
    .align-br {
    position: absolute;
    bottom: 0;
    right: 0;
    margin: 0 157px 10px 0;
    padding: 10px;
    font-family: 'Playfair Display', serif;
    border-radius: 3px;
    box-shadow: 0 8px 16px rgba(71, 85, 105, 0.1);
    color: #5e7f88;
    opacity: 0;
    animation: fadeInUp 7.5s ease-out forwards;
    animation-delay: 25s;
    text-decoration: none;
    display: ;
    }
    .more-br {
    position: absolute;
    bottom: 0;
    right: 0;
    margin: 0 10px 10px 0;
    padding: 10px;
    font-family: 'Playfair Display', serif;
    border-radius: 3px;
    box-shadow: 0 8px 16px rgba(71, 85, 105, 0.1);
    color: #5e7f88;
    opacity: 0;
    animation: fadeInUp 7.5s ease-out forwards;
    animation-delay: 25s;
    text-decoration: none;
    display: ;
    }
    .intention-br {
    position: absolute;
    bottom: 0;
    right: 0;
    margin: 0 72px 10px 0;
    padding: 10px;
    font-family: 'Playfair Display', serif;
    border-radius: 3px;
    box-shadow: 0 8px 16px rgba(71, 85, 105, 0.1);
    color: #5e7f88;
    opacity: 0;
    animation: fadeInUp 7.5s ease-out forwards;
    animation-delay: 20s;
    text-decoration: none;
}

.forge{ 
    position: absolute;
bottom: 0;
left: 50%;
transform: translateX(-50%);
margin: 0 0 10px 0;
padding: 10px;
font-family: 'Playfair Display', serif;
border-radius: 3px;
box-shadow: 0 8px 16px rgba(71, 85, 105, 0.1);
color: #5e7f88;
opacity: 0;
animation: fadeInUp 7.5s ease-out forwards;
animation-delay: 25s;
text-decoration: none;
}

.box {
  width: 40%;
  margin: 0 auto;
  background: rgba(255,255,255,0.2);
  padding: 35px;
  border: 2px solid #fff;
  border-radius: 4px;
  background-clip: padding-box;
  text-align: center;
}

.overlay {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.5);
  transition: opacity 900ms;
  visibility: hidden;
  opacity: 0;
}

.overlay:target {
  visibility: visible;
  opacity: 1;
}

.popup {
  margin: auto;
  top: 40%;
  padding: 20px 20px 30px;
  background: #fff;
  border-radius: 3px;
  width: 30%;
  position: relative;
  transition: all 0.5s ease-in-out;
  text-align: center;
  max-width: 95vw;
  box-sizing: border-box;
}

@media (max-width: 768px) {
  .popup {
    width: 90%;
    top: 20%;
    padding: 16px;
  }

  .token-input {
    width: 100%;
    margin-bottom: 1rem;
  }

  .button-primary {
    width: 100%;
    cursor: pointer;
  }
}


.popup .close {
  position: absolute;
  top: 20px;
  right: 30px;
  transition: all 100ms;
  font-size: 30px;
  font-weight: bold;
  text-decoration: none;
  color: #333;
}

.token-input {
  width: 100%;
  max-width: 250px;
  height: 24px;
  padding: 6px 12px;
  font-size: .8rem;
  border-radius: 3px;
  border: 1px solid #ccc;
  outline: none;
  margin-right: 1.5%;
  margin-top: 15px;
  color: #435a60;
}


.token-input:focus {
  border-color: #5a7b7f;
  box-shadow: 0 0 0 2px rgba(90, 123, 127, 0.2);
}

.form {
    margin-top: 10px;
}

.error-message,
.access-message {
  display: none;
  opacity: 0;
  transform: translateY(5px);
  transition: opacity 0.8s ease, transform 0.8s ease;
  font-size: 14px;
  margin-top: 30px;
  margin-bottom: 0;
  text-align: center;
  pointer-events: none;
    animation: fadeIn 0s ease-out forwards;
  animation-delay: 1.5s;
}

.error-message.show {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

.access-message.show {
  display: block;
  opacity: 1;
  transform: translateY(0);
  animation: opacity 0.4s ease, transform 0.4s ease;
  border-radius: 3px;
  padding: 10px 16px;  color: #435a60;
  font-weight: 500;
}


  p {
  color:#889396;
  text-shadow:5px 5px 10px #fff, 5px 5px 10px #fff;
  font-size:12.5px;
  text-align:center;
  letter-spacing: 1px;
  line-height: 1.5;
}

  .p-b {
  padding-top: 10px;
}

@keyframes pulseGlow {
  0% {
    box-shadow: 0 0 0 rgba(90, 123, 127, 0.4);
    transform: scale(1);
  }
  50% {
    box-shadow: 0 0 16px rgba(90, 123, 127, 0.4);
    transform: scale(1.02);
  }
  100% {
    box-shadow: 0 0 0 rgba(90, 123, 127, 0.4);
    transform: scale(1);
  }
}