* {
  font-family: sans-serif;
  box-sizing: border-box;
}

body {
  padding: 0;
  margin: 0;
  min-height: 100vh;

  font-size: 1.25em;
}

body,
dialog > .content-box {
  color: rgb(218, 218, 218);
  background-color: #444;
}

h2 {
  color: rgba(255, 255, 255, 0.5);
  margin: 0;
}

hr {
  border: none;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

dialog {
  background-color: transparent;
  border: none;
}

::backdrop {
  background-color: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(6px);
}

dialog > .content-box {
  margin: 0;
  min-width: 25em;
}

#app {
  transition: opacity 0.66s;
}

[v-cloak] {
  opacity: 0;
}

.hint {
  font-size: 0.9em;
  opacity: 0.8;
}

.wrap-set {
  display: inline-block;
}

.action-text {
  cursor: pointer;
  user-select: none;
}

.selection-item {
  display: inline-block;
  cursor: pointer;
  user-select: none;
  padding: 0.15em 0.25em 0.025em 0.25em;
  margin: 0.15em;
  border-radius: 0.5em;
  border: 1px solid transparent;
  background-color: transparent;

  transition: border-color 0.33s, background-color 0.33s, scale 0.25s;
}
.selection-item.selected {
  background-color: rgba(255, 255, 255, 0.2);
}

.selection-item:active {
  transform: scale(0.95);
}

.smaller-text {
  font-size: 0.8em;
}

.negative-amount {
  color: orange;
}

.style-obsolete {
  opacity: 0.5;
  text-decoration: line-through;
}

.style-concern {
  color: rgb(255, 115, 90);
  font-weight: bold;
}

.style-good {
  color: rgb(39, 217, 39);
  font-weight: bold;
}

.align-left {
  text-align: left;
}

.align-center {
  text-align: center;
}

.align-right {
  text-align: right;
}

.padding-none {
  padding: 0;
}

.padding-minimal {
  padding: 0.1em;
}

.padding-standard {
  padding: 0.1em;
}

.padding-extra {
  padding: 1em;
}

.icon-right {
  margin-left: 0.33em;
}

.icon-left {
  margin-right: 0.33em;
}

.content-container {
  display: grid;
  grid-template-columns: 45fr 55fr;
  gap: 1em;

  margin: 0 auto;
  max-width: 73em;
}

.content-container.align-vertical-center {
  align-items: center;
}

.content-box {
  margin: 0 0 1em 0;
  padding: 0.5em;
  background-color: rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 0.25em;

  box-shadow: 0 0 0.1em rgba(0, 0, 0, 0.15);
}

.content-box .box-header {
  margin-bottom: 0.8em;
}

input:not([type='checkbox']) {
  width: 100%;
  padding: 0.15em 0.25em;
  font-size: inherit;
  color: white;
  border: none;
  border-bottom: 1px dotted whitesmoke;
  background-color: transparent;
}

input.input-name {
  min-width: 10em;
  max-width: 15em;
}

input.input-amount {
  min-width: 5em;
  max-width: 6em;
}

input[type='date'] {
  width: 7.6em;
  text-align: center;
}

button {
  cursor: pointer;
  padding: 0.1em 0.15em;
  font-size: 0.9em;
  color: rgba(255, 255, 255, 0.5);
  border: none;
  border-radius: 0.5em;
  background-color: transparent;

  transition: scale 0.5s, color 0.4s;
}

button.edit-modified {
  font-size: 1.15em;
  transform: rotate(180deg);
}

button:hover {
  transform: scale(1.2);
  color: #fff;
}

button.edit-modified:hover {
  transform: scale(1.2) rotate(180deg);
  color: #fff;
}

button:active {
  transform: scale(0.95);
}

table {
  border-spacing: 0;
  width: 100%;
}

tr td {
  border-top: 0.5px solid rgba(255, 255, 255, 0.33);
}

table tr:nth-child(even) td {
  background-color: rgba(255, 255, 255, 0.025);
}

td,
th {
  text-align: left;
  padding: 0.15em 0.25em;
}

th {
  padding-right: 1em;
}
th:last-of-type {
  padding-right: 0.25em;
}

tr.input-row td {
  padding-top: 1em;
  border-top-width: 2px;
  background-color: transparent !important;
}

tr td.action-cell {
  width: 4em;
  padding: 0;
}

.graph-box {
  margin: 0.75em 0 0.5em 0;
}

.graph-canvas {
  width: 100%;
  max-width: 600px;
  display: block;
  margin: 0 auto;
  background-color: rgba(0, 0, 0, 0.05);
  border: 0.5px solid rgba(0, 0, 0, 0.5);
  border-radius: 0.25em;
}

@media (prefers-color-scheme: dark) {
}

@media (max-width: 975px) {
  h2 {
    font-size: 1.25em;
  }
  .content-container {
    grid-template-columns: 1fr;
  }
  .content-box {
    width: 100vw;
    max-width: 650px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 0.5em;
  }

  input.input-name,
  input.input-amount,
  input[type='text'],
  input[type='date'] {
    min-width: 1em;
  }

  .graph-canvas {
    width: 100%;
  }

  td,
  th {
    padding: 0.15em;
  }

  th {
    padding-right: 0.15em;
  }
  th:last-of-type {
    padding-right: 0.15em;
  }

  tr td.action-cell {
    width: unset;
  }
}

@media (max-width: 650px) {
  .content-box {
    padding: 0.5em 0.25em;
    border-radius: 0;
    border-left: none;
    border-right: none;
  }
}
