/* Flow UI styles */

.page-header .header-left .title {
  font-family: 'Roboto';
  font-weight: 100;
  font-size: 1.2rem;
  color: var(--color-3);
  margin-left: 1rem;
  display: inline-block;
  line-height: 2rem;
  vertical-align: middle;
}

.page-content {
  flex-direction: column;
}

.CodeMirror {
  resize: vertical;
  padding: 0.25rem 0.5rem;
  flex: 1;
}

.toggle-control {
  display: flex;
  height: 1.5rem;
  font-size: 0.5rem;
  padding: 0.3rem;
  background: var(--background-color);
  color: var(--color-3);
  text-align: center;
  border-radius: 0.25rem;
  margin-left: 0.5rem;
}

.toggle-control .label {
  line-height: 1.8;
  padding: 0 0.3rem;
  margin: 0 0.1rem;
  border-radius: 0.1rem;
}

.toggle-control .label.on {
  background: var(--color);
  color: var(--background-color);
}

.toggle-control:not(.readonly) .label:not(.on) {
  cursor: pointer;
}

.toggle-control:not(.readonly) .label:not(.on):hover {
  color: var(--color);
  background-color: var(--color-hover);
}

/*
 * home
 */


#home {
  display: flex;
  flex-direction: column;
  padding-bottom: 1rem;
}

#history-view {
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: 0;
}

.section {
  display: flex;
  flex-direction: column;
  background: var(--background-2);
  border-radius: 0.5rem;
  margin: 0.5rem 0;
  overflow: hidden;
}

.section > .item-head {
  background: var(--background-5);
}

.section > .body {
  padding: 0.5rem;
}

.section > .body form {
  overflow: auto;
  margin: 0;
}

.section > .body > [aria-busy=true] {
  font-size: 1rem;
  margin: 1rem auto;
}


/*
 * Menu
 */

#menu {
  display: flex;
  flex-wrap: wrap;
  background: none;
}

#menu .group {
  display: flex;
  flex-wrap: wrap;
  padding: 0;
  margin: 0.25rem;
}

#menu .group-label {
  text-align: center;
  font-size: 0.8rem;
  font-weight: 500;
  height: 2.5rem;
  width: 8rem;
  line-height: 1.5rem;
  padding: 0.5rem 1rem;
  background: var(--background-5);
  cursor: pointer;
  border-radius: 0.25rem;
  user-select: none;
}

#menu .group-label:has(.centered-icon) {
  display: flex;
  justify-content: space-between;
}

#menu .group-label .centered-icon {
  height: 1.5rem;
  width: 1.5rem;
  margin: auto 0;
}

#menu .group-label:hover {
  background: var(--color-hover);
}

#menu .group:not(.active) .group-body {
  display: none;
}

#menu .group-body {
  display: flex;
  flex-wrap: wrap;
  margin: -0.25rem 0.25rem;
}

#menu .field {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  font-size: 0.5rem;
  height: 2.5rem;
  width: 8rem;
  margin: 0.25rem;
  padding: 0.25rem;
  background: var(--background-7);
  border-radius: 0.25rem;
  user-select: none;
}

#menu .field label {
  line-height: 1rem;
  margin: 0;
  padding: 0 0.5rem;
  color: var(--color-2);
}

#menu .field select {
  width: 100%;
  margin: 0;
  padding: 0 0.5rem;
  background-color: var(--background-7);
}

#menu .field input:not([type=checkbox]):not(:focus),
#menu .field select:not(:focus) {
  border-color: transparent;
}

#menu .menu-btns {
  display: flex;
  padding: 0.75rem 0.25rem;
  margin: 0 0 0 auto;
}

#menu .menu-btns .icon-button {
  background: var(--background-3);
}

#menu-repeat-add .group-label {
  width: unset;
}

/*
 * Draft - Location
 */

.draft-location {
  display: flex;
  flex-wrap: wrap;
  padding: 0 0.5rem;
  margin: 0.5rem 0;
}

.draft-location .title {
  font-size: 0.8rem;
  font-weight: 700;
  color: orange;
  line-height: 1.6rem;
}

.draft-location .channel-field,
.draft-location .field {
  margin: 0 0.25rem;
}

.draft-location .channel-field label { display: none; }

.draft-location input:not([type=checkbox]):not(:focus),
.draft-location select:not(:focus) {
  border-color: transparent;
}

.draft-location input:not([type=checkbox]),
.draft-location select {
  margin: 0.1rem;
  background-color: var(--background-1);
}

.draft-location:has(input[name=ephemeral][value~=true]) input[name=id] {
  display: none;
}

/*
 * Item View - Info
 */

.item-info {
  position: relative;
  padding: 0.5rem 1rem;
  font-size: 0.7rem;
}

.item-info .type-icon svg {
  margin-right: 0.25rem;
  color: #999;
  height: 0.8rem;
}

.item-info .title {
  display: inline-block;
  line-height: 1.5rem;
  margin-right: 0.5rem;
}

.item-info .indicator {
  display: inline-block;
  color: black;
  vertical-align: top;
  margin: 0 0.25rem;
  padding: 0 0.25rem;
  font-size: 0.5rem;
}

.item-info .indicator:not(.circle) {
  height: 0.75rem;
  border-radius: 0.1rem;
  margin-top: 0.3rem;
}

.item-info .indicator.circle {
  height: 0.3rem;
  width: 0.3rem;
  border-radius: 50%;
  margin-top: 0.5rem;
  padding: 0;
}

.item-info .indicator.yellow {
  background-color: var(--color-orange);
}

.item-info .indicator.blue {
  background-color: var(--color-lightblue);
}

.item-info .indicator.green {
  background-color: var(--color-green);
}

.item-info .indicator.purple {
  background-color: var(--color-purple);
}

.item-info .indicator.cyan {
  background-color: #65a9b4;
}

.item-info .indicator.gray-1 {
  color: var(--color-1);
  background-color: #000;
}

.item-info .indicator.gray-2 {
  color: var(--color-1);
  background-color: #333;
}

.item-info .indicator.gray-3 {
  color: var(--color-1);
  background-color: #666;
}

.item-info .indicator.gray-4 {
  color: var(--color-1);
  background-color: #999;
}

.item-info [role=button] {
  font-size: 0.6rem;
}

.item-info .new-item {
  font-size: 0.7em;
  vertical-align: super;
}

.item-info .info,
.item-info .date {
  display: flex;
  flex-wrap: wrap;
  font-size: 0.6rem;
  padding: 0.125rem 0 0 0;
  /* opacity: 60%; */
}

#home:not(.item-info-verbose) .item-info .info,
#home:not(.item-info-verbose) .item-info .date {
  display: none;
}

.item-info .status {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 0.25rem;
  background: linear-gradient(#FF5900, #00BBFF);
}

.item-info .status:not(.open) {
  display: none;
}

.item-info .item-process-status.pending,
.item-details .item-process-status.pending {
  display: none;
}

.item-info .item-process-status.processing,
.item-details .item-process-status.processing {
  background: var(--color-orange);
}

.item-info .item-process-status.complete,
.item-details .item-process-status.complete {
  background: var(--color-green);
}

.item-info .item-process-status.failed,
.item-details .item-process-status.failed {
  background: var(--color-red);
}

.item-details {
  position: relative;
}

.item-details textarea {
  min-height: 3rem;
}

#home .item-details .CodeMirror {
  background: var(--background-7);
  border: 1px solid transparent;
  border-radius: 0.25rem;
  min-height: 4rem;
}

#home .item-details .CodeMirror:focus-within {
  --box-shadow: 0 0 0 var(--outline-width) var(--form-element-focus-color);
  border: 1px solid var(--form-element-active-border-color);
}


/* expandable */

.expandable.expanded .expandable-head .expand {
  display: none;
}

.expandable:not(.expanded) .expandable-head .collapse {
  display: none;
}

.expandable:not(.expanded) .expandable-body {
  display: none;
}

.expandable:not(.expanded) .expandable-head .save[role=button] {
  display: none;
}

.expandable:not(:has(.expandable-body form.editable)) .expandable-head .save[role=button] {
  display: none;
}


/* tool-picker-dialog */

#tool-picker-dialog {
  min-width: 50%;
}

#tool-picker-dialog article {
  display: flex;
  flex-direction: column;
  max-width: 90vw;
  min-height: 1rem;
}

#tool-picker-dialog .tool-picker-head {
  display: flex;
  margin-bottom: 0.5rem;
}

#tool-picker-dialog .tool-picker-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 1rem;
}
