/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/
:where(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-width: 0;
  vertical-align: baseline;
}

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

:where(ol, ul) {
  padding-left: 2rem;
}

:where(blockquote, q) {
  quotes: none;
}

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

:where(table) {
  border-collapse: collapse;
  border-spacing: 0;
}

:root {
  --input-bg-hue: 208;
  --input-bg-saturation: 8%;
  --input-bg-lightness: 62%;
  --placeholder-hue: 210;
  --placeholder-saturation: 4%;
  --placeholder-lightness: 51%;
  --bg-hue: 209;
  --bg-saturation: 14%;
  --bg-lightness: 80%;
  --color-hue: 26;
  --color-saturation: 6%;
  --color-lightness: 10%;
  --border-hue: 209;
  --border-saturation: 14%;
  --border-lightness: 55%;
  --link-color-hue: 170;
  --link-color-saturation: 40%;
  --link-color-lightness: 30%;
  --link-color: hsl(var(--link-color-hue), var(--link-color-saturation), var(--link-color-lightness));
  --tone-primary-bg-hue: 172;
  --tone-primary-bg-saturation: 19%;
  --tone-primary-bg-lightness: 60%;
  --tone-primary-color-hue: 175;
  --tone-primary-color-saturation: 82%;
  --tone-primary-color-lightness: 15%;
  --tone-primary-border-hue: 172;
  --tone-primary-border-saturation: 19%;
  --tone-primary-border-lightness: 35%;
  --tone-secondary-bg-hue: 190;
  --tone-secondary-bg-saturation: 9%;
  --tone-secondary-bg-lightness: 67%;
  --tone-secondary-color-hue: 172;
  --tone-secondary-color-saturation: 9%;
  --tone-secondary-color-lightness: 17%;
  --tone-secondary-border-hue: 172;
  --tone-secondary-border-saturation: 9%;
  --tone-secondary-border-lightness: 35%;
  --tone-success-color-hue: 76;
  --tone-success-color-saturation: 65%;
  --tone-success-color-lightness: 20%;
  --tone-success-bg-hue: 82;
  --tone-success-bg-saturation: 32%;
  --tone-success-bg-lightness: 85%;
  --tone-success-border-hue: 82;
  --tone-success-border-saturation: 32%;
  --tone-success-border-lightness: 44%;
  --tone-info-color-hue: 210;
  --tone-info-color-saturation: 72%;
  --tone-info-color-lightness: 30%;
  --tone-info-bg-hue: 210;
  --tone-info-bg-saturation: 33%;
  --tone-info-bg-lightness: 80%;
  --tone-info-border-hue: 210;
  --tone-info-border-saturation: 33%;
  --tone-info-border-lightness: 50%;
  --tone-warning-color-hue: 29;
  --tone-warning-color-saturation: 93%;
  --tone-warning-color-lightness: 20%;
  --tone-warning-bg-hue: 30;
  --tone-warning-bg-saturation: 41%;
  --tone-warning-bg-lightness: 80%;
  --tone-warning-border-hue: 30;
  --tone-warning-border-saturation: 41%;
  --tone-warning-border-lightness: 45%;
  --tone-danger-color-hue: 347;
  --tone-danger-color-saturation: 98%;
  --tone-danger-color-lightness: 25%;
  --tone-danger-bg-hue: 341;
  --tone-danger-bg-saturation: 31%;
  --tone-danger-bg-lightness: 85%;
  --tone-danger-border-hue: 341;
  --tone-danger-border-saturation: 31%;
  --tone-danger-border-lightness: 51%;
}

.theme-light {
  --input-bg-hue: 208;
  --input-bg-saturation: 8%;
  --input-bg-lightness: 62%;
  --placeholder-hue: 210;
  --placeholder-saturation: 4%;
  --placeholder-lightness: 51%;
  --bg-hue: 209;
  --bg-saturation: 14%;
  --bg-lightness: 80%;
  --color-hue: 26;
  --color-saturation: 6%;
  --color-lightness: 10%;
  --border-hue: 209;
  --border-saturation: 14%;
  --border-lightness: 55%;
  --link-color-hue: 170;
  --link-color-saturation: 40%;
  --link-color-lightness: 30%;
  --link-color: hsl(var(--link-color-hue), var(--link-color-saturation), var(--link-color-lightness));
  --tone-primary-bg-hue: 172;
  --tone-primary-bg-saturation: 19%;
  --tone-primary-bg-lightness: 60%;
  --tone-primary-color-hue: 175;
  --tone-primary-color-saturation: 82%;
  --tone-primary-color-lightness: 15%;
  --tone-primary-border-hue: 172;
  --tone-primary-border-saturation: 19%;
  --tone-primary-border-lightness: 35%;
  --tone-secondary-bg-hue: 190;
  --tone-secondary-bg-saturation: 9%;
  --tone-secondary-bg-lightness: 67%;
  --tone-secondary-color-hue: 172;
  --tone-secondary-color-saturation: 9%;
  --tone-secondary-color-lightness: 17%;
  --tone-secondary-border-hue: 172;
  --tone-secondary-border-saturation: 9%;
  --tone-secondary-border-lightness: 35%;
  --tone-success-color-hue: 76;
  --tone-success-color-saturation: 65%;
  --tone-success-color-lightness: 20%;
  --tone-success-bg-hue: 82;
  --tone-success-bg-saturation: 32%;
  --tone-success-bg-lightness: 85%;
  --tone-success-border-hue: 82;
  --tone-success-border-saturation: 32%;
  --tone-success-border-lightness: 44%;
  --tone-info-color-hue: 210;
  --tone-info-color-saturation: 72%;
  --tone-info-color-lightness: 30%;
  --tone-info-bg-hue: 210;
  --tone-info-bg-saturation: 33%;
  --tone-info-bg-lightness: 80%;
  --tone-info-border-hue: 210;
  --tone-info-border-saturation: 33%;
  --tone-info-border-lightness: 50%;
  --tone-warning-color-hue: 29;
  --tone-warning-color-saturation: 93%;
  --tone-warning-color-lightness: 20%;
  --tone-warning-bg-hue: 30;
  --tone-warning-bg-saturation: 41%;
  --tone-warning-bg-lightness: 80%;
  --tone-warning-border-hue: 30;
  --tone-warning-border-saturation: 41%;
  --tone-warning-border-lightness: 45%;
  --tone-danger-color-hue: 347;
  --tone-danger-color-saturation: 98%;
  --tone-danger-color-lightness: 25%;
  --tone-danger-bg-hue: 341;
  --tone-danger-bg-saturation: 31%;
  --tone-danger-bg-lightness: 85%;
  --tone-danger-border-hue: 341;
  --tone-danger-border-saturation: 31%;
  --tone-danger-border-lightness: 51%;
}

.theme-dark {
  --input-bg-hue: 30;
  --input-bg-saturation: 3%;
  --input-bg-lightness: 31%;
  --placeholder-hue: 209;
  --placeholder-saturation: 14%;
  --placeholder-lightness: 53%;
  --color-hue: 209;
  --color-saturation: 14%;
  --color-lightness: 80%;
  --bg-hue: 0;
  --bg-saturation: 0%;
  --bg-lightness: 15%;
  --border-hue: 26;
  --border-saturation: 6%;
  --border-lightness: 35%;
  --link-color-hue: 130;
  --link-color-saturation: 40%;
  --link-color-lightness: 70%;
  --link-color: hsl(var(--link-color-hue), var(--link-color-saturation), var(--link-color-lightness));
  --tone-primary-bg-hue: 172;
  --tone-primary-bg-saturation: 28%;
  --tone-primary-bg-lightness: 22%;
  --tone-primary-color-hue: 175;
  --tone-primary-color-saturation: 84%;
  --tone-primary-color-lightness: 45%;
  --tone-primary-border-hue: 172;
  --tone-primary-border-saturation: 28%;
  --tone-primary-border-lightness: 47%;
  --tone-secondary-bg-hue: 190;
  --tone-secondary-bg-saturation: 5%;
  --tone-secondary-bg-lightness: 17%;
  --tone-secondary-color-hue: 172;
  --tone-secondary-color-saturation: 13%;
  --tone-secondary-color-lightness: 67%;
  --tone-secondary-border-hue: 172;
  --tone-secondary-border-saturation: 13%;
  --tone-secondary-border-lightness: 37%;
  --tone-success-color-hue: 76;
  --tone-success-color-saturation: 64%;
  --tone-success-color-lightness: 70%;
  --tone-success-bg-hue: 73;
  --tone-success-bg-saturation: 31%;
  --tone-success-bg-lightness: 25%;
  --tone-success-border-hue: 73;
  --tone-success-border-saturation: 31%;
  --tone-success-border-lightness: 60%;
  --tone-info-color-hue: 211;
  --tone-info-color-saturation: 72%;
  --tone-info-color-lightness: 90%;
  --tone-info-bg-hue: 210;
  --tone-info-bg-saturation: 15%;
  --tone-info-bg-lightness: 35%;
  --tone-info-border-hue: 210;
  --tone-info-border-saturation: 15%;
  --tone-info-border-lightness: 67%;
  --tone-warning-color-hue: 29;
  --tone-warning-color-saturation: 93%;
  --tone-warning-color-lightness: 75%;
  --tone-warning-bg-hue: 28;
  --tone-warning-bg-saturation: 40%;
  --tone-warning-bg-lightness: 25%;
  --tone-warning-border-hue: 28;
  --tone-warning-border-saturation: 40%;
  --tone-warning-border-lightness: 61%;
  --tone-danger-color-hue: 347;
  --tone-danger-color-saturation: 100%;
  --tone-danger-color-lightness: 90%;
  --tone-danger-bg-hue: 349;
  --tone-danger-bg-saturation: 20%;
  --tone-danger-bg-lightness: 35%;
  --tone-danger-border-hue: 349;
  --tone-danger-border-saturation: 20%;
  --tone-danger-border-lightness: 68%;
}

@media (prefers-color-scheme: dark) {
  :root {
    --input-bg-hue: 30;
    --input-bg-saturation: 3%;
    --input-bg-lightness: 31%;
    --placeholder-hue: 209;
    --placeholder-saturation: 14%;
    --placeholder-lightness: 53%;
    --color-hue: 209;
    --color-saturation: 14%;
    --color-lightness: 80%;
    --bg-hue: 0;
    --bg-saturation: 0%;
    --bg-lightness: 15%;
    --border-hue: 26;
    --border-saturation: 6%;
    --border-lightness: 35%;
    --link-color-hue: 130;
    --link-color-saturation: 40%;
    --link-color-lightness: 70%;
    --link-color: hsl(var(--link-color-hue), var(--link-color-saturation), var(--link-color-lightness));
    --tone-primary-bg-hue: 172;
    --tone-primary-bg-saturation: 28%;
    --tone-primary-bg-lightness: 22%;
    --tone-primary-color-hue: 175;
    --tone-primary-color-saturation: 84%;
    --tone-primary-color-lightness: 45%;
    --tone-primary-border-hue: 172;
    --tone-primary-border-saturation: 28%;
    --tone-primary-border-lightness: 47%;
    --tone-secondary-bg-hue: 190;
    --tone-secondary-bg-saturation: 5%;
    --tone-secondary-bg-lightness: 17%;
    --tone-secondary-color-hue: 172;
    --tone-secondary-color-saturation: 13%;
    --tone-secondary-color-lightness: 67%;
    --tone-secondary-border-hue: 172;
    --tone-secondary-border-saturation: 13%;
    --tone-secondary-border-lightness: 37%;
    --tone-success-color-hue: 76;
    --tone-success-color-saturation: 64%;
    --tone-success-color-lightness: 70%;
    --tone-success-bg-hue: 73;
    --tone-success-bg-saturation: 31%;
    --tone-success-bg-lightness: 25%;
    --tone-success-border-hue: 73;
    --tone-success-border-saturation: 31%;
    --tone-success-border-lightness: 60%;
    --tone-info-color-hue: 211;
    --tone-info-color-saturation: 72%;
    --tone-info-color-lightness: 90%;
    --tone-info-bg-hue: 210;
    --tone-info-bg-saturation: 15%;
    --tone-info-bg-lightness: 35%;
    --tone-info-border-hue: 210;
    --tone-info-border-saturation: 15%;
    --tone-info-border-lightness: 67%;
    --tone-warning-color-hue: 29;
    --tone-warning-color-saturation: 93%;
    --tone-warning-color-lightness: 75%;
    --tone-warning-bg-hue: 28;
    --tone-warning-bg-saturation: 40%;
    --tone-warning-bg-lightness: 25%;
    --tone-warning-border-hue: 28;
    --tone-warning-border-saturation: 40%;
    --tone-warning-border-lightness: 61%;
    --tone-danger-color-hue: 347;
    --tone-danger-color-saturation: 100%;
    --tone-danger-color-lightness: 90%;
    --tone-danger-bg-hue: 349;
    --tone-danger-bg-saturation: 20%;
    --tone-danger-bg-lightness: 35%;
    --tone-danger-border-hue: 349;
    --tone-danger-border-saturation: 20%;
    --tone-danger-border-lightness: 68%;
  }
}
:root, .theme-dark, .theme-light {
  --input-bg: hsl(var(--input-bg-hue), var(--input-bg-saturation), var(--input-bg-lightness));
  --placeholder: hsl(var(--placeholder-hue), var(--placeholder-saturation), var(--placeholder-lightness));
  --bg: hsl(var(--bg-hue), var(--bg-saturation), var(--bg-lightness));
  --color: hsl(var(--color-hue), var(--color-saturation), var(--color-lightness));
  --border: hsl(var(--border-hue), var(--border-saturation), var(--border-lightness));
  --tone-primary-bg: hsl(var(--tone-primary-bg-hue), var(--tone-primary-bg-saturation), var(--tone-primary-bg-lightness));
  --tone-primary-color: hsl(var(--tone-primary-color-hue), var(--tone-primary-color-saturation), var(--tone-primary-color-lightness));
  --tone-primary-border: hsl(var(--tone-primary-border-hue), var(--tone-primary-border-saturation), var(--tone-primary-border-lightness));
  --tone-secondary-bg: hsl(var(--tone-secondary-bg-hue), var(--tone-secondary-bg-saturation), var(--tone-secondary-bg-lightness));
  --tone-secondary-color: hsl(var(--tone-secondary-color-hue), var(--tone-secondary-color-saturation), var(--tone-secondary-color-lightness));
  --tone-secondary-border: hsl(var(--tone-secondary-border-hue), var(--tone-secondary-border-saturation), var(--tone-secondary-border-lightness));
  --tone-success-color: hsl(var(--tone-success-color-hue), var(--tone-success-color-saturation), var(--tone-success-color-lightness));
  --tone-success-bg: hsl(var(--tone-success-bg-hue), var(--tone-success-bg-saturation), var(--tone-success-bg-lightness));
  --tone-success-border: hsl(var(--tone-success-border-hue), var(--tone-success-border-saturation), var(--tone-success-border-lightness));
  --tone-info-color: hsl(var(--tone-info-color-hue), var(--tone-info-color-saturation), var(--tone-info-color-lightness));
  --tone-info-bg: hsl(var(--tone-info-bg-hue), var(--tone-info-bg-saturation), var(--tone-info-bg-lightness));
  --tone-info-border: hsl(var(--tone-info-border-hue), var(--tone-info-border-saturation), var(--tone-info-border-lightness));
  --tone-warning-color: hsl(var(--tone-warning-color-hue), var(--tone-warning-color-saturation), var(--tone-warning-color-lightness));
  --tone-warning-bg: hsl(var(--tone-warning-bg-hue), var(--tone-warning-bg-saturation), var(--tone-warning-bg-lightness));
  --tone-warning-border: hsl(var(--tone-warning-border-hue), var(--tone-warning-border-saturation), var(--tone-warning-border-lightness));
  --tone-danger-color: hsl(var(--tone-danger-color-hue), var(--tone-danger-color-saturation), var(--tone-danger-color-lightness));
  --tone-danger-bg: hsl(var(--tone-danger-bg-hue), var(--tone-danger-bg-saturation), var(--tone-danger-bg-lightness));
  --tone-danger-border: hsl(var(--tone-danger-border-hue), var(--tone-danger-border-saturation), var(--tone-danger-border-lightness));
}

@layer layout {
  :where(.tone-primary-bg) {
    background-color: var(--tone-bg);
  }
  :where(.tone-primary-bg),
  :where(.tone-primary) {
    --bg-hue: var(--tone-primary-bg-hue);
    --bg-saturation: var(--tone-primary-bg-saturation);
    --bg-lightness: var(--tone-primary-bg-lightness);
    --bg: var(--tone-primary-bg);
    --tone-bg-hue: var(--tone-primary-bg-hue);
    --tone-bg-saturation: var(--tone-primary-bg-saturation);
    --tone-bg-lightness: var(--tone-primary-bg-lightness);
    --tone-bg: var(--tone-primary-bg);
  }
  :where(.tone-primary-border) {
    border-color: var(--tone-border);
  }
  :where(.tone-primary-border),
  :where(.tone-primary) {
    --border-hue: var(--tone-primary-border-hue);
    --border-saturation: var(--tone-primary-border-saturation);
    --border-lightness: var(--tone-primary-border-lightness);
    --border: var(--tone-primary-border);
    --tone-border-hue: var(--tone-primary-border-hue);
    --tone-border-saturation: var(--tone-primary-border-saturation);
    --tone-border-lightness: var(--tone-primary-border-lightness);
    --tone-border: var(--tone-primary-border);
  }
  :where(.tone-primary-text) {
    color: var(--tone-color);
  }
  :where(.tone-primary-text),
  :where(.tone-primary) {
    --color-hue: var(--tone-primary-color-hue);
    --color-saturation: var(--tone-primary-color-saturation);
    --color-lightness: var(--tone-primary-color-lightness);
    --color: var(--tone-primary-color);
    --tone-color-hue: var(--tone-primary-color-hue);
    --tone-color-saturation: var(--tone-primary-color-saturation);
    --tone-color-lightness: var(--tone-primary-color-lightness);
    --tone-color: var(--tone-primary-color);
    color: var(--color);
  }
  :where(.tone-secondary-bg) {
    background-color: var(--tone-bg);
  }
  :where(.tone-secondary-bg),
  :where(.tone-secondary) {
    --bg-hue: var(--tone-secondary-bg-hue);
    --bg-saturation: var(--tone-secondary-bg-saturation);
    --bg-lightness: var(--tone-secondary-bg-lightness);
    --bg: var(--tone-secondary-bg);
    --tone-bg-hue: var(--tone-secondary-bg-hue);
    --tone-bg-saturation: var(--tone-secondary-bg-saturation);
    --tone-bg-lightness: var(--tone-secondary-bg-lightness);
    --tone-bg: var(--tone-secondary-bg);
  }
  :where(.tone-secondary-border) {
    border-color: var(--tone-border);
  }
  :where(.tone-secondary-border),
  :where(.tone-secondary) {
    --border-hue: var(--tone-secondary-border-hue);
    --border-saturation: var(--tone-secondary-border-saturation);
    --border-lightness: var(--tone-secondary-border-lightness);
    --border: var(--tone-secondary-border);
    --tone-border-hue: var(--tone-secondary-border-hue);
    --tone-border-saturation: var(--tone-secondary-border-saturation);
    --tone-border-lightness: var(--tone-secondary-border-lightness);
    --tone-border: var(--tone-secondary-border);
  }
  :where(.tone-secondary-text) {
    color: var(--tone-color);
  }
  :where(.tone-secondary-text),
  :where(.tone-secondary) {
    --color-hue: var(--tone-secondary-color-hue);
    --color-saturation: var(--tone-secondary-color-saturation);
    --color-lightness: var(--tone-secondary-color-lightness);
    --color: var(--tone-secondary-color);
    --tone-color-hue: var(--tone-secondary-color-hue);
    --tone-color-saturation: var(--tone-secondary-color-saturation);
    --tone-color-lightness: var(--tone-secondary-color-lightness);
    --tone-color: var(--tone-secondary-color);
    color: var(--color);
  }
  :where(.tone-success-bg) {
    background-color: var(--tone-bg);
  }
  :where(.tone-success-bg),
  :where(.tone-success) {
    --bg-hue: var(--tone-success-bg-hue);
    --bg-saturation: var(--tone-success-bg-saturation);
    --bg-lightness: var(--tone-success-bg-lightness);
    --bg: var(--tone-success-bg);
    --tone-bg-hue: var(--tone-success-bg-hue);
    --tone-bg-saturation: var(--tone-success-bg-saturation);
    --tone-bg-lightness: var(--tone-success-bg-lightness);
    --tone-bg: var(--tone-success-bg);
  }
  :where(.tone-success-border) {
    border-color: var(--tone-border);
  }
  :where(.tone-success-border),
  :where(.tone-success) {
    --border-hue: var(--tone-success-border-hue);
    --border-saturation: var(--tone-success-border-saturation);
    --border-lightness: var(--tone-success-border-lightness);
    --border: var(--tone-success-border);
    --tone-border-hue: var(--tone-success-border-hue);
    --tone-border-saturation: var(--tone-success-border-saturation);
    --tone-border-lightness: var(--tone-success-border-lightness);
    --tone-border: var(--tone-success-border);
  }
  :where(.tone-success-text) {
    color: var(--tone-color);
  }
  :where(.tone-success-text),
  :where(.tone-success) {
    --color-hue: var(--tone-success-color-hue);
    --color-saturation: var(--tone-success-color-saturation);
    --color-lightness: var(--tone-success-color-lightness);
    --color: var(--tone-success-color);
    --tone-color-hue: var(--tone-success-color-hue);
    --tone-color-saturation: var(--tone-success-color-saturation);
    --tone-color-lightness: var(--tone-success-color-lightness);
    --tone-color: var(--tone-success-color);
    color: var(--color);
  }
  :where(.tone-info-bg) {
    background-color: var(--tone-bg);
  }
  :where(.tone-info-bg),
  :where(.tone-info) {
    --bg-hue: var(--tone-info-bg-hue);
    --bg-saturation: var(--tone-info-bg-saturation);
    --bg-lightness: var(--tone-info-bg-lightness);
    --bg: var(--tone-info-bg);
    --tone-bg-hue: var(--tone-info-bg-hue);
    --tone-bg-saturation: var(--tone-info-bg-saturation);
    --tone-bg-lightness: var(--tone-info-bg-lightness);
    --tone-bg: var(--tone-info-bg);
  }
  :where(.tone-info-border) {
    border-color: var(--tone-border);
  }
  :where(.tone-info-border),
  :where(.tone-info) {
    --border-hue: var(--tone-info-border-hue);
    --border-saturation: var(--tone-info-border-saturation);
    --border-lightness: var(--tone-info-border-lightness);
    --border: var(--tone-info-border);
    --tone-border-hue: var(--tone-info-border-hue);
    --tone-border-saturation: var(--tone-info-border-saturation);
    --tone-border-lightness: var(--tone-info-border-lightness);
    --tone-border: var(--tone-info-border);
  }
  :where(.tone-info-text) {
    color: var(--tone-color);
  }
  :where(.tone-info-text),
  :where(.tone-info) {
    --color-hue: var(--tone-info-color-hue);
    --color-saturation: var(--tone-info-color-saturation);
    --color-lightness: var(--tone-info-color-lightness);
    --color: var(--tone-info-color);
    --tone-color-hue: var(--tone-info-color-hue);
    --tone-color-saturation: var(--tone-info-color-saturation);
    --tone-color-lightness: var(--tone-info-color-lightness);
    --tone-color: var(--tone-info-color);
    color: var(--color);
  }
  :where(.tone-warning-bg) {
    background-color: var(--tone-bg);
  }
  :where(.tone-warning-bg),
  :where(.tone-warning) {
    --bg-hue: var(--tone-warning-bg-hue);
    --bg-saturation: var(--tone-warning-bg-saturation);
    --bg-lightness: var(--tone-warning-bg-lightness);
    --bg: var(--tone-warning-bg);
    --tone-bg-hue: var(--tone-warning-bg-hue);
    --tone-bg-saturation: var(--tone-warning-bg-saturation);
    --tone-bg-lightness: var(--tone-warning-bg-lightness);
    --tone-bg: var(--tone-warning-bg);
  }
  :where(.tone-warning-border) {
    border-color: var(--tone-border);
  }
  :where(.tone-warning-border),
  :where(.tone-warning) {
    --border-hue: var(--tone-warning-border-hue);
    --border-saturation: var(--tone-warning-border-saturation);
    --border-lightness: var(--tone-warning-border-lightness);
    --border: var(--tone-warning-border);
    --tone-border-hue: var(--tone-warning-border-hue);
    --tone-border-saturation: var(--tone-warning-border-saturation);
    --tone-border-lightness: var(--tone-warning-border-lightness);
    --tone-border: var(--tone-warning-border);
  }
  :where(.tone-warning-text) {
    color: var(--tone-color);
  }
  :where(.tone-warning-text),
  :where(.tone-warning) {
    --color-hue: var(--tone-warning-color-hue);
    --color-saturation: var(--tone-warning-color-saturation);
    --color-lightness: var(--tone-warning-color-lightness);
    --color: var(--tone-warning-color);
    --tone-color-hue: var(--tone-warning-color-hue);
    --tone-color-saturation: var(--tone-warning-color-saturation);
    --tone-color-lightness: var(--tone-warning-color-lightness);
    --tone-color: var(--tone-warning-color);
    color: var(--color);
  }
  :where(.tone-danger-bg) {
    background-color: var(--tone-bg);
  }
  :where(.tone-danger-bg),
  :where(.tone-danger) {
    --bg-hue: var(--tone-danger-bg-hue);
    --bg-saturation: var(--tone-danger-bg-saturation);
    --bg-lightness: var(--tone-danger-bg-lightness);
    --bg: var(--tone-danger-bg);
    --tone-bg-hue: var(--tone-danger-bg-hue);
    --tone-bg-saturation: var(--tone-danger-bg-saturation);
    --tone-bg-lightness: var(--tone-danger-bg-lightness);
    --tone-bg: var(--tone-danger-bg);
  }
  :where(.tone-danger-border) {
    border-color: var(--tone-border);
  }
  :where(.tone-danger-border),
  :where(.tone-danger) {
    --border-hue: var(--tone-danger-border-hue);
    --border-saturation: var(--tone-danger-border-saturation);
    --border-lightness: var(--tone-danger-border-lightness);
    --border: var(--tone-danger-border);
    --tone-border-hue: var(--tone-danger-border-hue);
    --tone-border-saturation: var(--tone-danger-border-saturation);
    --tone-border-lightness: var(--tone-danger-border-lightness);
    --tone-border: var(--tone-danger-border);
  }
  :where(.tone-danger-text) {
    color: var(--tone-color);
  }
  :where(.tone-danger-text),
  :where(.tone-danger) {
    --color-hue: var(--tone-danger-color-hue);
    --color-saturation: var(--tone-danger-color-saturation);
    --color-lightness: var(--tone-danger-color-lightness);
    --color: var(--tone-danger-color);
    --tone-color-hue: var(--tone-danger-color-hue);
    --tone-color-saturation: var(--tone-danger-color-saturation);
    --tone-color-lightness: var(--tone-danger-color-lightness);
    --tone-color: var(--tone-danger-color);
    color: var(--color);
  }
}
html {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

* {
  box-sizing: border-box;
}

@font-face {
  src: url(/assets/font/sansation/Sansation_Bold_Latin.ttf);
  font-family: Sansation;
  font-weight: bold;
}
h1, h2, h3, h4, h5, h6, .logo {
  font-family: "Sansation", "Times New Roman", serif;
  color: hsl(var(--tone-secondary-color-hue), var(--tone-secondary-color-saturation), calc(var(--tone-secondary-color-lightness) + 2.5 * clamp(-1%, 50% - var(--tone-secondary-color-lightness), 1%)));
}

h1 {
  font-size: 2rem;
}

h2 {
  font-size: 1.6rem;
}

h3 {
  font-size: 1.4rem;
}

h4 {
  font-size: 1.2rem;
}

h5 {
  font-size: 1.1rem;
}

h6 {
  font-size: 1rem;
}

p {
  line-height: 1.4;
  font-size: 1rem;
}

small {
  font-size: 0.8em;
}

i, em {
  font-style: italic;
}

b, strong {
  font-weight: bold;
  color: hsl(var(--tone-secondary-color-hue), var(--tone-secondary-color-saturation), calc(var(--tone-secondary-color-lightness) + 2.5 * clamp(-1%, 50% - var(--tone-secondary-color-lightness), 1%)));
}

hr {
  background: linear-gradient(90deg, transparent 10%, hsl(263, 43%, 90%) 10%, hsl(263, 43%, 70%) 20%, hsl(263, 43%, 70%) 80%, hsl(263, 43%, 90%) 90%, transparent 90%);
  margin-bottom: var(--gutter);
  margin-top: var(--gutter);
  border: none;
  width: 100%;
  height: 1px;
}

img {
  width: 100%;
  height: auto;
}

blockquote {
  padding: 0.5rem 0 0.5rem 1rem;
  border-left: solid 2px hsl(263, 43%, 70%);
  font-style: italic;
}

.text-spacing > * {
  margin-bottom: 1rem;
}
.text-spacing > h1, .text-spacing > h2, .text-spacing > h3, .text-spacing > h4, .text-spacing > h5, .text-spacing > h6 {
  padding-bottom: 0.5rem;
  margin-bottom: 0;
  margin-top: 0;
}
.text-spacing > h1:not(:first-child), .text-spacing > h2:not(:first-child), .text-spacing > h3:not(:first-child), .text-spacing > h4:not(:first-child), .text-spacing > h5:not(:first-child), .text-spacing > h6:not(:first-child) {
  padding-top: 2rem;
}
.text-spacing > *:last-child {
  margin-bottom: 0;
}

.gutter-vertical-gap {
  flex-direction: column;
  display: flex;
  gap: 1rem;
}
.gutter-vertical-gap > * {
  margin-bottom: 0;
  margin-top: 0;
}

.text-center {
  text-align: center;
}

h1[id] a, h2[id] a, h3[id] a, h4[id] a, h5[id] a, h6[id] a {
  background-color: transparent;
  -webkit-text-fill-color: initial;
  color: #4b4453;
}
h1[id] a:hover, h2[id] a:hover, h3[id] a:hover, h4[id] a:hover, h5[id] a:hover, h6[id] a:hover {
  color: hsl(263, 43%, 38%);
}
h1[id]:before, h2[id]:before, h3[id]:before, h4[id]:before, h5[id]:before, h6[id]:before {
  content: "#";
  color: hsl(268, 10%, 80%);
}

.w-100 {
  width: 100%;
}

.figure-highlight {
  position: relative;
}
.figure-highlight:after {
  transition: all 0.5s ease;
  z-index: -1; /* place the element behind */
  background: linear-gradient(90deg, hsl(263, 43%, 50%) 0%, hsl(263, 43%, 80%) 100%);
  filter: blur(10px); /* control the blur */
  top: 0.5rem;
  left: 0.5rem;
  bottom: -0.25rem;
  right: -0.5rem;
  content: " ";
  position: absolute;
}

.heading {
  color: var(--primary-main);
}
.heading small {
  color: hsl(var(--primary-main-hue), var(--primary-main-saturation), calc(var(--primary-main-lightness) + 10%));
}

.inline-list {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.pill {
  display: inline-block;
  padding: 0.25rem 0.5rem;
  background: hsl(263, 43%, 70%);
  color: white;
  border-radius: 0.2rem;
}

.definitions {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
}

@media screen and (min-width: 960px) {
  .definitions {
    grid-template-columns: repeat(3, 1fr);
  }
}
.image-gallery {
  grid-template-columns: repeat(var(--columns, 2), 1fr);
  display: grid;
  gap: 1rem;
}

@media screen and (min-width: 960px) {
  .image-gallery {
    --columns: 3 ;
  }
}
.picture-overlay {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
}
.picture-overlay > :not(img) {
  justify-content: center;
  align-items: center;
  flex-direction: column;
  display: flex;
  background-color: hsl(var(--bg-hue), var(--bg-saturation), var(--bg-lightness), 0.8);
  backdrop-filter: blur(0.5rem);
}
.picture-overlay > :not(img):hover {
  background-color: hsl(var(--tone-primary-bg-hue), var(--tone-primary-bg-saturation), calc(var(--tone-primary-bg-lightness) + 10 * clamp(-1%, 50% - var(--tone-primary-bg-lightness), 1%)), 0.9);
  color: var(--tone-primary-color);
  backdrop-filter: blur(0.5rem);
}
.picture-overlay > * {
  grid-column: 1/1;
  grid-row: 1/1;
  height: 100%;
}

:where(body > main > .block) {
  display: block;
}

body {
  flex-direction: column;
  min-height: 100vh;
  display: flex;
}
body > header {
  border-bottom: solid 1px var(--tone-primary-border);
  background-color: hsl(var(--tone-primary-bg-hue), var(--tone-primary-bg-saturation), var(--tone-primary-bg-lightness), 0.5);
  backdrop-filter: blur(0.5rem);
  z-index: 9;
  position: sticky;
  top: 0;
  display: grid;
  grid-template-columns: 1fr 10rem minmax(10rem, 49rem) 1fr;
  grid-template-areas: ". logo nav .";
  gap: 1rem;
}
body > header > a {
  padding: calc(var(--padding) / 2) 0;
  align-items: center;
  gap: 0.4rem;
  grid-area: logo;
  display: flex;
  font-size: 1.4rem;
  --color: var(--link-color);
  color: var(--link-color);
}
body > header nav {
  grid-area: nav;
  display: flex;
  align-items: center;
}
body > header nav ul {
  margin: 0;
  padding: 0;
  flex-direction: row;
  list-style: none;
  display: flex;
  height: 100%;
}
body > header nav ul a {
  padding-left: var(--padding);
  padding-right: var(--padding);
  transition: all 0.3s ease-in-out;
  height: 100%;
  display: flex;
  align-items: center;
}
body > header nav ul a.active {
  background-color: hsl(var(--link-color-hue), var(--link-color-saturation), calc(var(--link-color-lightness) + 50 * clamp(-1%, 50% - var(--link-color-lightness), 1%)), 0.7);
}
body > header nav ul a:hover {
  background-color: hsl(var(--link-color-hue), var(--link-color-saturation), calc(var(--link-color-lightness) + 50 * clamp(-1%, 50% - var(--link-color-lightness), 1%)), 0.5);
}
body > main {
  flex-grow: 1;
}
body > main > .block {
  padding: calc(var(--padding) * 3) var(--padding);
}
:where(body > main > .block > *) {
  max-width: 60rem;
  display: block;
  margin: 0 auto;
  width: 100%;
}
body > main > .block:nth-child(even) {
  background-color: var(--tone-secondary-bg);
  position: relative;
  margin-top: 2rem;
}
body > main > .block:nth-child(even):before, body > main > .block:nth-child(even):after {
  position: absolute;
  display: block;
  border-style: solid;
  right: 0;
}
body > main > .block:nth-child(even):before {
  border-left-color: var(--tone-secondary-bg);
  border-top-color: transparent;
  border-width: 1.5rem 0 0 100vw;
  top: -1.5rem;
  content: " ";
}
body > main > .block:nth-child(even):not(:last-child) {
  margin-bottom: 2rem;
}
body > main > .block:nth-child(even):not(:last-child):after {
  border-right-color: var(--tone-secondary-bg);
  border-bottom-color: transparent;
  border-width: 0 100vw 3rem 0;
  bottom: -3rem;
  content: " ";
}
body > footer {
  border-top: solid 1px var(--tone-primary-border);
  background-color: var(--tone-primary-bg);
  display: grid;
  grid-template-columns: 1fr minmax(10rem, 20rem) minmax(10rem, 39rem) 1fr;
  gap: 1rem;
  grid-template-areas: ". copyright nav .";
  padding: var(--padding);
}
body > footer .copyright {
  grid-area: copyright;
}
body > footer .copyright svg {
  height: 1rem;
}
body > footer nav {
  grid-area: nav;
}
body > footer nav ul {
  padding: 0;
  list-style: none;
}

.layout-sidebar {
  display: grid;
  gap: 1rem;
}

@media screen and (min-width: 1200px) {
  .layout-sidebar {
    grid-template-columns: 3fr 1fr;
  }
}
.layout-group {
  flex-direction: column;
  gap: var(--gutter);
  display: flex;
}

@media screen and (min-width: 1200px) {
  .layout-group {
    justify-content: center;
    flex-direction: row;
  }
  .layout-group > * {
    flex: 1 1 0;
    max-width: 50%;
  }
}
a {
  text-decoration: none;
  color: var(--link-color);
  transition: color 0.1s ease;
}
a:hover {
  color: hsl(var(--link-color-hue), var(--link-color-saturation), calc(var(--link-color-lightness) + 10 * clamp(-1%, 50% - var(--link-color-lightness), 1%)));
}

main a,
.link {
  text-decoration: none;
  color: var(--link-color);
  transition: color 0.1s ease;
  position: relative;
}
main a:after,
.link:after {
  position: absolute;
  border-bottom: var(--color);
  content: " ";
  bottom: 0;
  width: 80%;
  left: 10%;
}
main a:hover,
.link:hover {
  color: hsl(var(--link-color-hue), var(--link-color-saturation), calc(var(--link-color-lightness) + 10 * clamp(-1%, 50% - var(--link-color-lightness), 1%)));
}
main a:hover:after,
.link:hover:after {
  position: absolute;
  border-bottom: var(--color);
  content: " ";
  bottom: 0;
  width: 80%;
  left: 10%;
}

input,
.input,
button,
.button,
select,
optgroup,
textarea {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

.button,
button,
select {
  text-transform: none;
}

fieldset {
  min-width: 0;
  padding: 0;
  margin: 0;
  border-width: 0;
}

legend {
  padding: 0 0 calc(var(--padding) / 2) var(--padding);
  margin-bottom: calc(var(--padding) / 2);
  font-size: 1.5rem;
  float: left;
  width: 100%;
}
legend + * {
  clear: left;
}

.label,
label {
  margin-bottom: calc(var(--gutter) / 2);
  display: inline-block;
}

input[type=file] {
  height: calc(1.5rem + var(--padding) + 2px);
  vertical-align: middle;
  line-height: 1.5;
  font-size: 1rem;
}

.form-error {
  color: var(--danger-main);
}

.input,
input:not([type=radio]):not([type=checkbox]),
textarea,
select,
.button,
button {
  background-color: var(--input-bg);
  border: 1px solid var(--border);
  color: var(--color);
  padding: calc(var(--padding) / 2) var(--padding);
  vertical-align: middle;
  line-height: 1.5;
  font-size: 1rem;
  border-radius: 0.2rem;
}
.input:focus, .input.active,
input:not([type=radio]):not([type=checkbox]):focus,
input:not([type=radio]):not([type=checkbox]).active,
textarea:focus,
textarea.active,
select:focus,
select.active,
.button:focus,
.button.active,
button:focus,
button.active {
  --border: var(--primary-main, --border) ;
}
.input[readonly],
input:not([type=radio]):not([type=checkbox])[readonly],
textarea[readonly],
select[readonly],
.button[readonly],
button[readonly] {
  opacity: 0.7;
}

input:not(:enabled):not([href]), input.disabled, textarea:not(:enabled):not([href]), textarea.disabled, select:not(:enabled):not([href]), select.disabled, button:not(:enabled):not([href]), button.disabled, a:not(:enabled):not([href]), a.disabled {
  pointer-events: all;
  cursor: not-allowed;
  opacity: 0.5;
}

.button,
button {
  background-color: var(--bg);
  transition: 0.15s background-color;
  display: inline-block;
  text-align: center;
  cursor: pointer;
  border-width: 1px;
}
.button:hover:not(.disabled):enabled, .button.active:not(.disabled):enabled,
button:hover:not(.disabled):enabled,
button.active:not(.disabled):enabled {
  background-color: #cdc2ff;
  color: hsl(263, 43%, 51%);
}
.button[type=submit],
button[type=submit] {
  background-color: var(--primary-contrast);
  border-color: var(--primary-main);
  color: var(--primary-main);
}

select {
  word-wrap: normal;
  appearance: none;
}
select:not([multiple]) {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23141a20' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 16px 12px;
}
select[multiple] {
  resize: vertical;
  min-height: 5rem;
}
select:not(:enabled) {
  opacity: 1;
}

textarea {
  resize: vertical;
  height: auto;
}

input {
  accent-color: var(--tone-primary-color);
}
input:autofill {
  background: inherit;
}

textarea,
select,
input:not([type=radio]):not([type=checkbox]) {
  display: block;
  width: 100%;
}

.input-line {
  display: flex;
}
.input-line label {
  margin-bottom: 0;
}
.input-line > input, .input-line > .input, .input-line > select, .input-line > .input-wrapper, .input-line > .form-control-wrapper {
  flex-grow: 1;
}
.input-line > :not(input):not(select):not(.input-wrapper):not(.form-control-wrapper):not(.input) {
  flex-grow: 0;
  flex-shrink: 0;
}
.input-line > .input-line-text, .input-line > button {
  text-overflow: ellipsis;
  max-height: 2.5rem;
  overflow: hidden;
}
.input-line > *:not(:first-child), .input-line > *:not(:first-child) * {
  border-bottom-left-radius: 0 !important;
  border-top-left-radius: 0 !important;
}
.input-line > *:not(:last-child), .input-line > *:not(:last-child) * {
  border-bottom-right-radius: 0 !important;
  border-top-right-radius: 0 !important;
}
.input-line > *:not(:first-child), .input-line > *:not(:first-child) * {
  border-left: none;
}
.input-line > *:first-child {
  border-top-left-radius: var(--radius);
  border-bottom-left-radius: var(--radius);
}
.input-line > *:last-child {
  border-top-right-radius: var(--radius);
  border-bottom-right-radius: var(--radius);
}
.input-line .input-line-text {
  padding: calc(var(--padding) / 2 - 1px) var(--padding);
  background-color: var(--secondary-contrast);
  border: solid 1px var(--secondary-main);
  white-space: nowrap;
  align-items: center;
  display: flex;
}

.input-row {
  gap: var(--gutter);
  display: flex;
}
.input-row > *:not(button) {
  width: 100%;
}

@media (pointer: coarse) {
  *:hover {
    scale: 1 !important;
  }
}
:root {
  --padding: .75rem;
  --gutter: 1rem;
  --radius: .4rem;
}

html, body {
  font-size: 16px;
  line-height: 1.1;
  color: var(--color);
  background-color: var(--bg);
}

.select-box {
  background-color: hsl(var(--tone-primary-bg-hue), var(--tone-primary-bg-saturation), var(--tone-primary-bg-lightness), 0.3);
  border: solid 1px var(--tone-primary-border);
  border-radius: var(--radius);
  transition: scale 0.4s ease-in-out;
  overflow: hidden;
  color: var(--color);
}
.select-box:hover {
  z-index: 2;
  scale: 1.05;
  box-shadow: 0 0 0.25rem 0.2rem hsl(var(--tone-primary-border-hue), var(--tone-primary-border-saturation), var(--tone-primary-border-lightness), 0.2);
}
.select-box > :first-child {
  border-top-right-radius: var(--radius);
  border-top-left-radius: var(--radius);
}
.select-box > :last-child {
  border-bottom-right-radius: var(--radius);
  border-bottom-left-radius: var(--radius);
}
.select-box > :not(img):not(.picture-overlay) {
  text-align: center;
  padding: var(--padding);
}
:where(.select-box > *) {
  display: block;
}
.select-box picture {
  background-color: hsl(var(--tone-secondary-bg-hue), var(--tone-secondary-bg-saturation), var(--tone-secondary-bg-lightness), 0.5);
}
.select-box footer {
  background-color: hsl(var(--tone-primary-bg-hue), var(--tone-primary-bg-saturation), var(--tone-primary-bg-lightness), 0.3);
  position: relative;
}
.select-box footer:after {
  z-index: -1;
  background-color: hsl(var(--tone-primary-bg-hue), var(--tone-primary-bg-saturation), var(--tone-primary-bg-lightness), 0.9);
  border-bottom-right-radius: var(--radius);
  border-bottom-left-radius: var(--radius);
  position: absolute;
  content: " ";
  height: 100%;
  width: 0;
  left: 0;
  top: 0;
  transition: width 0.4s ease;
}
.select-box footer:hover:after {
  width: 100%;
}

.hero-header {
  text-align: center;
}
.hero-header picture {
  display: none;
}
.hero-header .title {
  color: hsl(var(--tone-secondary-color-hue), var(--tone-secondary-color-saturation), calc(var(--tone-secondary-color-lightness) + 20 * clamp(-1%, 50% - var(--tone-secondary-color-lightness), 1%)));
  font-style: italic;
  font-size: 2.5rem;
}
.hero-header .intro {
  font-size: 1.3rem;
  font-style: italic;
}

@media screen and (min-width: 1200px) {
  .hero-header {
    display: flex;
    align-items: center;
    gap: var(--gutter);
  }
  .hero-header :not(picture) {
    flex-grow: 1;
  }
  .hero-header picture {
    justify-content: center;
    border-radius: 60%;
    display: block;
    width: 35%;
  }
  .hero-header picture img {
    border-radius: 30% 1rem;
  }
}

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