@import url("./main.css");

:root {
  --color: #3e6d9c;
  --line-width: 2px;
  --color-alt: #001253;
  --background-color: white;
  --background-color-alt: #3e6d9c69;
  --default-border: solid var(--line-width) var(--color);
  --bold-border: solid 4px var(--color);
}

.main-section {
  box-sizing: border-box;
  width: 578px;
  display: block;
  flex: 0 0 578px;
  background: white;
  padding-bottom: 10px;
  border: var(--default-border);
}

.main-section > .content {
  padding-left: 32px;
  padding-right: 32px;
}

.toolbar {
  display: flex;
  background: var(--background-color);
  border: var(--default-border);
  padding: 0;
  align-items: stretch;
  justify-content: stretch;
}
.toolbar > .toolbar-item {
  flex: 1 0;
  vertical-align: middle;
  display: flex;
  justify-content: center;
  align-items: center;
  vertical-align: middle;
  border: none;
  border-right: var(--default-border);
  margin: 0;
  box-sizing: border-box;
  color: var(--color);
  background: var(--background-color);
}
.toolbar .toolbar-item.spacer {
  flex: 10 1;
}

.toolbar > .toolbar-item:last-child {
  border-right: none;
}

.toolbar > .toolbar-item label {
  cursor: pointer;
}
.toolbar input[type="radio"] {
  display: none;
}
.toolbar > *:has(input[type="radio"]:checked) {
  color: var(--color-alt);
  border-top: var(--bold-border);
}

.toolbar > button {
  cursor: pointer;
}
.toolbar > *:has(input:hover),
.toolbar > button:hover {
  background-color: var(--background-color-alt);
}
.content {
  padding-top: 10px;
  display: grid;
  gap: 10px;
  grid-template-rows: 40px 40px 512px 50px 1fr;
}

.tab-content {
  display: none;
}
.tab-content.selected {
  display: grid;
}

.main-section > header {
  height: 40px;
}

.tab-list {
  display: flex;
  justify-content: stretch;
  align-items: stretch;
}

.tab-list .tab-button {
  display: block;
  flex: 1 0;
  background: var(--background-color);
  border: none;
  border-right: var(--default-border);
  cursor: pointer;
  transition: background-color 0.3s ease;
  color: var(--color);
  text-decoration: none;
}

.tab-list .tab-button:hover {
  background: var(--background-color-alt);
}

.tab-button:last-child {
  border-right: none;
}

.tab-button.selected {
  border-top: solid 4px var(--color);
}

.multi-use-line {
  display: flex;
  justify-content: space-between;
}

.game-settings input[type="text"] {
  border: none;
  border-bottom: var(--default-border);
}

.main-section.left header {
  padding-left: 32px;
  padding-top: 10px;
}
h1 {
  font-size: 18pt;
  color: var(--color);
}
#draw-item-select {
  display: block;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  border: var(--default-border);
  color: color;
  padding-left: 1rem;
}

#painting-canvas {
  width: 512px;
  image-rendering: pixelated;
}
#object-management.selected {
  display: flex;
  flex-direction: column;
  max-height: calc(100% - 50px);
}

ul.object-list {
  list-style: none;
  display: block;
  padding: 0;
  margin: 0;
  border: var(--default-border);
  overflow-y: auto;
  min-width: 0;
  flex: 1 1;
  max-height: calc(100% - 64px);
}

ul.object-list > li {
  display: flex;
  border: none;
  border-top: var(--default-border);
  height: 40px;
  padding-left: 15px;
  color: var(--color);
}

ul.object-list > li.selected {
  border-left: var(--bold-border);
  padding-left: 11px;
}

ul.object-list > li:first-child {
  border-top: none;
}

ul.object-list > li[hidden] {
  display: none;
}

ul.object-list button,
ul.object-list input {
  list-style: none;
  background: none;
  border: none;
  color: var(--color);
}

ul.object-list .object-name {
  flex: 5 1;
  display: block;
}
ul.object-list > li button {
  opacity: 0;
  transition: opacity 0.3s;
  border-left: var(--default-border);
  cursor: pointer;
}
ul.object-list > li:hover button,
ul.object-list > li.selected button {
  opacity: 1;
}
ul.object-list > li button:hover {
  background: var(--background-color-alt);
}

#new-object-button {
  width: auto;
  margin: 0;
  border: var(--default-border);
  height: 40px;
  flex: 0 0 40px;
}

#new-object-button:hover,
ul.object-list > li:hover:not(:has(button:hover)) {
  background: var(--background-color-alt);
}

.time-controls input[type="number"] {
  max-width: 40px;
  border: none;
  border-bottom: var(--default-border);
  height: calc(100% - 10px);
  appearance: none;
  background: transparent;
}
.time-controls .toolbar-item {
  flex: 0 1;
}
.time-controls .timeline {
  flex: 1 0;
  display: flex;
  justify-content: stretch;
}
.time-controls .timeline input[type="range"] {
  flex: 1 0;
}
.time-controls input[type="range"] {
  margin-left: 10px;
  margin-right: 10px;
}
.time-controls input[type="number"]::after {
  appearance: none;
}
.time-controls input[type="number"]::-webkit-outer-spin-button,
.time-controls input[type="number"]::-webkit-inner-spin-button {
  appearance: none;
  margin: 0;
}
.time-controls .speed input[type="range"] {
  width: 75px;
}

input[type="range"]::-webkit-slider-runnable-track {
  background: var(--background-color-alt);
  appearance: none;
}
input[type="range"]::-webkit-slider-thumb {
  appearance: none;
  height: 10px;
}
input[type="range"]:focus {
  outline: none;
}
