@charset "UTF-8";
/**
 * ====================================================================
 * Theme colours
 * You can overwrite the accent colours here, as well as define new
 * colours
 * ====================================================================
 */
/** Base Colors */
/** ----------------------------------- */
/**
 * Section 1
 * ====================================================================
 * Colours
 * These colours are used for the main body and container backgrounds
 * ====================================================================
 */
/** Light -------------------------- */
/** Dark --------------------------- */
/**
 * Section 2
 * ====================================================================
 * Variables
 * These colours are used for the main body and container backgrounds
 * ====================================================================
 */
/** Synonyms */
/** Theming Maps */
@media (prefers-color-scheme: light) {
  :root {
    --pt-shadow-container: 0 0 3px -2px rgba(0, 0, 0, 0.7);
    --pt-shadow-control: 0 0 4px -1px rgba(0, 0, 0, 0.7);
    --pt-grey-1: hsl(0, 0%, 100%);
    --pt-grey-bg: hsl(0, 0%, 97.5%);
    --pt-grey-2: hsl(0, 0%, 95%);
    --pt-grey-3: hsl(0, 0%, 90%);
    --pt-grey-4: hsl(0, 0%, 75%);
    --pt-grey-5: hsl(0, 0%, 60%);
    --pt-border-grey: hsl(0, 0%, 60%);
    --pt-grey-6: hsl(0, 0%, 40%);
    --pt-grey-7: hsl(0, 0%, 20%);
    --pt-grey-8: hsl(0, 0%, 10%);
    --grey-button-top: hsl(0, 0%, 95%);
    --grey-button-bot: hsl(0, 0%, 75%);
    --grey-hl-button-top: hsl(0, 0%, 90%);
    --grey-hl-button-bot: hsl(0, 0%, 60%);
    --pt-accent-1: hsl(180, 80%, 90%);
    --pt-accent-2: hsl(180, 80%, 75%);
    --pt-accent-3: hsl(180, 80%, 60%);
    --pt-accent-4: hsl(180, 80%, 40%);
    --pt-accent-5: hsl(180, 80%, 20%);
    --pt-accent-button-top: hsl(180, 80%, 75%);
    --pt-accent-button-bot: hsl(180, 80%, 60%);
    --pt-accent-hl-button-top: hsl(180, 80%, 60%);
    --pt-accent-hl-button-bot: hsl(180, 80%, 40%);
    --pt-info-1: hsl(210, 100%, 90%);
    --pt-info-2: hsl(210, 100%, 75%);
    --pt-info-3: hsl(210, 100%, 60%);
    --pt-info-4: hsl(210, 100%, 40%);
    --pt-info-5: hsl(210, 100%, 20%);
    --pt-info-button-top: hsl(210, 100%, 75%);
    --pt-info-button-bot: hsl(210, 100%, 60%);
    --pt-info-hl-button-top: hsl(210, 100%, 60%);
    --pt-info-hl-button-bot: hsl(210, 100%, 40%);
    --pt-warning-1: hsl(40, 100%, 90%);
    --pt-warning-2: hsl(40, 100%, 75%);
    --pt-warning-3: hsl(40, 100%, 60%);
    --pt-warning-4: hsl(40, 100%, 40%);
    --pt-warning-5: hsl(40, 100%, 20%);
    --pt-warning-button-top: hsl(40, 100%, 75%);
    --pt-warning-button-bot: hsl(40, 100%, 60%);
    --pt-warning-hl-button-top: hsl(40, 100%, 60%);
    --pt-warning-hl-button-bot: hsl(40, 100%, 40%);
    --pt-critical-1: hsl(0, 100%, 90%);
    --pt-critical-2: hsl(0, 100%, 75%);
    --pt-critical-3: hsl(0, 100%, 60%);
    --pt-critical-4: hsl(0, 100%, 40%);
    --pt-critical-5: hsl(0, 100%, 20%);
    --pt-critical-button-top: hsl(0, 100%, 75%);
    --pt-critical-button-bot: hsl(0, 100%, 60%);
    --pt-critical-hl-button-top: hsl(0, 100%, 60%);
    --pt-critical-hl-button-bot: hsl(0, 100%, 40%);
    --pt-good-1: hsl(152, 70%, 90%);
    --pt-good-2: hsl(152, 70%, 75%);
    --pt-good-3: hsl(152, 70%, 60%);
    --pt-good-4: hsl(152, 70%, 40%);
    --pt-good-5: hsl(152, 70%, 20%);
    --pt-good-button-top: hsl(152, 70%, 75%);
    --pt-good-button-bot: hsl(152, 70%, 60%);
    --pt-good-hl-button-top: hsl(152, 70%, 60%);
    --pt-good-hl-button-bot: hsl(152, 70%, 40%);
  }
}
@media (prefers-color-scheme: dark) {
  :root {
    --pt-shadow-container: 0 0 3px -2px rgb(0, 0, 0);
    --pt-shadow-control: 0 0 4px -1px rgb(0, 0, 0);
    --pt-grey-1: hsl(0, 0%, 5%);
    --pt-grey-bg: hsl(0, 0%, 7.5%);
    --pt-grey-2: hsl(0, 0%, 10%);
    --pt-grey-3: hsl(0, 0%, 15%);
    --pt-grey-4: hsl(0, 0%, 30%);
    --pt-grey-5: hsl(0, 0%, 45%);
    --pt-border-grey: hsl(0, 0%, 45%);
    --pt-grey-6: hsl(0, 0%, 65%);
    --pt-grey-7: hsl(0, 0%, 85%);
    --pt-grey-8: hsl(0, 0%, 95%);
    --grey-button-top: hsl(0, 0%, 30%);
    --grey-button-bot: hsl(0, 0%, 10%);
    --grey-hl-button-top: hsl(0, 0%, 45%);
    --grey-hl-button-bot: hsl(0, 0%, 15%);
    --pt-accent-1: hsl(180, 80%, 10%);
    --pt-accent-2: hsl(180, 80%, 25%);
    --pt-accent-3: hsl(180, 80%, 40%);
    --pt-accent-4: hsl(180, 80%, 60%);
    --pt-accent-5: hsl(180, 80%, 80%);
    --pt-accent-button-top: hsl(180, 80%, 40%);
    --pt-accent-button-bot: hsl(180, 80%, 25%);
    --pt-accent-hl-button-top: hsl(180, 80%, 60%);
    --pt-accent-hl-button-bot: hsl(180, 80%, 40%);
    --pt-info-1: hsl(210, 100%, 10%);
    --pt-info-2: hsl(210, 100%, 25%);
    --pt-info-3: hsl(210, 100%, 40%);
    --pt-info-4: hsl(210, 100%, 60%);
    --pt-info-5: hsl(210, 100%, 20%);
    --pt-info-button-top: hsl(210, 100%, 40%);
    --pt-info-button-bot: hsl(210, 100%, 25%);
    --pt-info-hl-button-top: hsl(210, 100%, 60%);
    --pt-info-hl-button-bot: hsl(210, 100%, 40%);
    --pt-warning-1: hsl(40, 100%, 10%);
    --pt-warning-2: hsl(40, 100%, 25%);
    --pt-warning-3: hsl(40, 100%, 40%);
    --pt-warning-4: hsl(40, 100%, 60%);
    --pt-warning-5: hsl(40, 100%, 80%);
    --pt-warning-button-top: hsl(40, 100%, 40%);
    --pt-warning-button-bot: hsl(40, 100%, 25%);
    --pt-warning-hl-button-top: hsl(40, 100%, 60%);
    --pt-warning-hl-button-bot: hsl(40, 100%, 40%);
    --pt-critical-1: hsl(0, 100%, 10%);
    --pt-critical-2: hsl(0, 100%, 25%);
    --pt-critical-3: hsl(0, 100%, 40%);
    --pt-critical-4: hsl(0, 100%, 60%);
    --pt-critical-5: hsl(0, 100%, 80%);
    --pt-critical-button-top: hsl(0, 100%, 40%);
    --pt-critical-button-bot: hsl(0, 100%, 25%);
    --pt-critical-hl-button-top: hsl(0, 100%, 60%);
    --pt-critical-hl-button-bot: hsl(0, 100%, 40%);
    --pt-good-1: hsl(152, 70%, 10%);
    --pt-good-2: hsl(152, 70%, 25%);
    --pt-good-3: hsl(152, 70%, 40%);
    --pt-good-4: hsl(152, 70%, 60%);
    --pt-good-5: hsl(152, 70%, 80%);
    --pt-good-button-top: hsl(152, 70%, 40%);
    --pt-good-button-bot: hsl(152, 70%, 25%);
    --pt-good-hl-button-top: hsl(152, 70%, 60%);
    --pt-good-hl-button-bot: hsl(152, 70%, 40%);
  }
}
:root body.light {
  --pt-shadow-container: 0 0 3px -2px rgba(0, 0, 0, 0.7);
  --pt-shadow-control: 0 0 4px -1px rgba(0, 0, 0, 0.7);
  --pt-grey-1: hsl(0, 0%, 100%);
  --pt-grey-bg: hsl(0, 0%, 97.5%);
  --pt-grey-2: hsl(0, 0%, 95%);
  --pt-grey-3: hsl(0, 0%, 90%);
  --pt-grey-4: hsl(0, 0%, 75%);
  --pt-grey-5: hsl(0, 0%, 60%);
  --pt-border-grey: hsl(0, 0%, 60%);
  --pt-grey-6: hsl(0, 0%, 40%);
  --pt-grey-7: hsl(0, 0%, 20%);
  --pt-grey-8: hsl(0, 0%, 10%);
  --grey-button-top: hsl(0, 0%, 95%);
  --grey-button-bot: hsl(0, 0%, 75%);
  --grey-hl-button-top: hsl(0, 0%, 90%);
  --grey-hl-button-bot: hsl(0, 0%, 60%);
  --pt-accent-1: hsl(180, 80%, 90%);
  --pt-accent-2: hsl(180, 80%, 75%);
  --pt-accent-3: hsl(180, 80%, 60%);
  --pt-accent-4: hsl(180, 80%, 40%);
  --pt-accent-5: hsl(180, 80%, 20%);
  --pt-accent-button-top: hsl(180, 80%, 75%);
  --pt-accent-button-bot: hsl(180, 80%, 60%);
  --pt-accent-hl-button-top: hsl(180, 80%, 60%);
  --pt-accent-hl-button-bot: hsl(180, 80%, 40%);
  --pt-info-1: hsl(210, 100%, 90%);
  --pt-info-2: hsl(210, 100%, 75%);
  --pt-info-3: hsl(210, 100%, 60%);
  --pt-info-4: hsl(210, 100%, 40%);
  --pt-info-5: hsl(210, 100%, 20%);
  --pt-info-button-top: hsl(210, 100%, 75%);
  --pt-info-button-bot: hsl(210, 100%, 60%);
  --pt-info-hl-button-top: hsl(210, 100%, 60%);
  --pt-info-hl-button-bot: hsl(210, 100%, 40%);
  --pt-warning-1: hsl(40, 100%, 90%);
  --pt-warning-2: hsl(40, 100%, 75%);
  --pt-warning-3: hsl(40, 100%, 60%);
  --pt-warning-4: hsl(40, 100%, 40%);
  --pt-warning-5: hsl(40, 100%, 20%);
  --pt-warning-button-top: hsl(40, 100%, 75%);
  --pt-warning-button-bot: hsl(40, 100%, 60%);
  --pt-warning-hl-button-top: hsl(40, 100%, 60%);
  --pt-warning-hl-button-bot: hsl(40, 100%, 40%);
  --pt-critical-1: hsl(0, 100%, 90%);
  --pt-critical-2: hsl(0, 100%, 75%);
  --pt-critical-3: hsl(0, 100%, 60%);
  --pt-critical-4: hsl(0, 100%, 40%);
  --pt-critical-5: hsl(0, 100%, 20%);
  --pt-critical-button-top: hsl(0, 100%, 75%);
  --pt-critical-button-bot: hsl(0, 100%, 60%);
  --pt-critical-hl-button-top: hsl(0, 100%, 60%);
  --pt-critical-hl-button-bot: hsl(0, 100%, 40%);
  --pt-good-1: hsl(152, 70%, 90%);
  --pt-good-2: hsl(152, 70%, 75%);
  --pt-good-3: hsl(152, 70%, 60%);
  --pt-good-4: hsl(152, 70%, 40%);
  --pt-good-5: hsl(152, 70%, 20%);
  --pt-good-button-top: hsl(152, 70%, 75%);
  --pt-good-button-bot: hsl(152, 70%, 60%);
  --pt-good-hl-button-top: hsl(152, 70%, 60%);
  --pt-good-hl-button-bot: hsl(152, 70%, 40%);
}

:root body.dark {
  --pt-shadow-container: 0 0 3px -2px rgb(0, 0, 0);
  --pt-shadow-control: 0 0 4px -1px rgb(0, 0, 0);
  --pt-grey-1: hsl(0, 0%, 5%);
  --pt-grey-bg: hsl(0, 0%, 7.5%);
  --pt-grey-2: hsl(0, 0%, 10%);
  --pt-grey-3: hsl(0, 0%, 15%);
  --pt-grey-4: hsl(0, 0%, 30%);
  --pt-grey-5: hsl(0, 0%, 45%);
  --pt-border-grey: hsl(0, 0%, 45%);
  --pt-grey-6: hsl(0, 0%, 65%);
  --pt-grey-7: hsl(0, 0%, 85%);
  --pt-grey-8: hsl(0, 0%, 95%);
  --grey-button-top: hsl(0, 0%, 30%);
  --grey-button-bot: hsl(0, 0%, 10%);
  --grey-hl-button-top: hsl(0, 0%, 45%);
  --grey-hl-button-bot: hsl(0, 0%, 15%);
  --pt-accent-1: hsl(180, 80%, 10%);
  --pt-accent-2: hsl(180, 80%, 25%);
  --pt-accent-3: hsl(180, 80%, 40%);
  --pt-accent-4: hsl(180, 80%, 60%);
  --pt-accent-5: hsl(180, 80%, 80%);
  --pt-accent-button-top: hsl(180, 80%, 40%);
  --pt-accent-button-bot: hsl(180, 80%, 25%);
  --pt-accent-hl-button-top: hsl(180, 80%, 60%);
  --pt-accent-hl-button-bot: hsl(180, 80%, 40%);
  --pt-info-1: hsl(210, 100%, 10%);
  --pt-info-2: hsl(210, 100%, 25%);
  --pt-info-3: hsl(210, 100%, 40%);
  --pt-info-4: hsl(210, 100%, 60%);
  --pt-info-5: hsl(210, 100%, 20%);
  --pt-info-button-top: hsl(210, 100%, 40%);
  --pt-info-button-bot: hsl(210, 100%, 25%);
  --pt-info-hl-button-top: hsl(210, 100%, 60%);
  --pt-info-hl-button-bot: hsl(210, 100%, 40%);
  --pt-warning-1: hsl(40, 100%, 10%);
  --pt-warning-2: hsl(40, 100%, 25%);
  --pt-warning-3: hsl(40, 100%, 40%);
  --pt-warning-4: hsl(40, 100%, 60%);
  --pt-warning-5: hsl(40, 100%, 80%);
  --pt-warning-button-top: hsl(40, 100%, 40%);
  --pt-warning-button-bot: hsl(40, 100%, 25%);
  --pt-warning-hl-button-top: hsl(40, 100%, 60%);
  --pt-warning-hl-button-bot: hsl(40, 100%, 40%);
  --pt-critical-1: hsl(0, 100%, 10%);
  --pt-critical-2: hsl(0, 100%, 25%);
  --pt-critical-3: hsl(0, 100%, 40%);
  --pt-critical-4: hsl(0, 100%, 60%);
  --pt-critical-5: hsl(0, 100%, 80%);
  --pt-critical-button-top: hsl(0, 100%, 40%);
  --pt-critical-button-bot: hsl(0, 100%, 25%);
  --pt-critical-hl-button-top: hsl(0, 100%, 60%);
  --pt-critical-hl-button-bot: hsl(0, 100%, 40%);
  --pt-good-1: hsl(152, 70%, 10%);
  --pt-good-2: hsl(152, 70%, 25%);
  --pt-good-3: hsl(152, 70%, 40%);
  --pt-good-4: hsl(152, 70%, 60%);
  --pt-good-5: hsl(152, 70%, 80%);
  --pt-good-button-top: hsl(152, 70%, 40%);
  --pt-good-button-bot: hsl(152, 70%, 25%);
  --pt-good-hl-button-top: hsl(152, 70%, 60%);
  --pt-good-hl-button-bot: hsl(152, 70%, 40%);
}

/**
 * ==================================================================
 * Reset
 * ==================================================================
 */
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
.a11i-hidden:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(100%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

/** Controls */
/** ============================================= */
/** Text Headers */
/** Text Bodies */
/** Variables */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 1rem;
  vertical-align: baseline;
  color: inherit;
  z-index: 0;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

/** Body */
body {
  line-height: 1.125;
  font-size: 16px;
  background: var(--pt-grey-bg);
  color: var(--pt-grey-8);
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/** a11y */
a:focus-visible:not(:disabled), button:focus-visible:not(:disabled), select:focus-visible:not(:disabled), input:focus-visible:not(:disabled), textarea:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}

/** Basic formatting */
strong, b {
  font-weight: bold;
}

em, i {
  font-style: italic;
}

kbd {
  background-color: var(--kbd-color-background);
  color: var(--pt-text);
  background: var(--pt-container-bg);
  border-radius: 0.25rem;
  border: 1px solid var(--pt-border);
  box-shadow: 0 2px 0 1px var(--pt-border);
  font-size: 0.75em;
  line-height: 1;
  display: inline-block;
  text-align: center;
  padding: 2px 5px;
  position: relative;
  top: -0.25rem;
}

.a11i-hidden:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(100%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

/**
 * Section 1
 * ====================================================================
 * Content
 * ====================================================================
 */
.field-label {
  display: block;
  margin-bottom: 4px;
  font-weight: bold;
  font-size: 0.875rem;
}

/**
 * Section 2
 * ====================================================================
 * Controls
 * ====================================================================
 */
.a11i-hidden:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(100%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.button-high-affordance:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.button-high-affordance {
  min-width: 44px;
  min-height: 44px;
}
.button-high-affordance.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.button-high-affordance.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.button-high-affordance.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.button-high-affordance.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.button-high-affordance {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: solid;
  border-width: 1px;
  border-block-end-width: 3px;
}
.button-high-affordance:disabled {
  border-width: 1px;
}
.button-high-affordance {
  line-height: 24px;
  justify-content: center;
}
.button-high-affordance svg {
  width: 24px;
  height: 24px;
}
.button-high-affordance {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: bold;
  color: var(--pt-grey-8);
}
.button-high-affordance svg {
  fill: currentColor;
}
.button-high-affordance:hover:not(:disabled) {
  cursor: pointer;
}
.button-high-affordance:active:not(:disabled) {
  box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.7) inset;
  border-block-end-width: 1px;
}
.button-high-affordance:disabled {
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border: none;
}
.button-high-affordance {
  background: var(--pt-grey-4);
  background: linear-gradient(0deg, var(--grey-button-bot) 35%, var(--grey-button-top) 100%);
  border-color: var(--pt-grey-5);
}
.button-high-affordance:hover:not(:disabled) {
  background: var(--pt-grey-5);
  background: linear-gradient(0deg, var(--grey-hl-button-bot) 35%, var(--grey-hl-button-top) 100%);
  border-color: var(--pt-grey-6);
}
.button-high-affordance:active:not(:disabled) {
  background: var(--pt-grey-2);
  background: linear-gradient(0deg, var(--grey-hl-button-top) 35%, var(--grey-hl-button-bot) 100%);
  border-color: var(--pt-grey-6);
}

.button-accent-high-affordance:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.button-accent-high-affordance {
  min-width: 44px;
  min-height: 44px;
}
.button-accent-high-affordance.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.button-accent-high-affordance.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.button-accent-high-affordance.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.button-accent-high-affordance.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.button-accent-high-affordance {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: solid;
  border-width: 1px;
  border-block-end-width: 3px;
}
.button-accent-high-affordance:disabled {
  border-width: 1px;
}
.button-accent-high-affordance {
  line-height: 24px;
  justify-content: center;
}
.button-accent-high-affordance svg {
  width: 24px;
  height: 24px;
}
.button-accent-high-affordance {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: bold;
  color: var(--pt-grey-8);
}
.button-accent-high-affordance svg {
  fill: currentColor;
}
.button-accent-high-affordance:hover:not(:disabled) {
  cursor: pointer;
}
.button-accent-high-affordance:active:not(:disabled) {
  box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.7) inset;
  border-block-end-width: 1px;
}
.button-accent-high-affordance:disabled {
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border: none;
}
.button-accent-high-affordance {
  background: var(--pt-accent-2);
  background: linear-gradient(0deg, var(--pt-accent-button-bot) 30%, var(--pt-accent-button-top) 100%);
  border-color: var(--pt-accent-4);
}
.button-accent-high-affordance:hover:not(:disabled) {
  background: var(--pt-accent-3);
  background: linear-gradient(0deg, var(--pt-accent-hl-button-bot) 30%, var(--pt-accent-hl-button-top) 100%);
  border-color: var(--pt-accent-5);
}
.button-accent-high-affordance:active:not(:disabled) {
  background: var(--pt-accent-1);
  background: linear-gradient(0deg, var(--pt-accent-hl-button-top) 30%, var(--pt-accent-hl-button-bot) 100%);
  border-color: var(--pt-accent-5);
}

.button-info-high-affordance:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.button-info-high-affordance {
  min-width: 44px;
  min-height: 44px;
}
.button-info-high-affordance.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.button-info-high-affordance.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.button-info-high-affordance.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.button-info-high-affordance.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.button-info-high-affordance {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: solid;
  border-width: 1px;
  border-block-end-width: 3px;
}
.button-info-high-affordance:disabled {
  border-width: 1px;
}
.button-info-high-affordance {
  line-height: 24px;
  justify-content: center;
}
.button-info-high-affordance svg {
  width: 24px;
  height: 24px;
}
.button-info-high-affordance {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: bold;
  color: var(--pt-grey-8);
}
.button-info-high-affordance svg {
  fill: currentColor;
}
.button-info-high-affordance:hover:not(:disabled) {
  cursor: pointer;
}
.button-info-high-affordance:active:not(:disabled) {
  box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.7) inset;
  border-block-end-width: 1px;
}
.button-info-high-affordance:disabled {
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border: none;
}
.button-info-high-affordance {
  background: var(--pt-info-2);
  background: linear-gradient(0deg, var(--pt-info-button-bot) 30%, var(--pt-info-button-top) 100%);
  border-color: var(--pt-info-4);
}
.button-info-high-affordance:hover:not(:disabled) {
  background: var(--pt-info-3);
  background: linear-gradient(0deg, var(--pt-info-hl-button-bot) 30%, var(--pt-info-hl-button-top) 100%);
  border-color: var(--pt-info-5);
}
.button-info-high-affordance:active:not(:disabled) {
  background: var(--pt-info-1);
  background: linear-gradient(0deg, var(--pt-info-hl-button-top) 30%, var(--pt-info-hl-button-bot) 100%);
  border-color: var(--pt-info-5);
}

.button-warning-high-affordance:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.button-warning-high-affordance {
  min-width: 44px;
  min-height: 44px;
}
.button-warning-high-affordance.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.button-warning-high-affordance.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.button-warning-high-affordance.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.button-warning-high-affordance.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.button-warning-high-affordance {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: solid;
  border-width: 1px;
  border-block-end-width: 3px;
}
.button-warning-high-affordance:disabled {
  border-width: 1px;
}
.button-warning-high-affordance {
  line-height: 24px;
  justify-content: center;
}
.button-warning-high-affordance svg {
  width: 24px;
  height: 24px;
}
.button-warning-high-affordance {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: bold;
  color: var(--pt-grey-8);
}
.button-warning-high-affordance svg {
  fill: currentColor;
}
.button-warning-high-affordance:hover:not(:disabled) {
  cursor: pointer;
}
.button-warning-high-affordance:active:not(:disabled) {
  box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.7) inset;
  border-block-end-width: 1px;
}
.button-warning-high-affordance:disabled {
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border: none;
}
.button-warning-high-affordance {
  background: var(--pt-warning-2);
  background: linear-gradient(0deg, var(--pt-warning-button-bot) 30%, var(--pt-warning-button-top) 100%);
  border-color: var(--pt-warning-4);
}
.button-warning-high-affordance:hover:not(:disabled) {
  background: var(--pt-warning-3);
  background: linear-gradient(0deg, var(--pt-warning-hl-button-bot) 30%, var(--pt-warning-hl-button-top) 100%);
  border-color: var(--pt-warning-5);
}
.button-warning-high-affordance:active:not(:disabled) {
  background: var(--pt-warning-1);
  background: linear-gradient(0deg, var(--pt-warning-hl-button-top) 30%, var(--pt-warning-hl-button-bot) 100%);
  border-color: var(--pt-warning-5);
}

.button-critical-high-affordance:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.button-critical-high-affordance {
  min-width: 44px;
  min-height: 44px;
}
.button-critical-high-affordance.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.button-critical-high-affordance.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.button-critical-high-affordance.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.button-critical-high-affordance.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.button-critical-high-affordance {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: solid;
  border-width: 1px;
  border-block-end-width: 3px;
}
.button-critical-high-affordance:disabled {
  border-width: 1px;
}
.button-critical-high-affordance {
  line-height: 24px;
  justify-content: center;
}
.button-critical-high-affordance svg {
  width: 24px;
  height: 24px;
}
.button-critical-high-affordance {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: bold;
  color: var(--pt-grey-8);
}
.button-critical-high-affordance svg {
  fill: currentColor;
}
.button-critical-high-affordance:hover:not(:disabled) {
  cursor: pointer;
}
.button-critical-high-affordance:active:not(:disabled) {
  box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.7) inset;
  border-block-end-width: 1px;
}
.button-critical-high-affordance:disabled {
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border: none;
}
.button-critical-high-affordance {
  background: var(--pt-critical-2);
  background: linear-gradient(0deg, var(--pt-critical-button-bot) 30%, var(--pt-critical-button-top) 100%);
  border-color: var(--pt-critical-4);
}
.button-critical-high-affordance:hover:not(:disabled) {
  background: var(--pt-critical-3);
  background: linear-gradient(0deg, var(--pt-critical-hl-button-bot) 30%, var(--pt-critical-hl-button-top) 100%);
  border-color: var(--pt-critical-5);
}
.button-critical-high-affordance:active:not(:disabled) {
  background: var(--pt-critical-1);
  background: linear-gradient(0deg, var(--pt-critical-hl-button-top) 30%, var(--pt-critical-hl-button-bot) 100%);
  border-color: var(--pt-critical-5);
}

.button-good-high-affordance:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.button-good-high-affordance {
  min-width: 44px;
  min-height: 44px;
}
.button-good-high-affordance.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.button-good-high-affordance.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.button-good-high-affordance.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.button-good-high-affordance.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.button-good-high-affordance {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: solid;
  border-width: 1px;
  border-block-end-width: 3px;
}
.button-good-high-affordance:disabled {
  border-width: 1px;
}
.button-good-high-affordance {
  line-height: 24px;
  justify-content: center;
}
.button-good-high-affordance svg {
  width: 24px;
  height: 24px;
}
.button-good-high-affordance {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: bold;
  color: var(--pt-grey-8);
}
.button-good-high-affordance svg {
  fill: currentColor;
}
.button-good-high-affordance:hover:not(:disabled) {
  cursor: pointer;
}
.button-good-high-affordance:active:not(:disabled) {
  box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.7) inset;
  border-block-end-width: 1px;
}
.button-good-high-affordance:disabled {
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border: none;
}
.button-good-high-affordance {
  background: var(--pt-good-2);
  background: linear-gradient(0deg, var(--pt-good-button-bot) 30%, var(--pt-good-button-top) 100%);
  border-color: var(--pt-good-4);
}
.button-good-high-affordance:hover:not(:disabled) {
  background: var(--pt-good-3);
  background: linear-gradient(0deg, var(--pt-good-hl-button-bot) 30%, var(--pt-good-hl-button-top) 100%);
  border-color: var(--pt-good-5);
}
.button-good-high-affordance:active:not(:disabled) {
  background: var(--pt-good-1);
  background: linear-gradient(0deg, var(--pt-good-hl-button-top) 30%, var(--pt-good-hl-button-bot) 100%);
  border-color: var(--pt-good-5);
}

.button:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.button {
  min-width: 44px;
  min-height: 44px;
}
.button.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.button.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.button.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.button.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.button {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: none;
  line-height: 24px;
  justify-content: center;
}
.button svg {
  width: 24px;
  height: 24px;
}
.button {
  border-radius: 8px;
  border-width: 0;
  border-bottom-width: 3px;
  border-bottom-style: solid;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: bold;
  color: var(--pt-grey-8);
}
.button svg {
  fill: currentColor;
}
.button:hover:not(:disabled) {
  cursor: pointer;
}
.button:active:not(:disabled) {
  border-bottom-width: 0;
  border-bottom-style: none;
  box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.7) inset;
}
.button:disabled {
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border: none;
}
.button {
  background: rgba(0, 0, 0, 0.125);
  border-bottom-color: var(--pt-grey-4);
}
.button:hover:not(:disabled) {
  background: var(--pt-grey-4);
  background: rgba(0, 0, 0, 0.2);
}
.button:active:not(:disabled) {
  background: var(--pt-grey-2);
  background: rgba(0, 0, 0, 0.1);
}

.button-accent:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.button-accent {
  min-width: 44px;
  min-height: 44px;
}
.button-accent.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.button-accent.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.button-accent.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.button-accent.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.button-accent {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: none;
  line-height: 24px;
  justify-content: center;
}
.button-accent svg {
  width: 24px;
  height: 24px;
}
.button-accent {
  border-radius: 8px;
  border-width: 0;
  border-bottom-width: 3px;
  border-bottom-style: solid;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: bold;
  color: var(--pt-grey-8);
}
.button-accent svg {
  fill: currentColor;
}
.button-accent:hover:not(:disabled) {
  cursor: pointer;
}
.button-accent:active:not(:disabled) {
  border-bottom-width: 0;
  border-bottom-style: none;
  box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.7) inset;
}
.button-accent:disabled {
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border: none;
}
.button-accent {
  background: var(--pt-accent-2);
  border-bottom-color: var(--pt-accent-4);
}
.button-accent:hover:not(:disabled) {
  background: var(--pt-accent-3);
}
.button-accent:active:not(:disabled) {
  background: var(--pt-accent-1);
}

.button-info:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.button-info {
  min-width: 44px;
  min-height: 44px;
}
.button-info.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.button-info.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.button-info.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.button-info.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.button-info {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: none;
  line-height: 24px;
  justify-content: center;
}
.button-info svg {
  width: 24px;
  height: 24px;
}
.button-info {
  border-radius: 8px;
  border-width: 0;
  border-bottom-width: 3px;
  border-bottom-style: solid;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: bold;
  color: var(--pt-grey-8);
}
.button-info svg {
  fill: currentColor;
}
.button-info:hover:not(:disabled) {
  cursor: pointer;
}
.button-info:active:not(:disabled) {
  border-bottom-width: 0;
  border-bottom-style: none;
  box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.7) inset;
}
.button-info:disabled {
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border: none;
}
.button-info {
  background: var(--pt-info-2);
  border-bottom-color: var(--pt-info-4);
}
.button-info:hover:not(:disabled) {
  background: var(--pt-info-3);
}
.button-info:active:not(:disabled) {
  background: var(--pt-info-1);
}

.button-warning:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.button-warning {
  min-width: 44px;
  min-height: 44px;
}
.button-warning.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.button-warning.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.button-warning.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.button-warning.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.button-warning {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: none;
  line-height: 24px;
  justify-content: center;
}
.button-warning svg {
  width: 24px;
  height: 24px;
}
.button-warning {
  border-radius: 8px;
  border-width: 0;
  border-bottom-width: 3px;
  border-bottom-style: solid;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: bold;
  color: var(--pt-grey-8);
}
.button-warning svg {
  fill: currentColor;
}
.button-warning:hover:not(:disabled) {
  cursor: pointer;
}
.button-warning:active:not(:disabled) {
  border-bottom-width: 0;
  border-bottom-style: none;
  box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.7) inset;
}
.button-warning:disabled {
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border: none;
}
.button-warning {
  background: var(--pt-warning-2);
  border-bottom-color: var(--pt-warning-4);
}
.button-warning:hover:not(:disabled) {
  background: var(--pt-warning-3);
}
.button-warning:active:not(:disabled) {
  background: var(--pt-warning-1);
}

.button-critical:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.button-critical {
  min-width: 44px;
  min-height: 44px;
}
.button-critical.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.button-critical.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.button-critical.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.button-critical.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.button-critical {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: none;
  line-height: 24px;
  justify-content: center;
}
.button-critical svg {
  width: 24px;
  height: 24px;
}
.button-critical {
  border-radius: 8px;
  border-width: 0;
  border-bottom-width: 3px;
  border-bottom-style: solid;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: bold;
  color: var(--pt-grey-8);
}
.button-critical svg {
  fill: currentColor;
}
.button-critical:hover:not(:disabled) {
  cursor: pointer;
}
.button-critical:active:not(:disabled) {
  border-bottom-width: 0;
  border-bottom-style: none;
  box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.7) inset;
}
.button-critical:disabled {
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border: none;
}
.button-critical {
  background: var(--pt-critical-2);
  border-bottom-color: var(--pt-critical-4);
}
.button-critical:hover:not(:disabled) {
  background: var(--pt-critical-3);
}
.button-critical:active:not(:disabled) {
  background: var(--pt-critical-1);
}

.button-good:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.button-good {
  min-width: 44px;
  min-height: 44px;
}
.button-good.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.button-good.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.button-good.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.button-good.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.button-good {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: none;
  line-height: 24px;
  justify-content: center;
}
.button-good svg {
  width: 24px;
  height: 24px;
}
.button-good {
  border-radius: 8px;
  border-width: 0;
  border-bottom-width: 3px;
  border-bottom-style: solid;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: bold;
  color: var(--pt-grey-8);
}
.button-good svg {
  fill: currentColor;
}
.button-good:hover:not(:disabled) {
  cursor: pointer;
}
.button-good:active:not(:disabled) {
  border-bottom-width: 0;
  border-bottom-style: none;
  box-shadow: 0 0 4px -1px rgba(0, 0, 0, 0.7) inset;
}
.button-good:disabled {
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border: none;
}
.button-good {
  background: var(--pt-good-2);
  border-bottom-color: var(--pt-good-4);
}
.button-good:hover:not(:disabled) {
  background: var(--pt-good-3);
}
.button-good:active:not(:disabled) {
  background: var(--pt-good-1);
}

.a11i-hidden:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(100%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

/** deprecated */
.text-input-high-affordance:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.text-input-high-affordance {
  min-width: 44px;
  min-height: 44px;
}
.text-input-high-affordance.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.text-input-high-affordance.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.text-input-high-affordance.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.text-input-high-affordance.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.text-input-high-affordance {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: none;
  line-height: 24px;
  justify-content: center;
}
.text-input-high-affordance svg {
  width: 24px;
  height: 24px;
}
.text-input-high-affordance {
  display: inline-block;
  font-weight: normal;
  color: var(--pt-grey-8);
  background: var(--pt-grey-1);
  border-color: var(--pt-grey-5);
}
.text-input-high-affordance svg {
  fill: currentColor;
}
.text-input-high-affordance:hover:not(:disabled) {
  cursor: text;
  border-color: var(--pt-grey-6);
}
.text-input-high-affordance:active:not(:disabled), .text-input-high-affordance:focus:not(:disabled) {
  outline: none;
  box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.7) inset;
  border-color: var(--pt-grey-6);
  border-width: 1px;
}
.text-input-high-affordance:disabled {
  box-shadow: none;
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border-block-end-width: 1px;
}

.text-input:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.text-input {
  min-width: 44px;
  min-height: 44px;
}
.text-input.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.text-input.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.text-input.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.text-input.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.text-input {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: none;
  line-height: 24px;
  justify-content: center;
}
.text-input svg {
  width: 24px;
  height: 24px;
}
.text-input {
  background: var(--pt-grey-3);
  color: var(--pt-grey-8);
  background-color: rgba(0, 0, 0, 0.125);
}
.text-input:hover:not(:disabled):not(:active):not(:focus) {
  background-color: rgba(0, 0, 0, 0.2);
}
.text-input:disabled {
  box-shadow: none;
  background: none;
  border-color: var(--pt-grey-5);
  color: var(--pt-grey-6);
  cursor: no-drop;
}
.text-input:focus {
  outline: none;
  border-color: var(--pt-grey-5);
  padding: 8px;
  box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.7) inset;
}

.text-input-validate:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.text-input-validate {
  min-width: 44px;
  min-height: 44px;
}
.text-input-validate.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.text-input-validate.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.text-input-validate.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.text-input-validate.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.text-input-validate {
  box-sizing: border-box;
  border-radius: 4px;
  padding: 8px;
  font-size: 1rem;
  text-decoration: none;
  border-style: none;
  line-height: 24px;
  justify-content: center;
}
.text-input-validate svg {
  width: 24px;
  height: 24px;
}
.text-input-validate {
  display: inline-block;
  font-weight: normal;
  color: var(--pt-grey-8);
  background: var(--pt-grey-1);
  border-color: var(--pt-grey-5);
}
.text-input-validate svg {
  fill: currentColor;
}
.text-input-validate:hover:not(:disabled) {
  cursor: text;
  border-color: var(--pt-grey-6);
}
.text-input-validate:active:not(:disabled), .text-input-validate:focus:not(:disabled) {
  outline: none;
  box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.7) inset;
  border-color: var(--pt-grey-6);
  border-width: 1px;
}
.text-input-validate:disabled {
  box-shadow: none;
  color: var(--pt-grey-7);
  background: var(--pt-grey-3);
  border-block-end-width: 1px;
}
.text-input-validate:invalid:not(:disabled) {
  border-color: var(--pt-critical-4);
}
.text-input-validate:invalid:not(:disabled):focus {
  border-color: var(--pt-critical-5);
}
.text-input-validate:invalid:not(:disabled) + span:after {
  content: "✖";
  color: var(--pt-critical-3);
}
.text-input-validate:valid:not(:disabled) {
  border-color: var(--pt-good-4);
}
.text-input-validate:valid:not(:disabled):focus {
  border-color: var(--pt-good-5);
}
.text-input-validate:valid:not(:disabled) + span:after {
  content: "✔";
  color: var(--pt-good-3);
}

/**
 * Section 3
 * ====================================================================
 * Feedback & Status
 * ====================================================================
 */
/**
 * Pipet Banner Class
 * ========
 * Banners can be used to display messages to users.
 *
 * Recommended Structure
 * ========
 * - <div class="banner(-x)>
 *  - (optional) <h2>, <h3>, <h4>, <h5>, <h6>, <strong>, .banner-title
 *  - <p>
 */
.banner {
  border-top-width: 8px;
  border-bottom-width: 0;
  border-left-width: 0;
  border-right-width: 0;
  border-style: solid;
  border-radius: 4px;
  box-shadow: var(--pt-shadow-container);
  padding: 8px 16px;
  font-size: 1rem;
  color: var(--pt-grey-8);
}
.banner > .banner-title, .banner > h2, .banner > h3, .banner > h4, .banner > h5, .banner > h6, .banner > strong {
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 0.125rem;
}
.banner {
  background: var(--pt-grey-3);
  border-color: var(--pt-grey-5);
}

.banner-info {
  border-top-width: 8px;
  border-bottom-width: 0;
  border-left-width: 0;
  border-right-width: 0;
  border-style: solid;
  border-radius: 4px;
  box-shadow: var(--pt-shadow-container);
  padding: 8px 16px;
  font-size: 1rem;
  color: var(--pt-grey-8);
}
.banner-info > .banner-title, .banner-info > h2, .banner-info > h3, .banner-info > h4, .banner-info > h5, .banner-info > h6, .banner-info > strong {
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 0.125rem;
}
.banner-info {
  background: var(--pt-info-1);
  border-color: var(--pt-info-3);
}

.banner-good {
  border-top-width: 8px;
  border-bottom-width: 0;
  border-left-width: 0;
  border-right-width: 0;
  border-style: solid;
  border-radius: 4px;
  box-shadow: var(--pt-shadow-container);
  padding: 8px 16px;
  font-size: 1rem;
  color: var(--pt-grey-8);
}
.banner-good > .banner-title, .banner-good > h2, .banner-good > h3, .banner-good > h4, .banner-good > h5, .banner-good > h6, .banner-good > strong {
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 0.125rem;
}
.banner-good {
  background: var(--pt-good-1);
  border-color: var(--pt-good-3);
}

.banner-warn,
.banner-warning {
  border-top-width: 8px;
  border-bottom-width: 0;
  border-left-width: 0;
  border-right-width: 0;
  border-style: solid;
  border-radius: 4px;
  box-shadow: var(--pt-shadow-container);
  padding: 8px 16px;
  font-size: 1rem;
  color: var(--pt-grey-8);
}
.banner-warn > .banner-title, .banner-warn > h2, .banner-warn > h3, .banner-warn > h4, .banner-warn > h5, .banner-warn > h6, .banner-warn > strong,
.banner-warning > .banner-title,
.banner-warning > h2,
.banner-warning > h3,
.banner-warning > h4,
.banner-warning > h5,
.banner-warning > h6,
.banner-warning > strong {
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 0.125rem;
}
.banner-warn,
.banner-warning {
  background: var(--pt-warning-1);
  border-color: var(--pt-warning-3);
}

.banner-important,
.banner-critical {
  border-top-width: 8px;
  border-bottom-width: 0;
  border-left-width: 0;
  border-right-width: 0;
  border-style: solid;
  border-radius: 4px;
  box-shadow: var(--pt-shadow-container);
  padding: 8px 16px;
  font-size: 1rem;
  color: var(--pt-grey-8);
}
.banner-important > .banner-title, .banner-important > h2, .banner-important > h3, .banner-important > h4, .banner-important > h5, .banner-important > h6, .banner-important > strong,
.banner-critical > .banner-title,
.banner-critical > h2,
.banner-critical > h3,
.banner-critical > h4,
.banner-critical > h5,
.banner-critical > h6,
.banner-critical > strong {
  font-size: 1rem;
  font-weight: bold;
  margin-bottom: 0.125rem;
}
.banner-important,
.banner-critical {
  background: var(--pt-critical-1);
  border-color: var(--pt-critical-3);
}

/**
 * Pipet Tag Class
 * ========
 * Tags can be used to highlight small pieces of inline information.
 *
 * Recommended Structure
 * ========
 * - <strong>
 */
.tag {
  display: inline-block;
  font-weight: normal;
  font-size: 1rem;
  padding: 4px 16px;
  border-radius: 16px;
  color: var(--pt-grey-8);
  background: var(--pt-grey-3);
  border: 1px solid var(--pt-grey-5);
}

.tab-accent {
  display: inline-block;
  font-weight: normal;
  font-size: 1rem;
  padding: 4px 16px;
  border-radius: 16px;
  color: var(--pt-grey-8);
  background: var(--pt-accent-3);
  border: 1px solid var(--pt-accent-5);
}

.tag-info {
  display: inline-block;
  font-weight: normal;
  font-size: 1rem;
  padding: 4px 16px;
  border-radius: 16px;
  color: var(--pt-grey-8);
  background: var(--pt-info-1);
  border: 1px solid var(--pt-info-4);
}

.tag-good {
  display: inline-block;
  font-weight: normal;
  font-size: 1rem;
  padding: 4px 16px;
  border-radius: 16px;
  color: var(--pt-grey-8);
  background: var(--pt-good-1);
  border: 1px solid var(--pt-good-4);
}

.tag-warn,
.tag-warning {
  display: inline-block;
  font-weight: normal;
  font-size: 1rem;
  padding: 4px 16px;
  border-radius: 16px;
  color: var(--pt-grey-8);
  background: var(--pt-warning-1);
  border: 1px solid var(--pt-warning-4);
}

.tag-important,
.tag-critical {
  display: inline-block;
  font-weight: normal;
  font-size: 1rem;
  padding: 4px 16px;
  border-radius: 16px;
  color: var(--pt-grey-8);
  background: var(--pt-critical-1);
  border: 1px solid var(--pt-critical-4);
}

/**
 * Section 4
 * ====================================================================
 * Layout & Organisation
 * ====================================================================
 */
.box-wrapper {
  margin: 16px;
  color: var(--pt-grey-8);
}
.box-wrapper.--extra-margin, .box-wrapper:not(:first-of-type) {
  margin-top: 32px;
}

.box-header {
  margin-bottom: 8px;
  color: var(--pt-grey-8);
}
.box-header h2, .box-header h3, .box-header h4, .box-header h5, .box-header h6,
.box-header .box-title {
  font-size: 1.125rem;
  font-weight: bold;
  line-height: 1.25rem;
  color: inherit;
}
.box-header p,
.box-header .box-blurb {
  margin-top: 4px;
  font-size: 1rem;
  font-weight: normal;
  line-height: 1.125rem;
  color: inherit;
}

.box {
  border-radius: 8px;
  border: 1px solid var(--pt-grey-5);
  background: var(--pt-grey-1);
  box-shadow: var(--pt-shadow-container);
  overflow: hidden;
  color: var(--pt-grey-8);
  padding: 16px;
}

.box-small {
  border-radius: 8px;
  border: 1px solid var(--pt-grey-5);
  background: var(--pt-grey-1);
  box-shadow: var(--pt-shadow-container);
  overflow: hidden;
  color: var(--pt-grey-8);
  padding: 8px;
}

.box-list {
  border-radius: 8px;
  border: 1px solid var(--pt-grey-5);
  background: var(--pt-grey-1);
  box-shadow: var(--pt-shadow-container);
  overflow: hidden;
  color: var(--pt-grey-8);
  list-style: none;
}

.list-item {
  padding: 8px;
}
.list-item.active:hover:first-child {
  border-radius: 8px 8px 0 0;
}
.list-item.active:hover:last-child {
  border-radius: 0 0 8px 8px;
}
.list-item.active:hover {
  cursor: pointer;
  background-color: var(--pt-grey-3);
}
.list-item:not(:last-of-type) {
  border-bottom: 1px solid var(--pt-grey-5);
}

/**
 * Section 5
 * ====================================================================
 * Navigation
 * ====================================================================
 */
.a11i-hidden:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(100%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.breadcrumbs:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.breadcrumbs {
  min-width: 44px;
  min-height: 44px;
  box-sizing: border-box;
  font-size: 1rem;
  font-weight: bold;
  padding: 4px;
  display: flex;
  align-items: center;
  width: min-content;
  border: none;
  box-shadow: none;
  max-width: 100%;
  overflow-x: scroll;
  overflow-y: clip;
}
.breadcrumbs svg {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  fill: currentColor;
}
.breadcrumbs .chevron {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  fill: var(--pt-grey-8);
  text-align: center;
}
.breadcrumbs .chevron::after {
  content: "❯";
}
.breadcrumbs > span:not(.chevron), .breadcrumbs > a {
  padding: 8px;
  border-radius: 4px;
  width: max-content;
  flex-shrink: 0;
}
.breadcrumbs > span:not(.chevron):hover:not(.selected), .breadcrumbs > a:hover:not(.selected) {
  background: var(--pt-accent-3);
  color: var(--pt-grey-8);
}
.breadcrumbs .selected {
  background: var(--pt-accent-3);
  color: var(--pt-grey-8);
}

.a11i-hidden:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(100%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.tablist:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.tablist {
  min-width: 44px;
  min-height: 44px;
  padding: 4px 16px;
  gap: 4px;
  display: flex;
  overflow-y: hidden;
  box-sizing: border-box;
  color: var(--pt-grey-8);
  background: var(--pt-grey-3);
  overflow-x: scroll;
  border-bottom: 1px solid var(--pt-nav-5);
}
.tablist a,
.tablist button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  text-decoration: none;
  font-size: 1rem;
  font-weight: bold;
  color: inherit;
  padding: 4px 16px;
  margin: 0;
  gap: 8px;
  border-radius: 4px;
  flex-grow: 1;
  flex-basis: 0;
  text-align: center;
  background: none;
  border: none;
  min-width: max-content;
}
.tablist a svg,
.tablist button svg {
  width: 24px;
  height: 24px;
  fill: currentColor;
}
.tablist a:hover:not(.selected):not(:disabled), .tablist a:hover:not(.active):not(:disabled),
.tablist button:hover:not(.selected):not(:disabled),
.tablist button:hover:not(.active):not(:disabled) {
  cursor: pointer;
  color: var(--pt-grey-8);
  background: var(--pt-accent-1);
  border: 1px solid var(--pt-accent-4);
}
.tablist a.selected, .tablist a.active,
.tablist button.selected,
.tablist button.active {
  color: var(--pt-grey-8);
  background: var(--pt-accent-1);
  border: 1px solid var(--pt-accent-4);
}
.tablist a:disabled,
.tablist button:disabled {
  color: var(--pt-grey-7);
}

/**
 * ==================================================================
 * Controls
 * ==================================================================
 */
.a11i-hidden:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(100%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.radio-item:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.radio-item {
  display: flex;
  align-items: center;
  accent-color: var(--pt-theme-primary);
  padding: 8px;
  font-size: 1rem;
  font-weight: normal;
}
.radio-item:hover:not(.disabled) {
  background: var(--pt-container-bg-highlight);
  border-radius: 8px;
}
.radio-item:focus-within:focus-visible input[type=checkbox], .radio-item:focus-within:focus-visible input[type=radio] {
  outline: none;
}
.radio-item input[type=checkbox],
.radio-item input[type=radio] {
  margin-right: 8px;
  width: 20px;
  height: 20px;
}
.radio-item .radio-label {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
}
.radio-item .radio-label .radio-title {
  font-size: 1rem;
  font-weight: normal;
}
.radio-item .radio-label .radio-blurb {
  font-size: 0.875rem;
  font-weight: normal;
  line-height: 1;
}
.radio-item.disabled .radio-label {
  opacity: 0.75;
}
.radio-item.disabled .radio-label .radio-title,
.radio-item.disabled .radio-label .radio-blurb {
  text-decoration: line-through;
}

/**
 * Classes to center page contents and define widths
 * Contains:
 *  .centered-page, .small, .wide
 */
/**
 * @deprecated
 */
.centered-page {
  width: 100%;
  margin: auto;
  box-sizing: border-box;
}
.centered-page.small {
  max-width: 768px;
}
.centered-page.wide {
  max-width: 1024px;
}
.centered-page.padded {
  padding-inline: 16px;
  margin-block: 16px;
}

.centering, .centering-full, .centering-none {
  width: 100%;
  margin: auto;
  box-sizing: border-box;
}
.centering-small {
  width: 100%;
  margin: auto;
  box-sizing: border-box;
  max-width: 768px;
}
.centering-wide {
  width: 100%;
  margin: auto;
  box-sizing: border-box;
  max-width: 1024px;
}

.a11i-hidden:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(100%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

/**
 * Section 1
 * ====================================================================
 * Colours
 * These colours are used for the main body and container backgrounds
 * ====================================================================
 */
/** Light -------------------------- */
/** Dark --------------------------- */
/**
 * Section 2
 * ====================================================================
 * Variables
 * These colours are used for the main body and container backgrounds
 * ====================================================================
 */
/** Synonyms */
/**
 * Section 1
 * ====================================================================
 * Colours
 * These colours are used for the main body and container backgrounds
 * ====================================================================
 */
/** Light -------------------------- */
/** Dark --------------------------- */
/**
 * Section 2
 * ====================================================================
 * Variables
 * These colours are used for the main body and container backgrounds
 * ====================================================================
 */
/** Synonyms */
/** Controls */
/** ============================================= */
/** Text Headers */
/** Text Bodies */
/** Variables */
.a11i-hidden:not(:focus):not(:active) {
  clip: rect(0 0 0 0);
  clip-path: inset(100%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.container-wrapper {
  margin: 16px;
  color: var(--pt-text);
}
.container-wrapper:not(:first-of-type) {
  margin-top: 32px;
}

.container-header {
  margin-bottom: 8px;
  color: var(--pt-text);
}
.container-header h2, .container-header h3, .container-header h4, .container-header h5, .container-header h6,
.container-header .container-title {
  font-size: 1.125rem;
  font-weight: bold;
  line-height: 1.125rem;
  margin-bottom: 4px;
  color: inherit;
}
.container-header p,
.container-header .container-description {
  font-size: 1rem;
  font-weight: normal;
  line-height: 1rem;
  color: inherit;
}

.container {
  border-radius: 8px;
  border: 1px solid var(--pt-border);
  background-color: var(--pt-container-bg);
  box-shadow: var(--pt-shadow-container);
  padding: 16px;
}
.container.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.container.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.container.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.container.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.container {
  color: var(--pt-text);
}

.details-container-wrapper {
  border-radius: 8px;
  border: 1px solid var(--pt-border);
  background-color: var(--pt-container-bg);
  box-shadow: var(--pt-shadow-container);
}
.details-container-wrapper.--connect-start {
  margin-left: 0;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.details-container-wrapper.--connect-end {
  margin-right: 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.details-container-wrapper.--connect-top {
  margin-top: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.details-container-wrapper.--connect-bottom {
  margin-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.details-container-wrapper {
  color: var(--pt-text);
  padding: 0;
}
.details-container-wrapper .summary-container:focus-visible:not(:disabled) {
  outline: 3px solid var(--pt-accent-4);
  outline-offset: 0;
}
.details-container-wrapper .summary-container .summary {
  border-block-end: 1px solid var(--pt-border);
  padding: 8px;
}
.details-container-wrapper .summary-container .summary-flex {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
}
.details-container-wrapper .summary-container .summary-flex .summary-title {
  font-size: 1.125rem;
  font-weight: bold;
  line-height: 1;
}
.details-container-wrapper .summary-container .summary-flex .summary-blurb {
  font-size: 1rem;
  font-weight: normal;
  line-height: 1;
}
.details-container-wrapper .summary-container .expand-button {
  padding: 4px;
  display: flex;
  justify-content: center;
  border-radius: 0;
  align-items: center;
  border: none;
  width: 100%;
  background: none;
  box-sizing: border-box;
}
.details-container-wrapper .summary-container .expand-button * {
  display: block;
}
.details-container-wrapper .summary-container .expand-button svg {
  width: 24px;
  height: 24px;
}
.details-container-wrapper .summary-container .expand-button {
  background: var(--pt-flat-control-bg);
}
.details-container-wrapper .summary-container .expand-button:hover {
  background: var(--pt-flat-control-bg-highlight);
  cursor: pointer;
}
.details-container-wrapper .summary-container .expand-button:active {
  background: var(--pt-flat-control-bg-pressed);
}
.details-container-wrapper .summary-container.--expanded .expand-button {
  padding: 4px;
  display: flex;
  justify-content: center;
  border-radius: 0 0 4px 4px;
  align-items: center;
  border: none;
  width: 100%;
  background: none;
  box-sizing: border-box;
}
.details-container-wrapper .summary-container.--expanded .expand-button * {
  display: block;
}
.details-container-wrapper .summary-container.--expanded .expand-button svg {
  width: 24px;
  height: 24px;
}
.details-container-wrapper .summary-container.--expanded .expand-button {
  background: var(--pt-flat-control-bg);
}
.details-container-wrapper .summary-container.--expanded .expand-button:hover {
  background: var(--pt-flat-control-bg-highlight);
  cursor: pointer;
}
.details-container-wrapper .summary-container.--expanded .expand-button:active {
  background: var(--pt-flat-control-bg-pressed);
}
.details-container-wrapper .details-container {
  border-top: 1px solid var(--pt-border);
  background: rgba(0, 0, 0, 0.05);
  padding: 0;
}
.details-container-wrapper .details-container .details {
  padding: 8px;
  border-block-end: 1px solid var(--pt-border);
}
.details-container-wrapper .details-container .expand-button {
  padding: 4px;
  display: flex;
  justify-content: center;
  border-radius: 0 0 4px 4px;
  align-items: center;
  border: none;
  width: 100%;
  background: none;
  box-sizing: border-box;
}
.details-container-wrapper .details-container .expand-button * {
  display: block;
}
.details-container-wrapper .details-container .expand-button svg {
  width: 24px;
  height: 24px;
}
.details-container-wrapper .details-container .expand-button {
  background: var(--pt-flat-control-bg);
}
.details-container-wrapper .details-container .expand-button:hover {
  background: var(--pt-flat-control-bg-highlight);
  cursor: pointer;
}
.details-container-wrapper .details-container .expand-button:active {
  background: var(--pt-flat-control-bg-pressed);
}

.pt-sticky-top {
  position: sticky;
  top: 0;
}

.page-content {
  min-height: 95vh;
}

.header-bar {
  margin: 0;
  padding-inline: 0;
  padding-block: 16px;
}
.header-bar > .inner, .header-bar > div {
  padding-inline: 16px;
}
.header-bar > .inner .page-title,
.header-bar > .inner h1, .header-bar > div .page-title,
.header-bar > div h1 {
  font-size: 3rem;
  line-height: 3rem;
  font-weight: bold;
  color: var(--pt-accent-5);
}
.header-bar > .inner .page-description,
.header-bar > .inner p, .header-bar > div .page-description,
.header-bar > div p {
  margin-top: 8px;
  font-size: 1.125rem;
  line-height: 1.125rem;
  font-weight: normal;
}

.header-bar-raised {
  margin: 0;
  padding-inline: 0;
  padding-block: 16px 8px;
  position: relative;
  z-index: 11;
  background: var(--pt-grey-1);
}
.header-bar-raised > .inner, .header-bar-raised > div {
  padding-inline: 16px;
}
.header-bar-raised > .inner .page-title,
.header-bar-raised > .inner h1, .header-bar-raised > div .page-title,
.header-bar-raised > div h1 {
  font-size: 3rem;
  line-height: 3rem;
  font-weight: bold;
  color: var(--pt-accent-5);
}
.header-bar-raised > .inner .page-description,
.header-bar-raised > .inner p, .header-bar-raised > div .page-description,
.header-bar-raised > div p {
  margin-top: 8px;
  font-size: 1.125rem;
  line-height: 1.125rem;
  font-weight: normal;
}

.menu-bar {
  z-index: 10;
  margin: 0;
  padding-inline: 0;
  padding-block: 8px;
  position: sticky;
  top: 0;
  background: var(--pt-grey-1);
  border-bottom: 1px solid var(--pt-grey-5);
  box-shadow: var(--pt-shadow-control);
}
.menu-bar > .inner, .menu-bar > div {
  padding-inline: 16px;
}

.footer-bar {
  margin: 0;
  padding-inline: 0;
  padding-top: 16px;
  padding-bottom: 64px;
  background: var(--pt-grey-3);
  border-top: 1px solid var(--pt-grey-5);
}
.footer-bar > .inner, .footer-bar > div {
  padding-inline: 16px;
}

/**
 * Container classes
 * Contains:
 *  .container-wrapper { .container-header, .container }
 */
.margin {
  margin: 16px;
}

.centred {
  margin: 16px auto;
}

.flex-space-between {
  display: flex;
  justify-content: space-between;
}
.flex-space-between.--gap-small {
  gap: 8px;
}
.flex-space-between.--gap-wide {
  gap: 16px;
}
.flex-space-between {
  flex-direction: row;
}
.flex-space-between.--h {
  flex-direction: row;
}
.flex-space-between.--v {
  flex-direction: column;
}
.flex-space-between.--align {
  align-items: center;
}
.flex-space-between.--align-end {
  align-items: end;
}
.flex-space-between.--align-start {
  align-items: start;
}

.flex-start {
  display: flex;
  justify-content: flex-start;
}
.flex-start.--gap-small {
  gap: 8px;
}
.flex-start.--gap-wide {
  gap: 16px;
}
.flex-start {
  flex-direction: row;
}
.flex-start.--h {
  flex-direction: row;
}
.flex-start.--v {
  flex-direction: column;
}
.flex-start.--align {
  align-items: center;
}
.flex-start.--align-end {
  align-items: end;
}
.flex-start.--align-start {
  align-items: start;
}

.flex-end {
  display: flex;
  justify-content: flex-end;
}
.flex-end.--gap-small {
  gap: 8px;
}
.flex-end.--gap-wide {
  gap: 16px;
}
.flex-end {
  flex-direction: row;
}
.flex-end.--h {
  flex-direction: row;
}
.flex-end.--v {
  flex-direction: column;
}
.flex-end.--align {
  align-items: center;
}
.flex-end.--align-end {
  align-items: end;
}
.flex-end.--align-start {
  align-items: start;
}

/**
 * Controls
 */
/**
 * Other
 */
/**
 * Pipet Article Elements
 * ========
 * Styling for textual content
 */
/**
 * ==================================================================
 * Shared
 * ==================================================================
 */
/**
 * ==================================================================
 * Shared
 * ==================================================================
 */
/**
 * Paragraphs
 */
.paragraph {
  color: var(--pt-text);
  font-size: 1rem;
  line-height: 1.5rem;
  margin-block: 8px;
}

.ol {
  list-style: decimal;
  margin-inline-start: 2rem;
  font-size: 1rem;
  line-height: 1.5rem;
}

.ul {
  list-style: disc;
  margin-inline-start: 2rem;
  font-size: 1rem;
  line-height: 1.5rem;
}

/**
 * Hrefs
 *
 * Recommended structure
 * ========
 * - <a>, for links
 * - <span>, for future links / links without an endpoint
 */
.href {
  text-decoration: underline;
  text-decoration-thickness: 2px;
  color: inherit;
  text-decoration-color: var(--pt-theme-info);
}
.href:hover {
  cursor: pointer;
  color: var(--pt-theme-info-standalone);
}

.href-no-target {
  text-decoration: underline;
  text-decoration-thickness: 2px;
  color: inherit;
  text-decoration-color: var(--pt-theme-destructive);
}
.href-no-target:hover {
  cursor: not-allowed;
}

.blockquote {
  color: var(--pt-text);
  font-size: 1rem;
  line-height: 1.5rem;
  background: var(--pt-container-bg-highlight);
  padding: 16px;
  border-inline: 8px solid var(--pt-theme-primary);
  border-radius: 32px;
  border-end-end-radius: 0;
  border-start-start-radius: 0;
  box-shadow: var(--pt-shadow-container);
}
.blockquote::before {
  content: "“";
  font-size: 2rem;
  line-height: 1rem;
  font-weight: bold;
  vertical-align: bottom;
  color: var(--pt-theme-primary-standalone);
}
.blockquote::after {
  content: "”";
  font-size: 2rem;
  line-height: 1rem;
  font-weight: bold;
  vertical-align: bottom;
  color: var(--pt-theme-primary-standalone);
}

.image {
  box-sizing: border-box;
  max-width: 100%;
  background-color: var(--pt-container-bg);
  border: 1px solid var(--pt-border);
  border-radius: 4px;
  box-shadow: var(--pt-shadow-container);
  margin-block: 16px;
  object-fit: scale-down;
  display: block;
  margin-inline: auto;
  padding: 4px;
}

.table {
  box-sizing: border-box;
  max-width: 100%;
  background-color: var(--pt-container-bg);
  border: 1px solid var(--pt-border);
  border-radius: 4px;
  box-shadow: var(--pt-shadow-container);
  margin-block: 16px;
  width: 100%;
  border-collapse: collapse;
  overflow-x: scroll;
}
.table th, .table td {
  padding: 8px;
  text-align: start;
}
.table thead {
  font-size: 1.125rem;
  font-weight: bold;
  border-bottom: 3px solid var(--pt-border);
}
.table tbody tr:nth-child(odd) {
  background-color: var(--pt-container-bg-highlight);
}
.table tbody tr:not(:last-child) {
  border-bottom: 1px solid var(--pt-border);
}

.media-wrapper {
  margin-block: 1.5rem;
  background: var(--pt-grey-1);
  border-radius: 8px;
  border: 1px solid var(--pt-grey-5);
  box-shadow: var(--pt-shadow-container);
}
.media-wrapper img {
  box-sizing: border-box;
  max-width: 100%;
  object-fit: scale-down;
  display: block;
  margin-inline: auto;
}
.media-wrapper .media-caption {
  padding: 4px;
  font-size: 1rem;
  text-align: center;
}

.article {
  text-align: justify;
}
.article h2 {
  font-family: serif;
  margin-top: 1.5rem;
  margin-bottom: 1.375rem;
  font-size: 1.675rem;
  font-weight: bold;
}
.article h3 {
  font-family: serif;
}
.article h3::before {
  content: "§ ";
}
.article h3 {
  margin-top: 1.5rem;
  margin-bottom: 0.75rem;
  font-size: 1.375rem;
  font-weight: normal;
}
.article h4 {
  font-family: serif;
}
.article h4::before {
  content: "§§ ";
}
.article h4 {
  margin-top: 1.25rem;
  margin-bottom: 0.5rem;
  font-size: 1.25rem;
  font-weight: normal;
  font-style: italic;
}
.article p {
  color: var(--pt-text);
  font-size: 1rem;
  line-height: 1.5rem;
  margin-block: 8px;
}
.article a {
  text-decoration: underline;
  text-decoration-thickness: 2px;
  color: inherit;
  text-decoration-color: var(--pt-theme-info);
}
.article a:hover {
  cursor: pointer;
  color: var(--pt-theme-info-standalone);
}
.article ul {
  list-style: disc;
  margin-inline-start: 2rem;
  font-size: 1rem;
  line-height: 1.5rem;
}
.article ol {
  list-style: decimal;
  margin-inline-start: 2rem;
  font-size: 1rem;
  line-height: 1.5rem;
}
.article > section > blockquote, .article > blockquote {
  color: var(--pt-text);
  font-size: 1rem;
  line-height: 1.5rem;
  background: var(--pt-container-bg-highlight);
  padding: 16px;
  border-inline: 8px solid var(--pt-theme-primary);
  border-radius: 32px;
  border-end-end-radius: 0;
  border-start-start-radius: 0;
  box-shadow: var(--pt-shadow-container);
}
.article > section > blockquote::before, .article > blockquote::before {
  content: "“";
  font-size: 2rem;
  line-height: 1rem;
  font-weight: bold;
  vertical-align: bottom;
  color: var(--pt-theme-primary-standalone);
}
.article > section > blockquote::after, .article > blockquote::after {
  content: "”";
  font-size: 2rem;
  line-height: 1rem;
  font-weight: bold;
  vertical-align: bottom;
  color: var(--pt-theme-primary-standalone);
}
.article img {
  box-sizing: border-box;
  max-width: 100%;
  background-color: var(--pt-container-bg);
  border: 1px solid var(--pt-border);
  border-radius: 4px;
  box-shadow: var(--pt-shadow-container);
  margin-block: 16px;
  object-fit: scale-down;
  display: block;
  margin-inline: auto;
  padding: 4px;
}
.article table {
  box-sizing: border-box;
  max-width: 100%;
  background-color: var(--pt-container-bg);
  border: 1px solid var(--pt-border);
  border-radius: 4px;
  box-shadow: var(--pt-shadow-container);
  margin-block: 16px;
  width: 100%;
  border-collapse: collapse;
  overflow-x: scroll;
}
.article table th, .article table td {
  padding: 8px;
  text-align: start;
}
.article table thead {
  font-size: 1.125rem;
  font-weight: bold;
  border-bottom: 3px solid var(--pt-border);
}
.article table tbody tr:nth-child(odd) {
  background-color: var(--pt-container-bg-highlight);
}
.article table tbody tr:not(:last-child) {
  border-bottom: 1px solid var(--pt-border);
}

/**
 * Section 1
 * ====================================================================
 * Colours
 * These colours are used for the main body and container backgrounds
 * ====================================================================
 */
/** Light -------------------------- */
/** Dark --------------------------- */
/**
 * Section 2
 * ====================================================================
 * Variables
 * These colours are used for the main body and container backgrounds
 * ====================================================================
 */
/** Synonyms */
/** Controls */
/** ============================================= */
/** Text Headers */
/** Text Bodies */
/** Variables */
/** Controls */
/** ============================================= */
/** Text Headers */
/** Text Bodies */
/** Variables */
.title-2 {
  font-size: 1.75rem;
  font-weight: bold;
  color: var(--pt-accent-5);
  margin-top: 1.75rem;
  margin-bottom: 0.5rem;
}

.title-3 {
  font-size: 1.5rem;
  font-weight: bold;
  color: var(--pt-accent-5);
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}

.title-4 {
  font-size: 1.125rem;
  font-weight: bold;
  color: var(--pt-accent-5);
  margin-top: 1.125rem;
  margin-bottom: 0.5rem;
}

.text {
  font-weight: normal;
  font-style: normal;
}
.text.--small {
  font-size: 14px;
  line-height: 18px;
}
.text.--medium {
  font-size: 16px;
  line-height: 20px;
}
.text.--large {
  font-size: 18px;
  line-height: 22px;
}
.text.--bold {
  font-weight: bold;
}
.text.--italic {
  font-style: italic;
}

.form-label {
  font-size: 14px;
  line-height: 18px;
  font-weight: bold;
  margin-bottom: 4px;
  margin-top: 8px;
}

.label {
  font-size: 1rem;
  font-weight: bold;
  display: block;
  margin-bottom: 4px;
}
.label.--inline {
  display: inline-block;
  margin: unset;
}

/**
 * Section 1
 * ====================================================================
 * Colours
 * These colours are used for the main body and container backgrounds
 * ====================================================================
 */
/** Light -------------------------- */
/** Dark --------------------------- */
/**
 * Section 2
 * ====================================================================
 * Variables
 * These colours are used for the main body and container backgrounds
 * ====================================================================
 */
/** Synonyms */
/** Controls */
/** ============================================= */
/** Text Headers */
/** Text Bodies */
/** Variables */
:root {
  /** Tables */
}
:root .table, :root.light .table {
  width: 100%;
  border-collapse: collapse;
}
:root .table thead, :root.light .table thead {
  border-bottom: 2px solid var(--pt-border-grey);
  border-top: 2px solid var(--pt-border-grey);
}
:root .table thead tr th, :root.light .table thead tr th {
  padding: 4px;
}
:root .table tbody, :root.light .table tbody {
  border-bottom: 2px solid var(--pt-border-grey);
}
:root .table tbody tr:nth-child(even), :root.light .table tbody tr:nth-child(even) {
  background-color: #ededed;
}
:root .table td,
:root .table th, :root.light .table td,
:root.light .table th {
  padding: 4px 8px;
}
:root.dark .table {
  width: 100%;
  border-collapse: collapse;
}
:root.dark .table thead {
  border-bottom: 2px solid var(--pt-border-grey);
  border-top: 2px solid var(--pt-border-grey);
}
:root.dark .table thead tr th {
  padding: 4px;
}
:root.dark .table tbody {
  border-bottom: 2px solid var(--pt-border-grey);
}
:root.dark .table tbody tr:nth-child(even) {
  background-color: #ededed;
}
:root.dark .table td,
:root.dark .table th {
  padding: 4px 8px;
}

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