body {
  cursor: url("cursor/normal.cur"), default;
  background-color: black;
  font-family: Georgia;
  color: red;
  font-size: 4vw;
  margin: 0;
  padding: 0;
}

table.invisible, 
table.invisible th, 
table.invisible td {
  border: none !important; /* Ensures the border is removed */
}

::selection {
  color: black;
  background: red;
}

::-moz-selection {
  color: black;
  background: red;
}

a {
  text-decoration: none;
}

.bloggirl {
  word-wrap: break-word;
  white-space: normal;
  max-width: 50%;
  font-size: 20px;
  margin: 1em auto;
}

.box {
  border: 1vw solid #000000;
  text-align: center;
  word-wrap: break-word;
  width: 20vw;
  font-size: 1.5vw;
}

.tight {
  font-size: 1vw;
  line-height: 1;
}

.copyText {
cursor: pointer;
transition: text-decoration 0.3s ease;
}

.copyText:hover {
text-decoration: underline;
}

p {
  margin: 0.2em 0;
}

br {
  line-height: 2em;
}

a {
  color: red;
  text-decoration: none;
}

a:hover {
  color: red;
  text-decoration: underline;
}

a:visited {
  color: red;
}

a:active {
  color: red;
}

table, th, td {
  border: 3px double red;
  border-collapse: collapse;
  font-size: 2vw;
  padding: 1vw;
  text-align: center;
  vertical-align: middle;
  color: red;
}

.affiliates {
  border: 3px double red;
  border-collapse: collapse;
  font-size: 2vw;
  padding: 1vw; 
  text-align: center;
  vertical-align: middle;
  color: red;
}

.affiliates td, .affiliates th {
  font-size: 1vw;
    padding: .5vw;
}

.cell-content {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}

  .mobile-header {
  font-size: 3vw;
  }

  .input {
  font-size: 2.7vw;
}

@keyframes colorOverlayFade {
  0%   { background-color: rgba(0, 0, 0, 0); }
  38%  { background-color: rgba(0, 0, 0, 0); }
  50%  { background-color: rgba(160, 0, 0, 1); }
  69%  { background-color: rgba(0, 0, 0, 0); }
  100% { background-color: rgba(0, 0, 0, 0); }
}

.content {
  position: relative;
  z-index: 1;
  padding: 2rem;
}

.color-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 0;
  pointer-events: none;
  animation: colorOverlayFade 5s infinite;
}

.button-group button {
  padding: 0.5rem;
  font-size: 1rem;
  font-family: Georgia;
  cursor: pointer;
  color: black;
  background: red;
  border: none;
  border-radius: 0.25rem;
  display: inline-block;
  margin: 0.25rem;
  width: 10vw;
}

.button-group button:hover {
  background: repeating-linear-gradient(45deg, #ff4f4f, #ff4f4f 10px, transparent 10px, transparent 15px);
}

@media (min-width: 1000px) {

  .button-group button {
    width: 10vw;
  }
}

@media (max-width: 999px) {

.bloggirl {
  word-wrap: break-word;
  white-space: normal;
  max-width: 80%;
  font-size: 20px;
  margin: 1em auto;
}

  .button-group button {
    width: 30vw;
    font-size: 4vw;
  }

body {
  font-size: 14vw;
}

table, th, td {
  border: 1vw double red;
  border-collapse: collapse;
  font-size: 6vw;
  padding: 4vw;
  text-align: center;
  vertical-align: middle;
  color: red;
  max-width: 80vw;
}

.box {
  border: 1vw solid #000000;
  border-radius: 0.5rem;
  padding: 2vw;
  inline-size: 30%;
  text-align: center;
  word-wrap: break-word;
  width: 85vw;
  margin: 0 auto;
  font-size: 1.5rem;
}

.tight {
  font-size: 4vw;
  line-height: 1;
}

  .affiliates td, .affiliates th {
    font-size: 3vw;
    max-width: 30vw;
    padding: 2vw;
  }

  .mobile-header {
  font-size: 7vw;
  }

  .mobile-result {
  font-size: 7vw; /* Increase font size for mobile */
  }

  .input {
  font-size: 7vw;
}

}