:root {
  --main-bg-color: hsl(220, 24%, 10%);
  --primary-blue: hsl(210, 100%, 45%);
  --primary-blue-10: hsl(210, 100%, 35%);
  --anchor-color: var(--primary-blue);
  --anchor-hover-color: var(--primary-blue-10);
  --article-topic-badge-bg-color: hsl(56, 100%, 92%);
  --article-topic-badge-border-color: hsl(60, 60%, 59%);
  --error-message-bg-color: hsl(0, 100%, 80%);
  --error-message-border-color: hsl(0, 100%, 60%);
  --h1-color: hsl(220, 11%, 95%);
  --input-placeholder-color: hsl(221, 13%, 59%);
  --input-placeholder-focus-visible-color: hsl(221, 13%, 78%);
  --input-bg-color: hsl(221, 22%, 14%);
  --general-border-radius: 0.25rem;
  --general-border-width: 0.0625rem;
  --general-color: hsl(219, 13%, 79%);
  --general-hover-color: hsl(219, 13%, 95%);
  --tr-odd-bg-color: hsl(217, 23%, 11%);
  --tr-even-bg-color: hsl(220, 24%, 10%);
  --tr-hover-bg-color: hsl(0, 0%, 88%);
  --tr-border-color: hsl(220, 22%, 16%);
  --data-sources-btn-bg-color: hsl(217, 23%, 16%);
  --data-sources-btn-border-color: hsl(220, 22%, 16%);
  --data-sources-btn-hover-bg-color: hsl(217, 23%, 25%);
  --data-sources-btn-hover-border-color: var(--data-sources-btn-border-color);
  --data-source-status-bg-color: var(--primary-blue);
  --auth-btn-bg-color: var(--primary-blue-10);
  --auth-btn-hover-bg-color: var(--primary-blue);
}

body {
  font-family: "helvetica neue", arial, sans-serif;
  font-size: 12pt;
  line-height: 1.45em;
  margin: 0 auto;
  background-color: var(--main-bg-color);
  color: var(--general-color);
  min-height: 100vh;

  /*Only large viewports should restrict the max-width,*/
  /*otherwise mobile is not wide enough!*/
  @media (width >= 1200px) {
    max-width: 50vw;
  }
}

h1 {
  color: var(--h1-color);
}

a {
  text-decoration: none;
  color: var(--anchor-color);
}

a:hover {
  color: var(--anchor-hover-color);
}

table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin-bottom: 1em;
  margin-top: 1em;
}

table td {
  padding: 0.7rem;
  padding-left: 1em;
  text-align: left;
  border-bottom: 0.06rem solid var(--tr-border-color);
}

table tr {
  overflow: hidden;
  background-color: var(--tr-odd-bg-color);
  transition: background-color 0.3s ease;
}

tr a {
  color: var(--general-color);
}

table tr:nth-child(even) {
  background-color: var(--tr-even-bg-color);
}

table tr:hover {
  background-color: var(--tr-border-color);
}

table th {
  background-color: var(--tr-even-bg-color);
  padding: 0.7rem;
  font-size: 1.4rem;
  color: var(--general-color);
  text-align: center;
  border-bottom: 0.19rem solid var(--tr-border-color);
}

div.main-content {
  margin-right: 0.7em;
  margin-left: 0.7em;
}

footer {
  text-align: center;
  margin-top: 1.5em;
  margin-bottom: 1em;
}

span.article-topic-badge {
  background-color: var(--article-topic-badge-bg-color);
  color: black;
  border: 1px solid var(--article-topic-badge-border-color);
  border-radius: 5px;
  margin-left: 0.25em;
  padding: 0px 0.4em 1px 0.4em;
  font-size: 0.8em;
  vertical-align: middle;
  white-space: nowrap;
}

form.login {
  margin-top: 3em;
}

p.error-response {
  background-color: var(--error-message-bg-color);
  border-left: 4px solid var(--error-message-border-color);
  padding: 0.6em;
  margin: 2em auto 1em auto;
  color: black;
}

@media (width >= 1200px) {
  p.error-response {
    max-width: 50%;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

p.error-response {
  animation: fadeIn 0.5s ease-in-out;
}

form input {
  margin-bottom: 1em;
  margin-left: 1.2em;
  background-color: var(--input-bg-color);
  border: var(--general-border-width) solid #2a3140;
  border-radius: var(--general-border-radius);
  font-size: 1rem;
  padding: 0.75rem 1rem;
  color: var(--h1-color);
  transition:
    outline-width 0.5s 0s ease-in-out,
    background-color 0.5s 0s ease-in-out;
}

form input:focus-visible {
  outline: 2px solid var(--anchor-color);
  border-radius: 3px;
  background-color: transparent;
}

input::placeholder {
  color: var(--input-placeholder-color);
  opacity: 0.8;
}

input:focus-visible::placeholder {
  opacity: 1;
  color: var(--input-placeholder-focus-visible-color);
}

button {
  cursor: pointer;
}

button.auth-btn {
  background-color: var(--auth-btn-bg-color);
  border-radius: var(--general-border-radius);
  border: var(--general-border-width) solid var(--anchor-hover-color);
  color: var(--h1-color);
  text-align: center;
  text-decoration: none;
  padding: 0.75rem 1rem;
  transition:
    background-color 0.5s 0s ease-in-out,
    border 0.5s 0s ease-in-out;
}

button.auth-btn:hover {
  background-color: var(--auth-btn-hover-bg-color);
  border: var(--general-border-width) solid var(--anchor-color);
}

.box-flex-row-center {
  display: flex;
  flex-direction: row;
  justify-content: center;
}

.footer-flex {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: inherit;
}

button.data-sources-btn {
  margin-top: 0.2rem;
  padding: 0.75rem 1rem;
  background-color: var(--data-sources-btn-bg-color);
  color: var(--general-color);
  border-radius: var(--general-border-radius);
  border: var(--general-border-width) solid var(--data-sources-btn-border-color);
  text-align: center;
  text-decoration: none;
  transition:
    background-color 0.5s 0s ease-in-out,
    border 0.5s 0s ease-in-out,
    color 0.5s 0s ease-in-out;
}

button.data-sources-btn:hover {
  background-color: var(--data-sources-btn-hover-bg-color);
  border-color: var(--data-sources-btn-hover-border-color);
  color: var(--general-hover-color);
}

span.data-source-status {
  animation: fade-in-status 2s infinite;
}

@keyframes fade-in-status {
  50% {
    opacity: 0;
  }
}

span.data-source-status::before {
  border-radius: 1rem;
  display: inline-block;
  background-color: var(--data-source-status-bg-color);
  width: 0.75em;
  height: 0.75em;
  content: "";
}
