@import url("colour-scheme.css");

* {
  margin: 0;
  padding: 0;

  box-sizing: border-box;
}

:root {
  color-scheme: light dark;
}

body {
  font-family: "Google Sans Code", monospace;

  color: var(--ctp-text);
  background-color: var(--ctp-base);

  padding: 2rem;
}

div.main {
  max-width: 64rem;

  margin: 0 auto;
}

main {
  display: grid;

  grid-template-columns: 20rem 1fr;
  gap: 2rem;

  align-items: start;

  @media (max-width: 48rem) {
    grid-template-columns: 1fr;

    div.settings {
      position: static;
    }
  }
}

div.settings {
  background-color: var(--ctp-surface0);

  border: 1px solid var(--ctp-surface1);
  border-radius: 0.5rem;

  padding: 1rem;
}

div.setting-group {
  margin-bottom: 1.5rem;
}

span.setting-label,
label.setting-label {
  display: block;

  margin-bottom: 0.25rem;

  color: var(--ctp-subtext1);

  font-size: 0.875rem;

  text-transform: uppercase;
}

span.cpu-cores-helper-text {
  display: block;

  margin-top: 0.15rem;

  color: var(--ctp-overlay1);

  font-size: 0.75rem;
  font-style: italic;
}

input[type="text"],
input[type="number"],
select {
  font-family: inherit;

  width: 100%;
  height: 2.45rem;

  padding-left: 0.45rem;

  color: var(--ctp-text);
  background-color: var(--ctp-base);

  border: 1px solid var(--ctp-surface2);
  border-radius: 0.2rem;

  transition: border-color 0.2s;

  &:focus {
    outline: none;
    border-color: var(--ctp-mauve);
  }
}

select.setting-select {
  height: 100%;

  padding: 0;

  scrollbar-width: thin;

  option {
    color: var(--ctp-text);
    background-color: var(--ctp-base);

    padding: 0.7rem 0.45rem;

    &:checked {
      color: var(--ctp-base);
      background-color: var(--ctp-lavender);
    }
  }
}

div.button-group {
  display: flex;

  background-color: var(--ctp-base);

  border: 1px solid var(--ctp-surface2);
  border-radius: 0.2rem;

  /* Bad for accessibility,
     find a different solution. */
  input[type="radio"] {
    display: none;
  }

  div.button-group-button {
    flex: 1;

    text-align: center;

    &:first-child {
      border-top-left-radius: 0.2rem;
      border-bottom-left-radius: 0.2rem;
    }

    &:last-child {
      border-top-right-radius: 0.2rem;
      border-bottom-right-radius: 0.2rem;
    }

    &:has(input[type="radio"]:checked) {
      color: var(--ctp-base);
      background-color: var(--ctp-lavender);
    }

    label.button-group-button-label {
      display: inline-block;

      width: 100%;

      font-size: 0.85rem;

      padding: 0.6rem;

      cursor: pointer;
    }
  }
}

div.control-buttons {
  display: flex;

  justify-content: space-between;

  gap: 0.45rem;

  button[type="button"] {
    flex: 1;

    &:first-child {
      color: var(--ctp-base);
      background-color: var(--ctp-lavender);
    }
  }
}

button[type="button"] {
  font-family: inherit;

  height: 2.45rem;

  padding: 0 1.25rem;

  color: var(--ctp-text);
  background-color: var(--ctp-base);

  border: 1px solid var(--ctp-surface2);
  border-radius: 0.3rem;

  cursor: pointer;

  &:focus {
    outline: none;
    border-color: var(--ctp-mauve);
  }
}

div.results {
  display: grid;
  gap: 2rem;
}

div.stats {
  display: flex;

  background-color: var(--ctp-surface0);

  padding: 1rem;

  border: 1px solid var(--ctp-surface1);
  border-radius: 0.5rem;

  div.stat {
    flex: 1;

    text-align: center;

    span.stat-value {
      display: block;

      color: var(--ctp-lavender);

      font-size: large;
      font-weight: 600;
    }

    span.stat-label {
      color: var(--ctp-overlay1);

      font-size: small;

      text-transform: uppercase;
    }
  }
}

div.found-result {
  background: var(--ctp-surface0);

  padding: 1rem;

  border: 1px solid var(--ctp-surface1);
  border-radius: 0.5rem;

  div.status {
    hr {
      margin: 0.5rem 0;

      border: none;
      border-bottom: 1px solid var(--ctp-surface2);
    }

    span.status-text {
      color: var(--ctp-green);

      font-size: 0.875rem;

      text-transform: uppercase;

      &:after {
        content: attr(data-status);
      }

      &[data-status="error"] {
        color: var(--ctp-red);
      }

      &[data-status="ready"] {
        color: var(--ctp-blue);
      }

      &[data-status="running"] {
        color: var(--ctp-rosewater);
      }

      &[data-status="match found"] {
        color: var(--ctp-green);
      }
    }
  }

  div.found-key {
    div.key-info {
      margin-bottom: 1rem;

      &:last-child {
        margin-bottom: 0;
      }

      span.key-name {
        display: block;

        margin-bottom: 0.25rem;

        color: var(--ctp-overlay1);

        font-size: small;

        text-transform: uppercase;
      }

      div.key-value {
        padding: 0.5rem;

        color: var(--ctp-text);
        background-color: var(--ctp-base);

        border: 1px solid var(--ctp-surface2);
        border-radius: 0.3rem;

        word-break: break-all;
      }
    }
  }
}

code {
  font-size: small;
  font-family: "Open Sans Code", monospace;

  white-space: pre-wrap;
}
