/* Local Variables:                                                */
/* eval: (add-hook 'after-save-hook #'my/refresh-ff-styles nil t)  */
/* End:                                                            */

html {
  font-size: 24px;
  font-family: Verdana, Georgia, sans-serif;
}

:focus,
:focus-visible {
  outline: solid 0.1rem orange;
}

:root {
  --box-radius: 0.2rem;

  --dull-tint-0: #000006;
  --dull-tint-1: #000819;
  --dull-tint-2: #111a27;
  --dull-tint-3: #202937;
  --dull-tint-4: #303847;
  --dull-tint-5: #404958;
  --dull-tint-6: #515a6a;
  --dull-tint-7: #626b7c;
  --dull-tint-8: #747d8e;
  --dull-tint-9: #8690a1;
  --dull-tint-10: #99a3b4;
  --dull-tint-11: #adb6c8;
  --dull-tint-12: #c0cadc;
  --dull-tint-13: #d4def1;
  --dull-tint-14: #e9f3ff;
  --dull-tint-15: #fdffff;

  --bright-tint-0: #040000;
  --bright-tint-1: #18000a;
  --bright-tint-2: #23001b;
  --bright-tint-3: #2b0027;
  --bright-tint-4: #320036;
  --bright-tint-5: #410046;
  --bright-tint-6: #540057;
  --bright-tint-7: #670069;
  --bright-tint-8: #7b007b;
  --bright-tint-9: #8f1b8e;
  --bright-tint-10: #a333a1;
  --bright-tint-11: #b847b5;
  --bright-tint-12: #cd5bc9;
  --bright-tint-13: #e26fdd;
  --bright-tint-14: #f783f2;
  --bright-tint-15: #ff97ff;
  --bright-tint-16: #ffabff;
  --bright-tint-17: #ffc0ff;
  --bright-tint-18: #ffd4ff;

  --mid: var(--dull-tint-6);
  --bright-mid: var(--bright-tint-8);
}

@media (prefers-color-scheme: light) {
  :root {
    --bg: var(--dull-tint-10);
    --fg: var(--dull-tint-2);
    --layer: var(--dull-tint-9);
    --input: white;
    --button-bg: var(--dull-tint-8);
    --button-fg: var(--dull-tint-14);
    --playhead: var(--bright-tint-6);
    --overview-window: var(--dull-tint-9);
    --marker-handle: var(--bright-tint-9);
  }
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg: var(--dull-tint-1);
    --fg: var(--dull-tint-11);
    --layer: var(--dull-tint-2);
    --input: var(--dull-tint-3);
    --button-bg: var(--dull-tint-4);
    --button-fg: var(--bright-tint-15);
    --playhead: var(--dull-tint-14);
    --overview-window: var(--dull-tint-3);
    --marker-handle: var(--bright-tint-13);
  }
}

* {
  box-sizing: border-box;
  color: var(--fg);
}

input[type="text"] {
  background: var(--input);
  padding: 0.2rem;
  border-radius: 0.2em;
  border: none;
  font-size: 0.7rem;
}

body {
  margin: 0;
  background: var(--bg);
}

body.dragging * {
  cursor: grabbing !important;
}

main {
  display: flex;
  min-height: 100dvh;
  flex-direction: column;
}

body,
main {
  width: 100%;
}

section {
  padding: 1rem;
  position: relative;
}

#load-track-section {
  display: flex;
  align-items: center;
  justify-content: center;
}
#load-track-section > * {
  margin: 0 0.2rem;
}

#track-id {
  width: 50%;
  min-width: 300px;
}

.track-section {
  background: var(--layer);
  display: flex;
  flex-direction: column;
}

.track-section h1 {
  font-size: 1.3rem;
}

.track-section h2 {
  font-size: 1rem;
}

#player-container {
  display: flex;
}

#player-container > .right {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

#player-container > .left {
  padding: 0 1rem 0 0;
}

#track-title {
  font-size: 1.5rem;
}

#track-art {
  height: 10rem;
  width: 10rem;
  margin: 1rem 1rem 1rem 0;
}

#track-controls-section {
  align-items: center;
  display: flex;
  flex-direction: column;
}

.track-controls {
  display: flex;
}

.track-controls button {
  margin: 0.2rem;
  font-size: 1.5rem;
}

.hidden {
  display: none;
}

#overview {
  margin: 1rem;
  padding: 0;
  width: auto;
  position: relative;
  display: flex;
  align-items: center;
  height: 2rem;
  overflow: visible;
}

#overview-markers {
  position: absolute;
  width: 100%;
  height: 1.5rem;
  z-index: 1;
}
.overview-marker {
  background: var(--dull-tint-6);
  transform: translateX(-50%);
  width: 2px;
  height: 100%;
  position: absolute;
}
.overview-marker.active {
  background: var(--bright-tint-10);
}

#overview-bar {
  position: absolute;
  left: 0;
  right: 0;
  height: 0.5rem;
  background: var(--mid);
  border-radius: var(--box-radius);
}

#overview-bar.active {
  background: var(--bright-mid);
}

#overview-bar .between {
  transition: opacity 0.3s;
  background: var(--bright-tint-10);
  opacity: 0.000001;
  height: 100%;
  position: absolute;
}
#overview-bar .between.active {
  opacity: 1;
}

#overview-bar .between:first-child {
  border-radius: var(--box-radius) 0 0 var(--box-radius);
}

#overview-bar .between:last-child {
  border-radius: 0 var(--box-radius) var(--box-radius) 0;
}

#overview-window {
  transition:
    width 0.1s,
    opacity 0.6s;
  background: var(--overview-window);
  height: 100%;
  position: absolute;
  z-index: -10;
}

#overview-playhead {
  position: absolute;
  height: 1rem;
  width: 1rem;
  border-radius: 50%;
  background: var(--playhead);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
}

#overview-progress {
  background: var(--fg);
  position: absolute;
  left: 0;
  right: 50%;
  height: 100%;
  border-radius: var(--box-radius) 0 0 var(--box-radius);
}

#overview :not(#scrubber) {
  pointer-events: none;
}

#scrubber {
  width: 100%;
  height: 100%;
  opacity: 0.001;
}

#editor-section {
  min-height: 300px;
  flex-grow: 1;
  overflow-x: auto;
  overflow-y: visible;
  display: flex;
  flex-direction: column;
}

#editor-controls {
  align-self: end;
  padding: 0.2rem 1rem;
}

#editor-controls > div {
  font-size: 1rem;
  display: flex;
  justify-content: flex-end;
  gap: 0.2rem;
  padding: 0.2rem 0;
}

#zoom-settings {
  display: flex;
}

button {
  border: none;
  border-radius: var(--box-radius);
  background: var(--button-bg);
  color: var(--button-fg);
  padding: 0.2rem 0.5rem;
  font-size: 0.7rem;
}

#editor {
  width: 100%;
  height: 200px;
  background: var(--dull-tint-5);
  position: relative;
  container-type: size;
}

#backdrop {
  height: 100%;
  width: 100%;
  background: var(--dull-tint-4);
  position: relative;
  overflow: hidden;
}

#squiggle {
  top: 0;
  height: 100%;
  width: 100%;
  z-index: 1;
  pointer-events: none;
}

#playhead {
  width: 2px;
  position: absolute;
  top: 0;
  bottom: 0;
  background: var(--dull-tint-11);
  left: 0;
  z-index: 1;
  transform: translateX(-50%);
}

#playhead-handle {
  position: absolute;
  top: -14px;
  width: 0px;
  height: 0px;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 16px solid var(--playhead);
  transform: translateX(-9px);
}

#squiggle-path {
  fill: var(--dull-tint-5);
}

#editor-markers .between {
  position: absolute;
  top: 0;
  bottom: 0;
  background-color: #a333a100;
  mix-blend-mode: overlay;
  transition: background-color 0.1s linear;
}

#editor-markers .between.active {
  z-index: 1;
  background: var(--bright-tint-10);
}

.marker {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--bright-tint-13);
  opacity: 1;
  z-index: 1;
  cursor: grab;
  transform: translateX(-50%);
}

.marker.active {
  background: red;
}

.teardrop {
  border-radius: 100% 0% 60% 40% / 60% 0% 100% 40%;
  width: 30px;
  height: 30px;
}

.marker-handle {
  background: var(--marker-handle);
  position: absolute;
  bottom: -40px;
  right: -15px;
  transform: rotate(-45deg);
  border: solid 2px var(--bg);
}

.marker.active .marker-handle {
  background: red;
}
