/* 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: 25%;
  --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: 25%;
  --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: 80%;
  --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: 22%;
  --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: 80%;
    --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: 22%;
    --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;
}

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;
}

hr {
  background: linear-gradient(90deg, transparent 0%, var(--tone-secondary-border) 10%, var(--tone-primary-border) 20%, var(--tone-primary-border) 80%, var(--tone-secondary-border) 90%, transparent 100%);
  margin-bottom: calc(var(--gutter) * 2);
  margin-top: calc(var(--gutter) * 2);
  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;
}

dl dt {
  margin-bottom: calc(var(--gutter) / 3);
  font-style: italic;
}
dl dd {
  margin-bottom: var(--gutter);
}
dl dd:has(+ dd) {
  margin-bottom: calc(var(--gutter) / 2);
}
dl dd {
  padding-left: var(--padding);
}

.text-spacing > * {
  margin-bottom: var(--gutter);
}
.text-spacing > h1, .text-spacing > h2, .text-spacing > h3, .text-spacing > h4, .text-spacing > h5, .text-spacing > h6 {
  padding-bottom: calc(var(--gutter) / 2);
  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: calc(var(--gutter) * 1.5);
}
.text-spacing > *:last-child {
  margin-bottom: 0;
}

.gutter-vertical-gap {
  flex-direction: column;
  gap: var(--gutter);
  display: flex;
}
.gutter-vertical-gap > * {
  margin-bottom: 0;
  margin-top: 0;
}

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

.w-100 {
  width: 100% !important;
  min-width: 100% !important;
  max-width: 100% !important;
}

.stacked-caption {
  border-radius: var(--radius);
  position: relative;
  display: block;
  overflow: hidden;
}
.stacked-caption img {
  filter: blur(2px) grayscale(40%);
  border-radius: var(--radius);
  display: block;
}
.stacked-caption:before {
  background-color: hsla(var(--bg-hue), var(--bg-saturation), var(--bg-lightness), 0.7);
  position: absolute;
  content: " ";
  height: 100%;
  width: 100%;
  z-index: 1;
  left: 0;
  top: 0;
}
.stacked-caption figcaption {
  font-family: "Sansation", "Times New Roman", serif;
  justify-content: center;
  align-items: center;
  position: absolute;
  font-size: min(7.5vw, 3rem);
  font-weight: bold;
  display: flex;
  z-index: 4;
  bottom: 0;
  right: 0;
  left: 0;
  top: 0;
}

.nav-picture {
  flex-direction: column;
  display: flex;
  gap: 1rem;
}
.nav-picture a {
  transition: all 0.5s ease;
  scale: 1;
}
.nav-picture a:hover {
  box-shadow: 0 0 0.25rem var(--link-color);
  scale: 1.05;
  z-index: 5;
}

@media screen and (min-width: 960px) {
  .nav-picture {
    flex-direction: row;
  }
}
:where(body > main > .block) {
  display: block;
}

body {
  flex-direction: column;
  min-height: 100vh;
  display: flex;
}
body .hero-header {
  padding: calc(var(--padding) * 3);
  background: transparent;
  text-align: center;
  position: relative;
  overflow: hidden;
  z-index: 1;
}
body .hero-header a {
  transform: rotate(-2deg);
  transition: color 0.5s ease;
  flex-direction: column;
  position: relative;
  max-height: 5rem;
  font-size: min(9vw, 5rem);
  font-weight: bold;
  display: flex;
  color: var(--color);
}
body .hero-header a:hover {
  color: var(--tone-primary-color);
  scale: 1.1;
}
body .hero-header:before, body .hero-header:after {
  position: absolute;
  content: " ";
  height: 100%;
  width: 100%;
  left: 0;
  top: 0;
}
body .hero-header:before {
  background-color: hsla(var(--bg-hue), var(--bg-saturation), var(--bg-lightness), 0.6);
}
body .hero-header:after {
  background: url(/assets/image/home/hero.webp) no-repeat center center;
  background-size: cover;
  backdrop-filter: blur(10px);
  filter: blur(0.25rem);
  z-index: -1;
}
body .search-bar {
  position: sticky;
  top: 0;
  padding: var(--padding);
  background-color: hsl(var(--bg-hue), var(--bg-saturation), calc(var(--bg-lightness) + 5 * clamp(-1%, 50% - var(--bg-lightness), 1%)));
  box-shadow: 0 4px 2px -2px rgba(0, 0, 0, 0.2);
  z-index: 99;
}
body .search-bar input {
  width: 100%;
  max-width: 640px;
  margin: 0 auto;
}
body .search-bar input::placeholder {
  text-align: center;
}
body .main-nav {
  background-color: hsl(var(--bg-hue), var(--bg-saturation), calc(var(--bg-lightness) + 10 * clamp(-1%, 50% - var(--bg-lightness), 1%)));
  justify-content: center;
  gap: var(--gutter);
  display: flex;
}
body .main-nav .group {
  display: flex;
  justify-content: center;
}
body .main-nav a {
  transition: color 0.5s ease, background-color 0.5s ease;
  padding: var(--padding);
  color: var(--color);
  position: relative;
  display: block;
}
body .main-nav a.active:after {
  background-color: var(--tone-primary-border);
  right: calc(var(--padding) / 2);
  left: calc(var(--padding) / 2);
  position: absolute;
  height: 0.25rem;
  content: " ";
  bottom: 0;
}
body .main-nav a:hover {
  background-color: var(--tone-primary-bg);
  color: var(--tone-primary-color);
}
body .main-content {
  max-width: calc(1440px + var(--padding) * 2);
  padding: var(--padding);
  margin: 0 auto;
  flex-grow: 1;
  width: 100%;
}
body .main-footer {
  border-top: solid 1px var(--tone-primary-border);
  background-color: hsl(var(--bg-hue), var(--bg-saturation), calc(var(--bg-lightness) + 10 * clamp(-1%, 50% - var(--bg-lightness), 1%)));
}
body .main-footer nav {
  justify-content: space-between;
  max-width: calc(1440px + var(--padding) * 2);
  padding: var(--padding);
  gap: var(--gutter);
  margin: 0 auto;
  flex-wrap: wrap;
  display: flex;
}
body .main-footer nav a {
  display: block;
  color: var(--color);
  position: relative;
}
body .main-footer nav a:after {
  position: absolute;
  left: 0;
  bottom: -2px;
  border-bottom: 2px solid rgb(251, 189, 132);
  width: 0;
  content: " ";
  transition: width 0.25s ease;
}
body .main-footer nav a:hover:after {
  width: 100%;
}

@media screen and (max-width: 959px) {
  .main-nav .md {
    display: none !important;
  }
}
@media screen and (min-width: 960px) {
  .main-nav .sm {
    display: none !important;
  }
}
.img-slider {
  background-color: var(--tone-secondary-bg);
  padding: calc(var(--padding) / 2);
  border-radius: var(--radius);
  display: flex;
  gap: calc(var(--gutter) / 2);
  flex-direction: column;
}
.img-slider .overflow {
  overflow-x: scroll;
  scrollbar-width: none;
}
.img-slider .images {
  display: flex;
  gap: 1%;
  transition: transform 0.5s ease;
}
.img-slider .images button {
  border-radius: 0;
  border: none;
  padding: 0;
}
.img-slider .images button img {
  display: block;
}
.img-slider .images > * {
  min-width: 80%;
  max-width: 80%;
}
.img-slider .actions {
  align-items: center;
  gap: var(--gutter);
  display: flex;
}
.img-slider .actions .previews {
  gap: calc(var(--gutter) / 3);
  justify-content: center;
  flex-wrap: wrap;
  display: flex;
}
.img-slider .actions .previews button {
  padding: 0;
}
.img-slider .actions .previews button:hover img {
  opacity: 1;
}
.img-slider .actions .previews button img {
  opacity: 0.6;
  display: block;
  width: 5rem;
}

@media screen and (min-width: 960px) {
  .img-slider .images > * {
    min-width: 40%;
    max-width: 40%;
  }
}
.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%;
  }
}
.layout-focussed-sm {
  margin: 0 auto;
  max-width: 640px;
}

.layout-focussed-md {
  max-width: 960px;
  margin: 0 auto;
}

.layout-focussed-lg {
  max-width: 1200px;
  margin: 0 auto;
}

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 :where(a:not([class]):not(nav a)),
.link {
  text-decoration: none;
  color: var(--link-color);
  transition: color 0.1s ease;
  position: relative;
}
main :where(a:not([class]):not(nav a)):after,
.link:after {
  position: absolute;
  content: " ";
  transition: width 0.2s ease;
  bottom: 0;
  left: 10%;
  width: 0;
}
main :where(a:not([class]):not(nav 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 :where(a:not([class]):not(nav a)):hover:after,
.link:hover:after {
  background-color: hsl(var(--link-color-hue), var(--link-color-saturation), calc(var(--link-color-lightness) + 15 * clamp(-1%, 50% - var(--link-color-lightness), 1%)));
  height: 2px;
  width: 80%;
}

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-color: var(--tone-primary-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%;
}

section .section-title {
  padding-bottom: var(--padding);
  font-size: min(6vw, 3rem);
  text-align: center;
}

.pagination {
  justify-content: center;
  align-items: center;
  list-style: none;
  display: flex;
}
.pagination li {
  border: solid 1px var(--tone-secondary-border);
  transition: background-color 0.2s ease-in-out;
}
.pagination li:hover {
  background-color: var(--tone-secondary-bg);
}
.pagination li.active {
  background-color: var(--tone-success-bg);
  text-decoration: underline;
}
.pagination li:first-child {
  border-top-left-radius: var(--radius);
  border-bottom-left-radius: var(--radius);
}
.pagination li:last-child {
  border-top-right-radius: var(--radius);
  border-bottom-right-radius: var(--radius);
}
.pagination li a {
  padding: var(--padding);
  display: block;
}

@media screen and (min-width: 720px) {
  .book-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 1200px) {
  .book-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.book-grid {
  gap: var(--gutter);
  display: grid;
  list-style: none;
  padding: 0;
  margin: 0;
}
.book-grid a.book-item {
  transition: scale 0.5s ease;
  scale: 1;
}
.book-grid a.book-item:hover {
  box-shadow: var(--tone-secondary-bg) 0 7px 29px 0;
  scale: 1.05;
}
.book-grid .book-item {
  background-color: var(--tone-secondary-bg);
  justify-content: space-between;
  border-radius: var(--radius);
  padding: var(--padding);
  gap: var(--gutter);
  height: 100%;
  display: flex;
}
.book-grid .book-item .cover {
  align-items: center;
  flex: 0 0 8rem;
  display: flex;
}
.book-grid .book-item .cover img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
}
.book-grid .book-item .information {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  gap: var(--gutter);
}
.book-grid .book-item .information .authors {
  flex-grow: 1;
}
.book-grid .book-item .information .gtin {
  font-size: 0.9rem;
}
.book-grid .book-item .title {
  font-size: 1.1rem;
}

.book-header {
  gap: var(--gutter);
  grid-auto-rows: min-content;
  display: grid;
}
.book-header .book-cover {
  border: solid 1px var(--tone-secondary-border);
  background-color: var(--tone-secondary-bg);
  border-radius: var(--radius);
}
.book-header .book-cover > *:first-child {
  border-top-left-radius: var(--radius);
  border-top-right-radius: var(--radius);
}
.book-header .book-cover > *:last-child {
  border-bottom-left-radius: var(--radius);
  border-bottom-right-radius: var(--radius);
}
.book-header .book-cover .actions {
  justify-content: center;
}

.book-page {
  display: flex;
  flex-direction: column;
  gap: var(--gutter);
}

.book-details dl dd {
  font-size: 1.1rem;
}

@media screen and (min-width: 960px) {
  .book-header {
    grid-template-columns: 2fr 3fr;
  }
}
.book-samples .gallery {
  justify-content: space-between;
  gap: var(--gutter);
  flex-wrap: wrap;
  display: grid;
  grid-template-columns: repeat(8, 1fr);
}

:root {
  --padding: .75rem;
  --gutter: 1rem;
  --radius: .4rem;
}

@media (pointer: coarse) {
  *:hover {
    scale: 1 !important;
  }
}
html, body {
  font-size: 16px;
  line-height: 1.1;
  color: var(--color);
  background-color: var(--bg);
}

.block {
  box-shadow: var(--tone-primary-border) 0 7px 29px 0;
  border: solid 1px var(--tone-primary-border);
  background-color: var(--tone-secondary-bg);
  padding: var(--padding);
  border-radius: var(--radius);
}

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