.lato-light {
  font-family: "Lato", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.lato-regular {
  font-family: "Lato", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.lato-black {
  font-family: "Lato", sans-serif;
  font-weight: 900;
  font-style: normal;
}

.bd-placeholder-img {
  font-size: 1.125rem;
  text-anchor: middle;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}

@media (min-width: 768px) {
  .bd-placeholder-img-lg {
    font-size: 3.5rem;
  }
}

.b-example-divider {
  width: 100%;
  height: 3rem;
  background-color: rgba(0, 0, 0, 0.1);
  border: solid rgba(0, 0, 0, 0.15);
  border-width: 1px 0;
  box-shadow: inset 0 0.5em 1.5em rgba(0, 0, 0, 0.1),
    inset 0 0.125em 0.5em rgba(0, 0, 0, 0.15);
}

.b-example-vr {
  flex-shrink: 0;
  width: 1.5rem;
  height: 100vh;
}

.bi {
  vertical-align: -0.125em;
  fill: currentColor;
}

.nav-scroller {
  position: relative;
  z-index: 2;
  height: 2.75rem;
  overflow-y: hidden;
}

.nav-scroller .nav {
  display: flex;
  flex-wrap: nowrap;
  padding-bottom: 1rem;
  margin-top: -1px;
  overflow-x: auto;
  text-align: center;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
}

.btn-bd-primary {
  --bd-violet-bg: #e8e800;
  --bd-violet-rgb: 112.520718, 44.062154, 249.437846;

  --bs-btn-font-weight: 600;
  --bs-btn-color: var(--bs-white);
  --bs-btn-bg: var(--bd-violet-bg);
  --bs-btn-border-color: var(--bd-violet-bg);
  --bs-btn-hover-color: var(--bs-white);
  --bs-btn-hover-bg: #6528e0;
  --bs-btn-hover-border-color: #6528e0;
  --bs-btn-focus-shadow-rgb: var(--bd-violet-rgb);
  --bs-btn-active-color: var(--bs-btn-hover-color);
  --bs-btn-active-bg: #5a23c8;
  --bs-btn-active-border-color: #5a23c8;
}

a.disabled {
  pointer-events: none;
  cursor: default;
}

.bd-mode-toggle {
  z-index: 1500;
}

.bd-mode-toggle .dropdown-menu .active .bi {
  display: block !important;
}

h1 {
  font-family: "Lato", sans-serif;
  font-weight: 300;
  font-style: normal;
  font-size: 128px;
}

.lead {
  font-family: "Lato", sans-serif;
  font-weight: 300;
  font-size: 32px;
}

.bi-fake {
  width: 32px;
  vertical-align: -0.125em;
  fill: currentColor;
  margin: 6px;
}

.bi-fake:hover .s0 {
  /* fill: #ff0000; */
  fill: #0a58ca;
}

#parent {
  position: relative;
}

#child {
  position: absolute;
  top: 100%;
  left: 35%;
}

#hand {
  color: #e8e800;
}

#logo {
  padding-right: 1rem !important;
  padding-left: 1rem !important;
  max-width: 400px;
}

#message {
  margin-top: 10px;
  font-weight: bold;
}

#message.success {
  color: #00a67d;
}

#message.error {
  color: red;
}

/* Background Animation Styles */
:root {
  --size: 20px;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  /* Remove default margin */
  position: relative;
  /* Establish a new stacking context */
  min-height: 100vh;
  background: hsl(0 0% 6%);
  /* Fallback background color */
  /* overflow: hidden; /* Prevent scrollbars if not needed */
}

.perlin-noise {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  background: conic-gradient(
    from 0deg,
    #e8e800 0deg,
    #ff0000 180deg,
    #e8e800 360deg
  );
  mask: radial-gradient(circle at 50% 50%, white 2px, transparent 2.5px) 50% 50% /
      var(--size) var(--size),
    url("img/noise-mask.png") 256px 50% / 256px 256px;
  mask-composite: intersect;
  animation: flicker 20s infinite linear;
  pointer-events: none;
}

@keyframes flicker {
  to {
    mask-position: 50% 50%, 0 50%;
  }
}

input[type="email"] {
  /* Firefox, Chrome, Opera */
  text-align: center;
}
input[type="email"]::placeholder {
  /* Firefox, Chrome, Opera */
  text-align: center;
}
