/* Control for elements that display only in either direct or calc mode */
:root {
  --calc-mode-display  : inherit;
  --calc-mode-row      : table-row;
  --calc-mode-cell     : table-cell;
  --direct-mode-display: none;
  --direct-mode-row    : none;
  --direct-mode-cell   : none;

  --radar-mode-display: block;
  --fan-mode-display  : none;

  --rel-dev-mode-display     : inline;
  --abs-dev-mode-display     : none;
  --non-none-dev-mode-display: inline;
  --none-dev-mode-display    : none;
}

[input-mode="direct"] {
  --calc-mode-display  : none;
  --calc-mode-row      : none;
  --calc-mode-cell     : none;
  --direct-mode-display: block;
  --direct-mode-row    : table-row;
  --direct-mode-cell   : table-cell;
}

[chart-mode="fan"] {
  --radar-mode-display: none;
  --fan-mode-display  : block;
}

[dev-calc-mode="absolute"] {
  --rel-dev-mode-display     : none;
  --abs-dev-mode-display     : inline;
  --non-none-dev-mode-display: inline;
  --none-dev-mode-display    : none;
}

[dev-calc-mode="none"] {
  --rel-dev-mode-display     : none;
  --abs-dev-mode-display     : none;
  --non-none-dev-mode-display: none;
  --none-dev-mode-display    : inline;
}

.calc-mode-only {
  display: var(--calc-mode-display) !important;
}

td.calc-mode-only,
th.calc-mode-only {
  display: var(--calc-mode-cell) !important;
}

tr.calc-mode-only {
  display: var(--calc-mode-row) !important;
}

.direct-mode-only {
  display: var(--direct-mode-display) !important;
}

td.direct-mode-only,
th.direct-mode-only {
  display: var(--direct-mode-cell) !important;
}

tr.direct-mode-only {
  display: var(--direct-mode-row) !important;
}

.radar-mode-only {
  display: var(--radar-mode-display) !important;
}

.fan-mode-only {
  display: var(--fan-mode-display) !important;
}

.rel-dev-mode-only {
  display: var(--rel-dev-mode-display) !important;
}

.abs-dev-mode-only {
  display: var(--abs-dev-mode-display) !important;
}

.non-none-dev-mode-only {
  display: var(--non-none-dev-mode-display) !important;
}

.none-dev-mode-only {
  display: var(--none-dev-mode-display) !important;
}

/* Customisation of input boxes */
input.mean-value,
input.abs-deviation-value,
input.rel-deviation-value {
  text-align: right;
}

input:disabled {
  background-color: var(--psdi-bg-color-secondary);
}

[data-theme='dark'] input:disabled {
  background-color: var(--psdi-dm-bg-color-secondary-dark);
}

/* Buttons that are initially disabled */
button:disabled {
  background-color: var(--psdi-bg-color-secondary);
  border-color    : rgba(118, 118, 118, 0.3);
  color           : gray
}

/* Button with a fixed small size */
button.fix-size-small {
  height : 2rem;
  width  : 1.5rem;
  padding: 0;
}

tr td:first-child button,
#export-buttons button:first-child {
  margin-left: 0;
}

#glorius-plot {
  width : 700px;
  border: 1px solid black;
}

.hidden {
  display: none !important;
}

/* Style the title and output label tables */
.output-label,
#title-label {
  font-weight  : bold;
  padding-right: 0.5rem;
}

#title-input {
  width: 20rem;
}

.output-label-row {
  height: calc(2rem + 2px);
}

#table-options td {
  max-width: 16rem;
}

/* Style the sensitivity table */
.sensitivity-table th {
  max-width    : 8.5rem;
  padding-left : 0.25rem;
  padding-right: 0.25rem;
  text-align   : center;
}

.sensitivity-table th.rel-deviation-heading {
  /* We add a little extra padding to the relative deviation heading heading, so it wraps the same way as the absolute
  deviation heading */
  padding-left : 0.5rem;
  padding-right: 0.5rem;
}

.sensitivity-table {
  border-collapse: separate;
  border-spacing : 0 0;
}

.sensitivity-table td {
  padding-top   : 0.25rem;
  padding-bottom: 0.25rem;
  min-height    : 3rem;
}

.sample-button-container,
.plot-select-container {
  display        : flex;
  flex-direction : row;
  justify-content: center;
  align-items    : center;
}

td.condition-button-cell {
  display        : flex;
  flex-direction : row;
  justify-content: space-between;
}

.condition-label-cell {
  padding-left : 0.125rem;
  padding-right: 0.5rem;
}

.baseline-value-cell,
.sample-value-cell,
.mean-value-cell,
.abs-deviation-value-cell,
.rel-deviation-value-cell {
  padding-left : 0.125rem;
  padding-right: 0.125rem;
}

input {
  border: 2px inset #767676;
}

input.condition-label {
  max-width: 10.5rem;
}

.baseline-line-container,
.sample-line-container,
.mean-line-container,
.abs-deviation-line-container,
.rel-deviation-line-container {
  display        : flex;
  flex-direction : column;
  justify-content: center;
  align-items    : center;
}

input.baseline-value,
input.sample-value,
input.mean-value,
input.abs-deviation-value,
input.rel-deviation-value {
  max-width: 5rem;
}

.baseline-input-line,
.sample-input-line,
.mean-input-line,
.abs-deviation-input-line,
.rel-deviation-input-line {
  display        : flex;
  flex-direction : row;
  justify-content: start;
  gap            : 0.25rem;
}

.sensitivity-table td.plot-select-cell,
.plot-select-container,
.plot-select {
  padding: 0;
}

.plot-select-container {
  height: 3rem;
  width : 100%;
}

.plot-select-container:hover,
.plot-select:hover {
  cursor          : pointer;
  background-color: var(--ifm-color-secondary);
  border-radius   : 0.5rem;
}

.plot-select-container:active,
.plot-select:active {
  background-color: var(--ifm-background-color);
}

.col-selected,
.col-selected-top,
.col-selected-bottom {
  border-right: 1px solid var(--ifm-font-color-base);
  border-left : 1px solid var(--ifm-font-color-base);
}

.col-selected-top {
  border-top   : 1px solid var(--ifm-font-color-base);
  border-radius: 0.5rem 0.5rem 0 0;
}

.col-selected-bottom {
  border-bottom: 1px solid var(--ifm-font-color-base);
  border-radius: 0 0 0.5rem 0.5rem;
}

button#reset-plot-dims {
  margin-left: 0;
}

/* How to indicate text which has a tooltip on mouseover */
.mouseover-tooltip::before {
  display         : inline-flex;
  justify-content : center;
  align-items     : center;
  content         : "i";
  background-color: var(--ifm-color-info);
  color           : var(--psdi-light-text-color-body);
  font-family     : serif;
  font-weight     : bold;
  width           : 1rem;
  height          : 1rem;
  border-radius   : 0.5rem;
  margin-right    : 0.125rem;
}

/* Style the details and summary boxes */

.multicol-container {
  display              : grid;
  grid-template-columns: 1fr 1fr;
  column-gap           : 2rem;
}

details {
  border        : 1px solid var(--ifm-font-color-base);
  margin-bottom : 0.5rem;
  padding       : 0.25rem;
  padding-bottom: 0;
}

details>*:nth-child(2) {
  margin-top: 0.75rem;
}

details>*:last-child {
  margin-bottom: 0.25rem;
}

summary {
  display       : block;
  position      : relative;
  cursor        : pointer;
  user-select   : none;
  margin        : -0.25rem;
  margin-bottom : 0rem;
  padding       : 0.25rem;
  padding-bottom: 0.25;
}

details>summary:before {
  display         : inline-block;
  text-align      : center;
  padding         : 0;
  content         : "?";
  line-height     : 1rem;
  background-color: var(--ifm-color-info);
  color           : var(--psdi-light-text-color-body);
  font-family     : serif;
  font-weight     : bold;
  width           : 1rem;
  height          : 1rem;
  border-radius   : 0.5rem;
  margin-right    : 0.125rem;
  position        : relative;
  top             : 0;
  right           : 0;
}

details[open]>summary:before {
  /* n-dash is used here, which is slightly wider than a hyphen */
  content    : "–";
  top        : -0.125rem;
  line-height: 0.75rem;
}

details summary:hover {
  background-color: color-mix(in srgb, var(--ifm-background-color), var(--ifm-font-color-base) 20%);
}

.secondary details summary:hover {
  background-color: color-mix(in srgb, var(--ifm-background-color-secondary), var(--ifm-font-color-base) 20%);
}

details summary:active {
  background-color: var(--ifm-background-color);
}

.secondary details summary:active {
  background-color: var(--ifm-background-color-secondary);
}

/* Style the popup tooltips */
.tooltip {
  --bs-tooltip-opacity: 1;
}

.tooltip-on-light {
  --bs-tooltip-bg   : var(--ifm-color-primary);
  --bs-tooltip-color: var(--psdi-light-text-color-body);
}

.tooltip-on-dark {
  --bs-tooltip-bg   : var(--ifm-background-color);
  --bs-tooltip-color: var(--psdi-dark-text-color-body);
}

/* Canvas styling */
.white-bg {
  background-color: white;
}

/* Quill styling */
.ql-container.ql-snow {
  border: none;
}

*:has(>.ql-toolbar.ql-snow) {
  position: relative;
  height  : fit-content;
}

.ql-toolbar.ql-snow,
.ql-editor {
  padding: 1px 2px;
  height : 2rem;
}

.ql-toolbar.ql-snow {
  display            : none;
  border             : 1px solid #3A3A3A;
  border-bottom-width: 2px;
  position           : absolute;
  bottom             : calc(2rem - 2px);
  z-index            : 1;
  background         : var(--ifm-background-color);
}

.ql-toolbar.ql-snow .ql-formats {
  margin-right: 0.25rem;
}

.ql-toolbar.ql-snow .ql-formats button {
  color: var(--ifm-font-color-base);
}

.ql-toolbar.ql-snow .ql-formats button .ql-stroke {
  stroke: var(--ifm-font-color-base);
}

.ql-toolbar.ql-snow .ql-formats button .ql-fill {
  fill: var(--ifm-font-color-base);
}

.ql-toolbar.ql-snow .ql-formats button.ql-active {
  color: #06c;
}

.ql-toolbar.ql-snow .ql-formats button.ql-active .ql-stroke {
  stroke: #06c;
}

.ql-toolbar.ql-snow .ql-formats button.ql-active .ql-fill {
  fill: #06c;
}

.ql-toolbar.ql-snow .ql-formats button:hover {
  color           : var(--ifm-font-color-base);
  background-color: var(--ifm-color-secondary);
}

.ql-toolbar.ql-snow .ql-formats button:hover .ql-stroke {
  stroke: var(--ifm-font-color-base);
}

.ql-toolbar.ql-snow .ql-formats button:hover .ql-fill {
  fill: var(--ifm-font-color-base);
}

.ql-toolbar.ql-snow .ql-formats button:hover.ql-active {
  color: #06c;
}

.ql-toolbar.ql-snow .ql-formats button:hover.ql-active .ql-stroke {
  stroke: #06c;
}

.ql-toolbar.ql-snow .ql-formats button:hover.ql-active .ql-fill {
  fill: #06c;
}

.ql-toolbar.ql-snow .ql-formats button:active {
  background-color: var(--ifm-background-color);
}

.ql-toolbar.ql-snow.visible {
  display: block;
}

.ql-toolbar.ql-snow button {
  margin: 0px;
}

.ql-editor {
  border     : 2px inset #767676;
  font-family: 'Fira Sans', sans-serif;
  font-size  : var(--ifm-font-size-base);
  min-width  : 10.5rem;
}

.ql-editor.ql-blank::before {
  font-family: var(--ifm-font-family-base);
  font-size  : var(--ifm-font-size-base);
  color      : color-mix(in srgb, var(--ifm-font-color-base), transparent 40%);
}

.condition-input .ql-editor {
  width: 12rem;
}