@charset "UTF-8";
/* Site is designed mobile first & dark first
 * Inspired by the following:
 * https://codepen.io/kevinpowell/pen/XJJwaxG?editors=1100
 * https://www.youtube.com/watch?v=_ZFghigBmqo
 */
@import url(https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:FILL@0..1&icon_names=arrow_range,bluetooth_searching,circle,dangerous,dashboard,deployed_code_update,flip,logout,nest_true_radiant,next_plan,reset_settings,share,speed&display=block);
:root {
  --is-mobile-ui: true;
  --is-portrait: true;
  --text-1: hsl(0, 0%, 100%);
  --text-2: hsl(240, 21%, 88%);
  --text-3: hsl(240, 15%, 76%);
  --surface-1: hsl(256, 43%, 7%);
  --surface-2: hsl(240, 24%, 13%);
  --surface-3: hsl(243, 26%, 15%);
  --border-1: hsl(259, 13%, 28%);
  --border-2: hsl(252, 9%, 22%);
}
@media (prefers-color-scheme: light) {
  :root {
    --text-1: hsl(0, 0%, 0%);
    --text-2: hsl(256, 43%, 7%);
    --text-3: hsl(240, 24%, 13%);
    --surface-1: hsl(240, 21%, 88%);
    --surface-2: hsl(240, 15%, 76%);
    --surface-3: hsl(251, 13%, 68%);
    --border-1: hsl(254, 22%, 32%);
    --border-2: hsl(259, 13%, 28%);
  }
}
@media (min-width: 501px) and (min-height: 1001px) {
  :root {
    --is-mobile: false;
  }
}
@media (orientation: landscape) {
  :root {
    --is-portrait: false;
  }
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  color: inherit;
  outline: none;
  -webkit-tap-highlight-color: transparent;
}

html, body {
  margin: 0;
  padding: 0;
  width: 100dvw;
  height: 100dvh;
  overflow: hidden;
}

body {
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--text-1);
  font-family: system-ui;
  padding-bottom: env(safe-area-inset-bottom);
}

button,
a.button {
  padding: 1rem;
  border: none;
  border-radius: 0.75em;
  transition: background 0.2s ease;
  text-decoration: none;
  background-color: hsl(from var(--surface-1) h s l/0.5);
  color: var(--text-1);
}
button:hover:not([disabled]),
a.button:hover:not([disabled]) {
  background-color: hsl(from var(--surface-2) h s l/0.5);
  cursor: pointer;
}
button[disabled],
a.button[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

input:focus {
  outline: none;
}
input[type=text], input[type=password], input[type=email], input[type=number] {
  background-color: transparent;
  border: none;
  border-radius: 0.75em;
  padding: 0.75rem;
  background-color: hsl(from var(--surface-1) h s l/0.5);
  transition: background-color 0.2s ease, border-color 0.2s ease;
}
input[type=checkbox] {
  border-radius: 0.25em;
  cursor: pointer;
}
input[type=checkbox]:has(+ label) {
  display: inline;
}
input[type=checkbox]:has(+ label) + label {
  cursor: pointer;
  vertical-align: middle;
}
input[type=checkbox]:not(:has(+ label)) {
  appearance: none;
}
input[type=checkbox]:not(:has(+ label)):after {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: middle;
  background-color: hsl(from var(--surface-1) h s l/0.5);
  transition: background-color 0.2s ease, border-color 0.2s ease;
  width: 1.2em;
  height: 1.2em;
  border-radius: 0.25em;
}
input[type=checkbox]:not(:has(+ label)):checked:after {
  background-color: hsl(from hsl(275, 100%, 69%) h s l/0.5);
  background-repeat: no-repeat;
  background-position: center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M20.285 6.709l-11.025 11.025-5.285-5.285 1.414-1.414 3.871 3.871 9.611-9.611z'/%3E%3C/svg%3E");
}
input[type=checkbox]:not(:has(+ label)):hover:after {
  background-color: hsl(from var(--surface-2) h s l/0.5);
}
input[type=checkbox]:not(:has(+ label)):checked:hover:after {
  background-color: hsl(from hsl(275, 100%, 69%) h s l/0.3);
}
input[type=checkbox]:has(+ label):not(.after-label) {
  display: none;
}
input[type=checkbox]:has(+ label):not(.after-label) + label:before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: middle;
  background-color: hsl(from var(--surface-1) h s l/0.5);
  transition: background-color 0.2s ease, border-color 0.2s ease;
  margin-right: 0.5rem;
  border-radius: 0.25em;
}
input[type=checkbox]:has(+ label):not(.after-label):checked + label:before {
  background-color: hsl(from hsl(275, 100%, 69%) h s l/0.5);
  background-repeat: no-repeat;
  background-position: center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M20.285 6.709l-11.025 11.025-5.285-5.285 1.414-1.414 3.871 3.871 9.611-9.611z'/%3E%3C/svg%3E");
}
input[type=checkbox]:has(+ label):not(.after-label):hover + label:before {
  background-color: hsl(from var(--surface-2) h s l/0.5);
}
input[type=checkbox]:has(+ label):not(.after-label):checked:hover + label:before {
  background-color: hsl(from hsl(275, 100%, 69%) h s l/0.3);
}
input[type=checkbox].after-label {
  display: none;
}
input[type=checkbox].after-label + label:after {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: middle;
  background-color: hsl(from var(--surface-1) h s l/0.5);
  transition: background-color 0.2s ease, border-color 0.2s ease;
  margin-left: 0.5rem;
  border-radius: 0.25em;
}
input[type=checkbox].after-label:checked + label:after {
  background-color: hsl(from hsl(275, 100%, 69%) h s l/0.5);
  background-repeat: no-repeat;
  background-position: center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M20.285 6.709l-11.025 11.025-5.285-5.285 1.414-1.414 3.871 3.871 9.611-9.611z'/%3E%3C/svg%3E");
}
input[type=checkbox].after-label:hover + label:after {
  background-color: hsl(from var(--surface-2) h s l/0.5);
}
input[type=checkbox].after-label:checked:hover + label:after {
  background-color: hsl(from hsl(275, 100%, 69%) h s l/0.3);
}
input[type=checkbox].hidden {
  display: none;
}
input[type=checkbox].hidden + label {
  display: none;
}
input[type=checkbox].icon + label:before,
input[type=checkbox].icon + label:after, input[type=checkbox].icon::after {
  background-image: none !important;
  font-family: "Material Symbols Outlined";
  font-size: 1em;
  text-align: center;
}
input[type=checkbox].icon:checked + label:before,
input[type=checkbox].icon:checked + label:after, input[type=checkbox].icon:checked::after {
  background-image: none !important;
}
input[type=checkbox].icon:not(:has(+ label)):after {
  line-height: 1.2em;
  content: attr(data-unchecked-icon);
}
input[type=checkbox].icon:not(:has(+ label)):checked:after {
  content: attr(data-checked-icon);
}
input[type=checkbox].icon:has(+ label):not(.after-label) + label:before {
  line-height: 1.2em;
  content: attr(data-unchecked-icon);
}
input[type=checkbox].icon:has(+ label):not(.after-label):checked + label:before {
  content: attr(data-checked-icon);
}
input[type=checkbox].icon.after-label + label:after {
  line-height: 1.2em;
  content: attr(data-unchecked-icon);
}
input[type=checkbox].icon.after-label:checked + label:after {
  content: attr(data-checked-icon);
}
input[type=radio] {
  border-radius: 100%;
  cursor: pointer;
}
input[type=radio]:has(+ label) {
  display: inline;
}
input[type=radio]:has(+ label) + label {
  cursor: pointer;
  vertical-align: middle;
}
input[type=radio]:not(:has(+ label)) {
  appearance: none;
}
input[type=radio]:not(:has(+ label)):after {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: middle;
  background-color: hsl(from var(--surface-1) h s l/0.5);
  transition: background-color 0.2s ease, border-color 0.2s ease;
  width: 1.2em;
  height: 1.2em;
  border-radius: 100%;
}
input[type=radio]:not(:has(+ label)):checked:after {
  background-color: hsl(from hsl(275, 100%, 69%) h s l/0.5);
  background-repeat: no-repeat;
  background-position: center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Ccircle cx='12' cy='12' r='6'/%3E%3C/svg%3E");
}
input[type=radio]:not(:has(+ label)):hover:after {
  background-color: hsl(from var(--surface-2) h s l/0.5);
}
input[type=radio]:not(:has(+ label)):checked:hover:after {
  background-color: hsl(from hsl(275, 100%, 69%) h s l/0.3);
}
input[type=radio]:has(+ label):not(.after-label) {
  display: none;
}
input[type=radio]:has(+ label):not(.after-label) + label:before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: middle;
  background-color: hsl(from var(--surface-1) h s l/0.5);
  transition: background-color 0.2s ease, border-color 0.2s ease;
  margin-right: 0.5rem;
  border-radius: 100%;
}
input[type=radio]:has(+ label):not(.after-label):checked + label:before {
  background-color: hsl(from hsl(275, 100%, 69%) h s l/0.5);
  background-repeat: no-repeat;
  background-position: center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Ccircle cx='12' cy='12' r='6'/%3E%3C/svg%3E");
}
input[type=radio]:has(+ label):not(.after-label):hover + label:before {
  background-color: hsl(from var(--surface-2) h s l/0.5);
}
input[type=radio]:has(+ label):not(.after-label):checked:hover + label:before {
  background-color: hsl(from hsl(275, 100%, 69%) h s l/0.3);
}
input[type=radio].after-label {
  display: none;
}
input[type=radio].after-label + label:after {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: middle;
  background-color: hsl(from var(--surface-1) h s l/0.5);
  transition: background-color 0.2s ease, border-color 0.2s ease;
  margin-left: 0.5rem;
  border-radius: 100%;
}
input[type=radio].after-label:checked + label:after {
  background-color: hsl(from hsl(275, 100%, 69%) h s l/0.5);
  background-repeat: no-repeat;
  background-position: center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Ccircle cx='12' cy='12' r='6'/%3E%3C/svg%3E");
}
input[type=radio].after-label:hover + label:after {
  background-color: hsl(from var(--surface-2) h s l/0.5);
}
input[type=radio].after-label:checked:hover + label:after {
  background-color: hsl(from hsl(275, 100%, 69%) h s l/0.3);
}
input[type=radio].hidden {
  display: none;
}
input[type=radio].hidden + label {
  display: none;
}
input[type=radio].icon + label:before,
input[type=radio].icon + label:after, input[type=radio].icon::after {
  background-image: none !important;
  font-family: "Material Symbols Outlined";
  font-size: 1em;
  text-align: center;
}
input[type=radio].icon:checked + label:before,
input[type=radio].icon:checked + label:after, input[type=radio].icon:checked::after {
  background-image: none !important;
}
input[type=radio].icon:not(:has(+ label)):after {
  line-height: 1.2em;
  content: attr(data-unchecked-icon);
}
input[type=radio].icon:not(:has(+ label)):checked:after {
  content: attr(data-checked-icon);
}
input[type=radio].icon:has(+ label):not(.after-label) + label:before {
  line-height: 1.2em;
  content: attr(data-unchecked-icon);
}
input[type=radio].icon:has(+ label):not(.after-label):checked + label:before {
  content: attr(data-checked-icon);
}
input[type=radio].icon.after-label + label:after {
  line-height: 1.2em;
  content: attr(data-unchecked-icon);
}
input[type=radio].icon.after-label:checked + label:after {
  content: attr(data-checked-icon);
}
input[type=range] {
  --range-value: 50%;
  --range-track-thickness: 100%;
  border-radius: 0.75em;
  appearance: none;
  background: transparent;
  cursor: pointer;
}
input[type=range]::-webkit-slider-runnable-track {
  border-radius: 0.75em;
  transition: background 0.2s ease;
}
input[type=range]::-moz-range-track {
  border-radius: 0.75em;
  transition: background 0.2s ease;
}
input[type=range]::-ms-track {
  border-radius: 0.75em;
  transition: background 0.2s ease;
}
input[type=range]::-webkit-slider-thumb {
  appearance: none;
  width: 0;
  height: 0;
  border: none;
}
input[type=range]::-moz-range-thumb {
  width: 0;
  height: 0;
  border: none;
}
input[type=range]::-ms-thumb {
  width: 0;
  height: 0;
  border: none;
}
input[type=range]:active {
  cursor: grabbing;
}
input[type=range]:not([orientation=vertical]) {
  min-height: 1rem;
}
input[type=range]:not([orientation=vertical])::-webkit-slider-runnable-track {
  height: var(--range-track-thickness);
  background: linear-gradient(to right, hsl(from hsl(275, 100%, 69%) h s l/0.5) 0%, hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/100% var(--range-track-thickness) no-repeat;
}
input[type=range]:not([orientation=vertical])::-moz-range-track {
  height: var(--range-track-thickness);
  background: linear-gradient(to right, hsl(from hsl(275, 100%, 69%) h s l/0.5) 0%, hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/100% var(--range-track-thickness) no-repeat;
}
input[type=range]:not([orientation=vertical])::-ms-track {
  height: var(--range-track-thickness);
  background: linear-gradient(to right, hsl(from hsl(275, 100%, 69%) h s l/0.5) 0%, hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/100% var(--range-track-thickness) no-repeat;
}
input[type=range][orientation=vertical] {
  writing-mode: vertical-lr;
  direction: rtl;
  min-width: 1rem;
}
input[type=range][orientation=vertical]::-webkit-slider-runnable-track {
  width: var(--range-track-thickness);
  transition: background 0.5s ease;
  background: linear-gradient(to top, hsl(from hsl(275, 100%, 69%) h s l/0.5) 0%, hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/var(--range-track-thickness) 100% no-repeat;
}
input[type=range][orientation=vertical]::-moz-range-track {
  width: var(--range-track-thickness);
  transition: background 0.5s ease;
  background: linear-gradient(to top, hsl(from hsl(275, 100%, 69%) h s l/0.5) 0%, hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/var(--range-track-thickness) 100% no-repeat;
}
input[type=range][orientation=vertical]::-ms-track {
  width: var(--range-track-thickness);
  transition: background 0.5s ease;
  background: linear-gradient(to top, hsl(from hsl(275, 100%, 69%) h s l/0.5) 0%, hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/var(--range-track-thickness) 100% no-repeat;
}

section {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.5rem;
}

p {
  line-height: 1.5;
}

footer {
  position: absolute;
  left: 0;
  right: 0;
  text-align: center;
  font-size: 0.75rem;
  color: var(--text-2);
  transition: opacity 0.2s ease;
}

.material-symbol {
  display: inline-block;
  width: 1.5em;
  height: 0;
  line-height: 0;
  vertical-align: middle;
  font-family: "Material Symbols Outlined";
  font-size: 1.5em;
  overflow: visible;
}
.material-symbol.fill {
  font-variation-settings: "FILL" 1;
}
.material-symbol.small {
  width: 1em;
  font-size: 1em;
}
.material-symbol::before {
  content: attr(data-icon);
  display: block;
  transform: translateY(-0.075em);
}
.material-symbol.no-offset::before {
  transform: translateY(0);
}

.no-border {
  border: none !important;
}

.space-between {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.input-container-number {
  display: inline-flex;
  border-radius: 0.5em;
  overflow: hidden;
}
.input-container-number [type=number] {
  flex: 1;
  min-width: 0;
  appearance: textfield;
  border-radius: 0;
}
.input-container-number [type=number]::-webkit-inner-spin-button, .input-container-number [type=number]::-webkit-outer-spin-button {
  -webkit-appearance: none;
}
.input-container-number > button {
  padding: 0.2rem 0.5rem;
  border-radius: 0;
}
.input-container-number:has(> input[type=number].spin-left) > input[type=number] {
  text-align: left;
}
.input-container-number:has(> input[type=number].spin-right) > input[type=number] {
  text-align: right;
}
.input-container-number:has(> input[type=number].spin-split) > input[type=number] {
  text-align: center;
}
.input-container-range-double {
  --range-from-value: 20%;
  --range-to-value: 80%;
  position: relative;
  display: inline-flex;
  flex-wrap: wrap;
}
.input-container-range-double > input[type=range] {
  position: relative;
  flex: 100%;
}
.input-container-range-double > input[type=range][data-component=from] {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
}
.input-container-range-double:not([orientation=vertical]) > input[type=range][data-component=from] {
  clip-path: inset(0 calc(100% - var(--range-to-value) + (var(--range-to-value) - var(--range-from-value)) / 2) 0 0);
}
.input-container-range-double:not([orientation=vertical]) > input[type=range][data-component=from]::-webkit-slider-runnable-track {
  background: transparent;
}
.input-container-range-double:not([orientation=vertical]) > input[type=range][data-component=from]::-moz-range-track {
  background: transparent;
}
.input-container-range-double:not([orientation=vertical]) > input[type=range][data-component=from]::-ms-track {
  background: transparent;
}
.input-container-range-double:not([orientation=vertical]) > input[type=range][data-component=to]:not(:disabled)::-webkit-slider-runnable-track {
  background: linear-gradient(to right, hsl(from var(--surface-2) h s l/0.5) 0%, hsl(from var(--surface-2) h s l/0.5) var(--range-from-value), hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-from-value), hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-to-value), hsl(from var(--surface-2) h s l/0.5) var(--range-to-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/100% var(--range-track-thickness) no-repeat;
}
.input-container-range-double:not([orientation=vertical]) > input[type=range][data-component=to]:not(:disabled)::-moz-range-track {
  background: linear-gradient(to right, hsl(from var(--surface-2) h s l/0.5) 0%, hsl(from var(--surface-2) h s l/0.5) var(--range-from-value), hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-from-value), hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-to-value), hsl(from var(--surface-2) h s l/0.5) var(--range-to-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/100% var(--range-track-thickness) no-repeat;
}
.input-container-range-double:not([orientation=vertical]) > input[type=range][data-component=to]:not(:disabled)::-ms-track {
  background: linear-gradient(to right, hsl(from var(--surface-2) h s l/0.5) 0%, hsl(from var(--surface-2) h s l/0.5) var(--range-from-value), hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-from-value), hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-to-value), hsl(from var(--surface-2) h s l/0.5) var(--range-to-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/100% var(--range-track-thickness) no-repeat;
}
.input-container-range-double[orientation=vertical] > input[type=range] {
  writing-mode: vertical-lr;
  direction: rtl;
  min-width: 1rem;
}
.input-container-range-double[orientation=vertical] > input[type=range]::-webkit-slider-runnable-track {
  width: var(--range-track-thickness);
  transition: background 0.5s ease;
  background: linear-gradient(to top, hsl(from hsl(275, 100%, 69%) h s l/0.5) 0%, hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/var(--range-track-thickness) 100% no-repeat;
}
.input-container-range-double[orientation=vertical] > input[type=range]::-moz-range-track {
  width: var(--range-track-thickness);
  transition: background 0.5s ease;
  background: linear-gradient(to top, hsl(from hsl(275, 100%, 69%) h s l/0.5) 0%, hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/var(--range-track-thickness) 100% no-repeat;
}
.input-container-range-double[orientation=vertical] > input[type=range]::-ms-track {
  width: var(--range-track-thickness);
  transition: background 0.5s ease;
  background: linear-gradient(to top, hsl(from hsl(275, 100%, 69%) h s l/0.5) 0%, hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) var(--range-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/var(--range-track-thickness) 100% no-repeat;
}
.input-container-range-double[orientation=vertical] > input[type=range] {
  height: initial;
}
.input-container-range-double[orientation=vertical] > input[type=range][data-component=from] {
  clip-path: inset(calc(100% - var(--range-to-value) + (var(--range-to-value) - var(--range-from-value)) / 2) 0 0 0);
}
.input-container-range-double[orientation=vertical] > input[type=range][data-component=from]::-webkit-slider-runnable-track {
  background: transparent;
}
.input-container-range-double[orientation=vertical] > input[type=range][data-component=from]::-moz-range-track {
  background: transparent;
}
.input-container-range-double[orientation=vertical] > input[type=range][data-component=from]::-ms-track {
  background: transparent;
}
.input-container-range-double[orientation=vertical] > input[type=range][data-component=to]:not(:disabled)::-webkit-slider-runnable-track {
  background: linear-gradient(to top, hsl(from var(--surface-2) h s l/0.5) 0%, hsl(from var(--surface-2) h s l/0.5) var(--range-from-value), hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-from-value), hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-to-value), hsl(from var(--surface-2) h s l/0.5) var(--range-to-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/var(--range-track-thickness) 100% no-repeat;
}
.input-container-range-double[orientation=vertical] > input[type=range][data-component=to]:not(:disabled)::-moz-range-track {
  background: linear-gradient(to top, hsl(from var(--surface-2) h s l/0.5) 0%, hsl(from var(--surface-2) h s l/0.5) var(--range-from-value), hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-from-value), hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-to-value), hsl(from var(--surface-2) h s l/0.5) var(--range-to-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/var(--range-track-thickness) 100% no-repeat;
}
.input-container-range-double[orientation=vertical] > input[type=range][data-component=to]:not(:disabled)::-ms-track {
  background: linear-gradient(to top, hsl(from var(--surface-2) h s l/0.5) 0%, hsl(from var(--surface-2) h s l/0.5) var(--range-from-value), hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-from-value), hsl(from hsl(275, 100%, 69%) h s l/0.5) var(--range-to-value), hsl(from var(--surface-2) h s l/0.5) var(--range-to-value), hsl(from var(--surface-2) h s l/0.5) 100%) center/var(--range-track-thickness) 100% no-repeat;
}

.glass-border::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset: 0;
  border-radius: inherit;
  border: 1px solid transparent;
  background: linear-gradient(var(--border-1), var(--border-2)) border-box;
  mask: linear-gradient(black, black) border-box, linear-gradient(black, black) padding-box;
  mask-composite: subtract;
}

.card {
  border-radius: 1em;
  background: hsl(from var(--surface-3) h s l/0.25);
  backdrop-filter: blur(12px);
}
.card::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset: 0;
  border-radius: inherit;
  border: 1px solid transparent;
  background: linear-gradient(var(--border-1), var(--border-2)) border-box;
  mask: linear-gradient(black, black) border-box, linear-gradient(black, black) padding-box;
  mask-composite: subtract;
}

.hidden {
  display: none !important;
  opacity: 0 !important;
}

.info-container {
  border: none;
  border-radius: 0.75em;
  border-left: calc(0.75em - 1px) solid hsl(from var(--text-1) h s l/0.7);
  background-color: hsl(from var(--surface-2) h s l/0.5);
  display: flex;
  flex-direction: column;
  text-align: center;
  gap: 1rem;
  padding: 1rem;
}
.info-container[data-state=success] {
  border-left-color: hsl(from hsl(135, 64%, 50%) h s l/0.8);
  background: hsl(from hsl(135, 64%, 50%) h s l/0.05);
}
.info-container[data-state=success]::before {
  font-size: 1.5rem;
  font-weight: bold;
}
.info-container[data-state=error] {
  border-left-color: hsl(from hsl(352, 100%, 61%) h s l/0.8);
  background: hsl(from hsl(352, 100%, 61%) h s l/0.05);
}
.info-container[data-state=error]::before {
  font-size: 1.5rem;
  font-weight: bold;
}
.info-container[data-state=warning] {
  border-left-color: hsl(from hsl(48, 100%, 50%) h s l/0.8);
  background: hsl(from hsl(48, 100%, 50%) h s l/0.05);
}
.info-container[data-state=warning]::before {
  font-size: 1.5rem;
  font-weight: bold;
}
.info-container[data-state=success]::before {
  content: "✅ Success!";
}
.info-container[data-state=error]::before {
  content: "❌ Error!";
}
.info-container[data-state=warning]::before {
  content: "⚠️ Warning!";
}

.highlight {
  background-color: hsl(from hsl(204, 85%, 60%) h s l/0.9);
  animation: opacity-pulse 2s ease-in-out infinite;
}

.transition-bounds {
  transition: width 0.5s ease, height 0.5s ease;
  interpolate-size: allow-keywords;
}
@media (prefers-reduced-motion: reduce) {
  .transition-bounds {
    transition: none;
    interpolate-size: none;
  }
}

@keyframes fade-in {
  from {
    opacity: 0;
    transform: scale(0.9);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes fade-out {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(0.9);
  }
}
.transition-fade {
  --transition-fade-duration: 0.5s;
  animation-duration: var(--transition-fade-duration);
  animation-timing-function: ease;
}
.transition-fade[data-transition-fade=in] {
  animation-name: fade-in;
}
.transition-fade[data-transition-fade=out] {
  animation-name: fade-out;
}

@keyframes grain-fade {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
}
@keyframes opacity-pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.7;
  }
}
@keyframes scale-pulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(0.975);
  }
}
.scale-pulse {
  animation: scale-pulse 2s ease-in-out infinite;
}
@media (prefers-reduced-motion: reduce) {
  .scale-pulse {
    animation: none;
  }
}

#background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  inset: 0;
  isolation: isolate;
  pointer-events: none;
  background-color: var(--surface-1);
  background: radial-gradient(circle at bottom left, hsl(from hsl(204, 85%, 60%) h s l/0.2), transparent 20%), radial-gradient(circle at bottom right, hsl(from hsl(275, 100%, 69%) h s l/0.2), transparent 40%), var(--surface-1);
  background-size: cover;
  background-attachment: fixed;
}
#background::before, #background::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image: url("./noise.svg");
  background-repeat: repeat;
  background-size: 100px;
  mix-blend-mode: overlay;
  filter: contrast(220%) brightness(90%);
}
#background {
  /* TODO: Re-enable animation once performance impact issue is resolved.
   * Seems to heavily load the GPU at least on Firefox.
   * While this may be of no concern on desktop or Chrome (since chrome is the target browser),
   * it could have negative effects on battery life and performance on mobile devices.
   */
}
#background::after {
  background-position: 50px -50px;
  animation-delay: calc(-1 * 5s / 2);
}
@media (prefers-reduced-motion: reduce) {
  #background .grain::before,
  #background .grain::after {
    animation: none;
  }
}

#style-guide {
  padding: 15px 20px;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-content: flex-start;
  gap: 1rem;
}
#style-guide #container {
  position: fixed;
  left: 10dvw;
  right: 10dvw;
  bottom: 10dvw;
  height: 20dvw;
  display: flex;
  justify-content: center;
  align-items: center;
}
#style-guide > div {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  width: fit-content;
}
#style-guide > footer {
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.75rem;
}

#main-content {
  position: relative;
  display: flex;
  flex-direction: column;
  text-align: center;
  max-width: 100dvw;
  max-height: 100dvh;
}
#main-content:not(.fill-page) {
  width: fit-content;
  height: fit-content;
  padding: calc(100px / 2);
}
#main-content:not(.fill-page) > footer {
  top: calc(100% - 100px / 2);
  margin-top: 1rem;
}
#main-content.fill-page {
  width: 100dvw;
  height: 100dvh;
}
#main-content.fill-page > footer {
  display: none;
}
@media (min-width: 501px) and (min-height: 1001px) {
  #main-content.fill-page > footer {
    display: unset;
    top: calc(100% + 100px / 4);
    transform: translateY(-50%);
  }
}
@media (min-width: 501px) and (min-height: 1001px) {
  #main-content.fill-page {
    width: calc(100dvw - 100px);
    height: calc(100dvh - 100px);
  }
}

#control-screen {
  width: 100%;
  height: 100%;
  display: flex;
  flex-grow: 1;
  flex-direction: column;
  gap: 1rem;
}
#control-screen div.card {
  padding: 1rem;
}
@media (max-width: 500px), (max-height: 1000px) {
  #control-screen {
    border: none;
    border-radius: 0;
  }
}

#state-indicator::after {
  content: attr(data-text);
  margin-left: 0.2em;
}
#state-indicator[data-state=ok] > span {
  color: hsl(from hsl(135, 64%, 50%) h s l/1);
}
#state-indicator[data-state=warning] > span {
  color: hsl(from hsl(48, 100%, 50%) h s l/1);
}
#state-indicator[data-state=not-ready] > span {
  color: hsl(from hsl(352, 100%, 61%) h s l/1);
}
#state-indicator[data-state=processing] > span {
  color: hsl(from hsl(204, 85%, 60%) h s l/1);
}
#state-indicator[data-state=processing] > span {
  animation: opacity-pulse 2s ease-in-out infinite;
}
@media (prefers-reduced-motion: reduce) {
  #state-indicator[data-state=processing] > span {
    animation: none;
  }
}

.status {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.5rem 0.75rem !important;
}
.status > div {
  display: flex;
  gap: 0.5rem;
}
.status button {
  padding: 0.75rem 0.5rem;
}
.status button#stop-button {
  padding: 0.75rem 1.5rem;
  background-color: hsl(from hsl(352, 100%, 61%) h s l/0.7);
}
.status button:last-child {
  margin-right: -0.25rem;
}

#options-and-controls {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  gap: 1rem;
  user-select: none;
}
#options-and-controls > .options {
  flex: 1 1 auto;
  min-height: 0;
}
#options-and-controls > .controls {
  flex: 0 0 70%;
}
@media (orientation: landscape) {
  #options-and-controls {
    flex-direction: row;
  }
  #options-and-controls > .options {
    flex: 1 1 auto;
    min-width: 0;
  }
  #options-and-controls > .controls {
    flex: 0 0 70%;
  }
}

.options {
  display: flex;
}

#patterns-panel {
  display: flex;
  flex-direction: row;
  gap: 0.5rem;
  text-align: left;
}
#patterns-panel > div {
  flex: 1 1 0;
}
#patterns-panel > .pattern-list {
  display: flex;
  flex-direction: column;
  gap: inherit;
  overflow: hidden;
}
#patterns-panel > .pattern-list > #pattern-select {
  display: inherit;
  flex-direction: inherit;
  gap: inherit;
  min-height: 0;
  overflow-y: auto;
  scrollbar-gutter: stable;
}
#patterns-panel > .pattern-settings {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: inherit;
}
#patterns-panel > .pattern-settings > #description-text {
  margin-bottom: auto;
}
#patterns-panel > .pattern-settings > #apply-pattern-button {
  padding: 0.75rem;
}
@media (orientation: landscape) {
  #patterns-panel {
    flex-direction: column;
  }
}

#dashboard-panel {
  display: flex;
  flex: 1;
  flex-direction: column;
  justify-content: space-evenly;
  gap: 0.5rem;
}

.controls {
  height: 100%;
  display: grid;
  grid-template-rows: auto 1fr auto;
  grid-auto-flow: column;
  grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
  justify-items: center;
  justify-content: space-evenly;
  align-content: space-evenly;
  align-items: center;
  gap: 1rem;
}
.controls > div {
  min-width: 0;
  display: contents;
}
.controls > div > :nth-child(1) {
  display: flex;
  position: relative;
  grid-row: 1;
}
.controls > div > :nth-child(2) {
  display: flex;
  position: relative;
  grid-row: 2;
}
.controls > div > :nth-child(3) {
  display: flex;
  position: relative;
  grid-row: 3;
}
.controls > div > :nth-child(2) {
  width: 100%;
  height: 100%;
}
.controls > div > * {
  max-width: 6rem;
}
@media (orientation: landscape) {
  .controls {
    grid-template-rows: auto;
    grid-template-columns: auto 1fr auto;
  }
  .controls > div > :nth-child(1) {
    grid-column: 1;
    grid-row: auto;
  }
  .controls > div > :nth-child(2) {
    grid-column: 2;
    grid-row: auto;
  }
  .controls > div > :nth-child(3) {
    grid-column: 3;
    grid-row: auto;
  }
  .controls > div > :nth-child(2) {
    max-width: unset;
  }
}
.controls > div > :nth-child(2) {
  border-radius: 0.75em;
}
.controls > div > :nth-child(2) > .input-container-range-double,
.controls > div > :nth-child(2) > input[type=range] {
  flex: 1;
}
.controls > div > :nth-child(2) > .material-symbol {
  position: absolute;
  pointer-events: none;
  left: 50%;
  transform: translateX(-50%);
  color: hsl(from var(--text-1) h s l/0.7);
  bottom: min(10%, 3rem);
}
@media (orientation: landscape) {
  .controls > div > :nth-child(2) > .material-symbol {
    bottom: unset;
    top: 50%;
    left: min(15%, 2rem);
  }
}
.controls .invert-intensity {
  justify-content: center;
  font-size: 1.5em;
}
.controls .invert-intensity::after {
  width: 1.5em;
  height: 1.5em;
  line-height: 1.5em !important;
  transition: transform 0.4s ease, background-color 0.2s ease;
}
.controls .invert-intensity:checked::after {
  transform: rotateY(180deg);
}

/*# sourceMappingURL=styles.css.map */
