@font-face {
  font-family: 'Neue Haas Grotesk Display Pro';
  src: url('../fonts/haasgrotdisp-55roman-webfont.woff2') format('woff2'), url('../fonts/haasgrotdisp-55roman-webfont.woff') format('woff');
  font-weight: 500;
  font-style: normal;
}
@font-face {
  font-family: 'Crabath Text';
  src: url('../fonts/crabath_text_book-webfont.woff2') format('woff2'), url('../fonts/crabath_text_book-webfont.woff') format('woff');
  font-weight: 300;
  font-style: normal;
}
/* 1. Reset/Normalize */
body,
div,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
th,
td,
article,
aside,
figure,
footer,
header,
menu,
nav,
section {
  margin: 0;
  padding: 0;
  border: 0;
}
* {
  box-sizing: border-box;
  text-rendering: optimizeLegibility;
}
input::-moz-focus-inner,
button::-moz-focus-inner {
  border: 0;
}
i {
  font-style: normal;
}
/* 2. Global */
* {
  box-sizing: border-box;
  text-rendering: optimizeLegibility;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
}
*:before,
*:after {
  box-sizing: border-box;
}
html {
  font-size: 16px;
}
body {
  font-family: 'Crabath Text', serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
  font-size: 1.1875rem;
  line-height: 1.31578947;
  color: #000000;
  background: #ffffff;
}
input,
select,
textarea,
button {
  font-family: 'Crabath Text', serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
  font-size: 1.1875rem;
}
button {
  padding: 0;
  background: transparent;
  border: 0;
  outline: none;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
input::-moz-focus-inner,
button::-moz-focus-inner {
  padding: 0;
  border: 0;
}
a img {
  border: 0;
}
/* 3. Layout */
.page-wrapper {
  display: flex;
  flex-flow: column;
  gap: 0;
  min-height: 100vh;
  overflow: hidden;
  margin: 0 auto;
}
.page-inner {
  display: flex;
  flex-flow: column;
  gap: 0;
}
.page-aside {
  display: flex;
  flex-flow: column;
  gap: 2rem;
}
.page-content {
  display: flex;
  flex-flow: column;
  padding: 1rem;
  border: 0.5rem solid #ffffff;
}
.page-main {
  flex: 1 1 auto;
}
.page-footer {
  flex: 0 0 auto;
}
.page-selected--books .page-content {
  border-color: #e6e6e6;
}
.grid {
  display: flex;
  flex-flow: column;
  gap: 2.125rem;
}
@media (min-width: 600px) {
  .grid-3 {
    flex-flow: row wrap;
  }
  .grid-3 .column {
    flex: 1 0 auto;
    width: 30%;
  }
  .grid-3 .column-x2 {
    flex: 2 0 auto;
    width: 60%;
  }
}
@media (min-width: 960px) {
  .page-inner {
    flex-flow: row;
    max-width: 100rem;
    margin: 0 auto;
    padding: 0;
  }
  .page-aside {
    display: flex;
    flex-flow: column;
    gap: 2rem;
    flex: 0 0 auto;
    width: 17.25rem;
    padding: 0 0 1.875rem 2.5rem;
  }
  .page-content {
    flex: 1 1 auto;
    width: calc(100vw - 17.25rem);
    min-height: 100vh;
    padding: 1.375rem;
  }
  .grid {
    flex-flow: row wrap;
  }
  .column {
    flex: 1 0 auto;
    width: 40%;
  }
  .column-x2 {
    flex: 2 0 auto;
    width: 100%;
  }
  .grid-3 .column {
    width: 30%;
  }
  .grid-3 .column-x2 {
    width: 60%;
  }
}
@media (min-width: 100rem) {
  .page-content {
    width: 82.75rem;
  }
}
/* 4. Typography */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 1em;
}
.main-title {
  margin-bottom: 0.71428571em;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 1.75rem;
  line-height: 1.28571429;
  text-align: center;
}
.section-title {
  max-width: 40rem;
  margin: 0 auto 0.83333333em;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 1.5rem;
  line-height: 1.25;
  text-align: center;
}
p + .section-title,
.two-cols + .section-title {
  margin-top: 1.44444444em;
}
.sub-title {
  margin-bottom: 1.05263158em;
  font-family: 'Crabath Text', serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
  font-size: 1.1875rem;
  line-height: 1.31578947;
}
.small-title {
  margin-bottom: 0.25rem;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}
.x-small-title {
  display: inline;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}
p {
  margin-bottom: 1.31578947em;
}
p:last-child {
  margin-bottom: 0;
}
.p-large {
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 1.1875rem;
  line-height: 1.31578947;
}
.no-break {
  margin-bottom: 1.31578947em;
  break-inside: avoid;
  page-break-inside: avoid;
}
.no-break:last-child {
  margin-bottom: 0;
}
@media (max-width: 599px) {
  p {
    font-size: 1.0625rem;
    line-height: 1.29411765;
  }
}
@media (min-width: 600px) {
  .main-title {
    margin-bottom: 0.8em;
    font-size: 3.125rem;
    line-height: 1.2;
  }
  .section-title {
    max-width: 60rem;
    margin-bottom: 0.55555556em;
    font-size: 2.25rem;
    line-height: 1.22222222;
  }
  p + .section-title,
  .two-cols + .section-title {
    margin-top: 1.44444444em;
  }
  .p-large {
    font-size: 1.5rem;
    line-height: 1.25;
  }
}
@media (min-width: 1200px) {
  .p-large {
    font-size: 2.25rem;
    line-height: 1.22222222;
  }
}
a {
  text-decoration: none;
  transition: all 0.3s;
}
a:focus,
a:hover {
  text-decoration: none;
}
b,
strong {
  font-weight: normal;
}
i,
em {
  font-style: normal;
}
ul {
  list-style-type: none;
}
.list-with-bullets {
  list-style: disc inside;
}
q {
  quotes: "“" "”" "‘" "’";
}
q:before {
  content: open-quote;
}
q:after {
  content: close-quote;
}
.lang-cs q {
  quotes: "„" "“" "‚" "‘";
}
/* 5. Colours */
.main-title,
.section-title,
.small-title {
  color: #000000;
}
a {
  color: #000000;
  outline: none;
}
a:focus,
a:hover {
  color: #000000;
}
.color-success {
  color: #1be413 !important;
}
.color-warning {
  color: #ef404a !important;
}
.color-error {
  color: #ef404a !important;
}
::placeholder {
  color: #000000;
  opacity: 0.3;
}
/* 6. Header + 7. Nav */
.page-logo {
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 2.5rem;
  line-height: 1.1;
}
.page-logo a {
  display: block;
  padding: 1rem 1.5rem;
}
.page-nav {
  display: none;
  flex-flow: column;
  gap: 1rem;
  margin-left: -2.5rem;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 2.25rem;
  line-height: 1.22222222;
}
.book-nav-item a {
  display: block;
  padding: 0.5rem 0 0.5rem 2.5rem;
}
.selected-book-nav-item {
  background: #e6e6e6;
}
.selected-book-nav-item a {
  color: #000000;
  background: #e6e6e6;
}
.selected-book-nav-item .select-chapter-form {
  display: block;
  padding-right: 2.25rem;
  padding-left: 2.5rem;
}
.select-chapter-form {
  display: none;
  padding-bottom: 1rem;
}
.select-chapter-form .form-action {
  display: flex;
  flex-flow: row;
  gap: 0.625rem;
}
.select-chapter-form .select-all-chapters,
.select-chapter-form .select-multiple-chapters {
  flex: 1 1 auto;
  width: 2.5rem;
}
.select-chapter-form .select-all-chapters label,
.select-chapter-form .select-multiple-chapters label {
  position: relative;
  display: inline-block;
  height: 1.93333333em;
  overflow: hidden;
  padding: 0 1.5em;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 0.9375rem;
  line-height: 1.8;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  color: #000000;
  background: transparent;
  border: 1px solid currentColor;
  border-radius: 1.5rem;
  cursor: pointer;
  appearance: none;
  transition: all 0.3s;
  display: block;
  width: 100%;
  padding-right: 0.25rem;
  padding-left: 0.25rem;
  background: #ffffff;
}
.select-chapter-form .select-all-chapters label:active,
.select-chapter-form .select-multiple-chapters label:active,
.select-chapter-form .select-all-chapters label:focus,
.select-chapter-form .select-multiple-chapters label:focus,
.select-chapter-form .select-all-chapters label:hover,
.select-chapter-form .select-multiple-chapters label:hover {
  text-decoration: none;
  color: #ffffff;
  background: #000000;
  border-color: #000000;
  outline: none;
}
.select-chapter-form .select-all-chapters label:before,
.select-chapter-form .select-multiple-chapters label:before,
.select-chapter-form .select-all-chapters label:after,
.select-chapter-form .select-multiple-chapters label:after {
  content: none;
}
.select-chapter-form .select-all-chapters label:focus,
.select-chapter-form .select-multiple-chapters label:focus,
.select-chapter-form .select-all-chapters label:hover,
.select-chapter-form .select-multiple-chapters label:hover {
  color: #000000;
}
.chapters-nav {
  display: flex;
  flex-flow: row wrap;
  gap: 0.5rem 0.75rem;
  padding: 1rem 0 1.25rem;
}
.chapters-nav .checkbox {
  width: 1.875rem;
  height: 1.875rem;
  padding: 0;
  border-radius: 0.625rem;
  background: #e6e6e6;
}
.chapters-nav .checkbox label {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 11;
  width: 100%;
  height: 100%;
  padding: 0.1875rem 0 0;
  font-size: 0.9375rem;
  line-height: 1.46666667;
  text-align: center;
  background: #ffffff;
  border: 1px solid currentColor;
  border-radius: 1rem;
  transition: none;
}
.chapters-nav .checkbox label:before,
.chapters-nav .checkbox label:after {
  content: none;
}
.chapters-nav .chapters-nav .checked label {
  background: #e6e6e6;
  border-color: #e6e6e6;
}
.book-nav-item-red.selected-book-nav-item a {
  background: #ef404a;
}
.book-nav-item-red > a:focus,
.book-nav-item-red > a:hover {
  background: #ef404a;
}
.book-nav-item-red .select-chapter-form .select-all-chapters label:focus,
.book-nav-item-red .select-chapter-form .select-multiple-chapters label:focus,
.book-nav-item-red .select-chapter-form .select-all-chapters label:hover,
.book-nav-item-red .select-chapter-form .select-multiple-chapters label:hover {
  background: #ef404a;
  border-color: #ef404a;
}
.book-nav-item-red .select-chapter-form .select-all-chapters.checked label,
.book-nav-item-red .select-chapter-form .select-multiple-chapters.checked label {
  background: #ef404a;
  border-color: #ef404a;
}
.book-nav-item-red .chapters-nav .checked label {
  background: #ef404a;
  border-color: #ef404a;
}
.book-nav-item-blue.selected-book-nav-item a {
  background: #14b1e7;
}
.book-nav-item-blue > a:focus,
.book-nav-item-blue > a:hover {
  background: #14b1e7;
}
.book-nav-item-blue .select-chapter-form .select-all-chapters label:focus,
.book-nav-item-blue .select-chapter-form .select-multiple-chapters label:focus,
.book-nav-item-blue .select-chapter-form .select-all-chapters label:hover,
.book-nav-item-blue .select-chapter-form .select-multiple-chapters label:hover {
  background: #14b1e7;
  border-color: #14b1e7;
}
.book-nav-item-blue .select-chapter-form .select-all-chapters.checked label,
.book-nav-item-blue .select-chapter-form .select-multiple-chapters.checked label {
  background: #14b1e7;
  border-color: #14b1e7;
}
.book-nav-item-blue .chapters-nav .checked label {
  background: #14b1e7;
  border-color: #14b1e7;
}
.book-nav-item-purple.selected-book-nav-item a {
  background: #b41e8e;
}
.book-nav-item-purple > a:focus,
.book-nav-item-purple > a:hover {
  background: #b41e8e;
}
.book-nav-item-purple .select-chapter-form .select-all-chapters label:focus,
.book-nav-item-purple .select-chapter-form .select-multiple-chapters label:focus,
.book-nav-item-purple .select-chapter-form .select-all-chapters label:hover,
.book-nav-item-purple .select-chapter-form .select-multiple-chapters label:hover {
  background: #b41e8e;
  border-color: #b41e8e;
}
.book-nav-item-purple .select-chapter-form .select-all-chapters.checked label,
.book-nav-item-purple .select-chapter-form .select-multiple-chapters.checked label {
  background: #b41e8e;
  border-color: #b41e8e;
}
.book-nav-item-purple .chapters-nav .checked label {
  background: #b41e8e;
  border-color: #b41e8e;
}
.primary-nav a {
  display: block;
  padding: 1rem 0 1rem 2.5rem;
}
.primary-nav a:focus,
.primary-nav a:hover {
  background: #e6e6e6;
}
.primary-nav .selected a {
  color: #000000;
  background: #e6e6e6;
}
.shop-nav {
  display: flex;
  flex-flow: row;
  padding-left: 2.5rem;
}
.shop-nav .button {
  flex: 0 0 auto;
  height: 3.75rem;
  padding: 0.375rem 2.5rem;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 2.25rem;
  line-height: 1.22222222;
  text-transform: none;
  border-radius: 2rem;
}
.shop-nav .selected-button {
  color: #ffffff;
  background: #000000;
  border-color: #000000;
}
.social {
  display: flex;
  flex-flow: row;
  gap: 0.625rem;
}
.social li {
  flex: 0 0 auto;
}
.social a {
  display: block;
  padding: 0 0.75rem;
}
.aside-social {
  margin-top: 1rem;
  padding-left: 2.5rem;
}
@media (max-width: 959px) {
  .page-inner {
    padding-top: 4.75rem;
  }
  .page-aside {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 999;
    display: block;
    background: #ffffff;
  }
  .page-header {
    display: flex;
    flex-flow: row;
    align-items: center;
  }
  .page-logo {
    flex: 1 1 auto;
  }
  .page-logo br {
    display: none;
  }
  .toggle-nav-button {
    position: relative;
    flex: 0 0 auto;
    width: 1.875rem;
    height: 1.3125rem;
    margin: 0.375rem 1.5rem 0 0;
    padding: 0;
    background: transparent;
    border: 0;
  }
  .toggle-nav-button:before,
  .toggle-nav-button:after,
  .toggle-nav-button span {
    content: '';
    position: absolute;
    left: 0;
    width: 100%;
    height: 3px;
    background: #000000;
    transition: all 0.3s;
  }
  .toggle-nav-button:before {
    top: 0;
  }
  .toggle-nav-button:after {
    bottom: 0;
  }
  .toggle-nav-button span {
    top: 0.5625rem;
    transition: all 0.3s;
  }
  .page-nav {
    position: fixed;
    top: 4.75rem;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1000;
    overflow: auto;
    margin-left: 0;
    padding-bottom: 2rem;
    background: #ffffff;
  }
  .with-page-nav-open {
    overflow: hidden;
  }
  .with-page-nav-open .page-nav {
    display: flex;
  }
  .with-page-nav-open .toggle-nav-button:before,
  .with-page-nav-open .toggle-nav-button:after {
    opacity: 0;
  }
  .with-page-nav-open .toggle-nav-button span {
    transform-origin: 50% 50%;
  }
  .with-page-nav-open .toggle-nav-button span:first-child {
    transform: rotate(36.67deg);
  }
  .with-page-nav-open .toggle-nav-button span:last-child {
    transform: rotate(-36.67deg);
  }
  .book-nav-item a,
  .primary-nav a,
  .shop-nav,
  .aside-social {
    padding-left: 1.5rem;
  }
  .chapters-nav {
    padding: 1.25rem 0;
    gap: 0.5rem 0.5rem;
  }
  .select-chapter-form {
    padding-bottom: 0;
  }
  .select-chapter-form .form-action {
    display: none;
  }
}
@media (min-width: 960px) {
  .page-header {
    margin-left: -2.5rem;
  }
  .page-logo {
    font-size: 3.125rem;
    line-height: 0.9;
  }
  .page-logo a {
    padding: 2.125rem 0 0 2.5rem;
  }
  .toggle-nav-button {
    display: none;
  }
  .page-nav {
    display: flex;
  }
}
/* 8. Footer */
.page-footer {
  padding-top: 4.75rem;
  padding-bottom: 0.5rem;
}
.footer-grid {
  display: flex;
  flex-flow: row wrap;
  gap: 1rem;
  align-items: flex-start;
  justify-content: space-between;
}
.footer-grid a {
  display: block;
}
.colophon {
  display: flex;
  flex-flow: row wrap;
  gap: 1rem;
  align-items: flex-start;
  justify-content: space-between;
  margin-top: 1rem;
  font-size: 0.9375rem;
  line-height: 1.66666667;
  color: #808080;
}
.colophon a {
  color: #808080;
}
.colophon a:focus,
.colophon a:hover {
  color: #000000;
}
.footer-links {
  display: flex;
  flex-flow: row wrap;
  gap: 1rem;
}
.footer-links li {
  flex: 0 0 auto;
}
@media (max-width: 769px) {
  .footer-grid {
    margin-bottom: 2.125rem;
    flex-flow: column;
    align-items: center;
  }
}
@media (max-width: 429px) {
  .footer-grid .button {
    padding: 0 1em;
  }
}
/* 9. Content */
.landmark {
  position: relative;
  top: -4.75rem;
  z-index: -2;
  height: 0;
  margin: 0;
  padding: 0;
  background: green;
  border: 0;
  pointer-events: none;
}
@media (min-width: 960px) {
  .landmark {
    top: -2.25rem;
  }
}
.section {
  padding: 1.5rem 0;
}
.section:first-child {
  padding-top: 0;
}
.section-wip,
.section-error {
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  text-align: center;
}
.section-wip .inner,
.section-error .inner {
  max-width: 38rem;
  margin: 0 auto;
}
.error-image {
  display: block;
  width: 100%;
  max-width: 100%;
  margin: -1.625rem auto 1.625rem;
}
.section-cta {
  margin-top: 2.5rem;
}
.hero-slideshow {
  position: relative;
  width: 100%;
  height: 0;
  overflow: hidden;
  border-radius: 1.25rem;
  margin-bottom: 2rem;
  padding-bottom: 66.58446363%;
}
.hero-slideshow .keen-slider {
  position: absolute !important;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.hero-slideshow .keen-slider-slide {
  height: 100%;
}
.hero-slideshow img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero-slideshow .hero-cta-button {
  position: absolute;
  right: 1.875rem;
  bottom: 1.875rem;
  width: auto;
  padding-right: 2.75rem;
  padding-left: 2.75rem;
  color: #000000;
  background: #ffffff;
  border-color: #000000;
}
.hero-slideshow .hero-cta-button:focus,
.hero-slideshow .hero-cta-button:hover {
  color: #ffffff;
  background: #000000;
  border-color: #000000;
}
@media (max-width: 599px) {
  .hero-slideshow {
    border-radius: 0;
  }
}
.shop-hero {
  display: flex;
  flex-flow: row wrap;
  gap: 0 2rem;
}
.shop-hero > .header {
  position: relative;
  flex: 0 0 auto;
  width: 100%;
  margin-bottom: 2rem;
}
.shop-hero .hero-slideshow {
  margin-bottom: 0;
}
.shop-hero > .main {
  flex: 1 1 auto;
}
.shop-hero > .footer {
  flex: 0 0 auto;
  width: 100%;
  max-width: 22.5rem;
}
.shop-hero .section-title {
  margin-bottom: 0.75rem;
  text-align: left;
}
.shop-hero p {
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}
.shop-hero-image {
  display: block;
  max-width: 100%;
  border-radius: 0.5rem;
}
@media (max-width: 599px) {
  .shop-hero {
    flex-flow: column;
    gap: 1rem;
  }
  .shop-hero > .header {
    width: auto;
    margin-right: -1.5rem;
    margin-bottom: 1rem;
    margin-left: -1.5rem;
  }
  .section-hero .inner {
    margin-right: -1.5rem;
    margin-left: -1.5rem;
  }
  .section-hero .p-large {
    margin-right: 1.5rem;
    margin-left: 1.5rem;
  }
}
.section-order-thanks {
  text-align: center;
}
.thanks-social {
  justify-content: center;
}
@media (max-width: 429px) {
  .thanks-social .button {
    padding: 0 1em;
  }
}
.books-list {
  margin: 0 -0.4375rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.25rem 0;
}
@media (max-width: 659px) {
  .books-list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 459px) {
  .books-list {
    display: flex;
    flex-flow: column;
    gap: 2.25rem;
  }
}
.book-listed a {
  position: relative;
  display: block;
  padding: 0 0.4375rem 1.25rem;
  border-radius: 0.75rem;
  transition: all 0.3s;
}
.book-listed a:before {
  content: '';
  position: absolute;
  top: 11rem;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
  background: #e6e6e6;
  border-radius: 0.8125rem;
  opacity: 0;
  pointer-events: none;
  transition: all 0.3s;
}
.book-listed a:focus,
.book-listed a:hover {
  color: inherit;
}
.book-listed a:focus:before,
.book-listed a:hover:before {
  opacity: 1;
}
.book-listed a:focus .book-listed-image:after,
.book-listed a:hover .book-listed-image:after {
  opacity: 1;
}
.book-listed-red a:focus .book-listed-image:after,
.book-listed-red a:hover .book-listed-image:after {
  content: '01';
  background: #ef404a;
}
.book-listed-blue a:focus .book-listed-image:after,
.book-listed-blue a:hover .book-listed-image:after {
  content: '02';
  background: #14b1e7;
}
.book-listed-purple a:focus .book-listed-image:after,
.book-listed-purple a:hover .book-listed-image:after {
  content: '03';
  background: #b41e8e;
}
.book-listed-title {
  margin-bottom: 0.5rem;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 1.5rem;
  line-height: 1.25;
}
.book-listed-subtitle {
  margin-bottom: 1.25rem;
  font-family: 'Crabath Text', serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
  font-size: 1.1875rem;
  line-height: 1.31578947;
}
.book-listed-image {
  position: relative;
  overflow: hidden;
  margin-bottom: 2rem;
  border-radius: 0.625rem;
}
.book-listed-image:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding-top: 57.5%;
  text-align: center;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 5rem;
  line-height: 1.15;
  background: #b3b3b3;
  opacity: 0;
  transition: none;
}
.book-listed-image img {
  display: block;
  width: 100%;
}
.book-listed-meta {
  margin-bottom: 1.33333333em;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 0.9375rem;
  line-height: 1.33333333;
  text-transform: uppercase;
}
.book-listed-description {
  font-size: 0.9375rem;
  line-height: 1.33333333;
}
@media (min-width: 600px) {
  .book-listed-title {
    font-size: 2.25rem;
    line-height: 1.22222222;
  }
}
.book-header {
  display: flex;
  flex-flow: row;
  margin: -1.375rem -1.375rem 0;
  padding: 1.375rem 4.375rem 1.875rem 1.375rem;
  background: #e6e6e6;
}
.book-number {
  width: 3rem;
  flex: 0 0 auto;
  text-align: left;
}
.book-title {
  display: none;
  width: 15rem;
  flex: 0 0 auto;
  text-align: left;
}
.book-subtitle {
  flex: 1 1 auto;
  font-family: 'Crabath Text', serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
  text-align: center;
}
@media (min-width: 1200px) {
  .book-header {
    padding-right: 16.375rem;
    padding-left: 1.375rem;
  }
  .book-number {
    display: none;
  }
  .book-title {
    display: block;
  }
}
.section-book-chapters {
  padding-top: 1rem;
}
.book-chapters {
  margin-bottom: 1.625rem;
}
.book-chapters-title {
  display: none;
}
@media (min-width: 600px) {
  .book-chapters {
    display: flex;
    flex-flow: row wrap;
    align-items: center;
    gap: 1.875rem;
    margin-bottom: 2.5rem;
  }
  .book-chapters-title {
    display: block;
    flex: 1 0 auto;
    width: 15rem;
    margin: 0;
    text-align: left;
  }
  .book-search-form {
    flex: 1 0 auto;
    width: 15rem;
  }
}
.chapters-list {
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
}
.chapter-listed {
  margin-bottom: 0.125rem;
}
.chapter-listed a,
.chapter-listed span {
  display: block;
  padding: 0.125rem 0;
}
.chapter-listed a {
  display: block;
  background: #ffffff;
  border-radius: 0.1875rem;
}
.chapter-listed .selected-chapter-listed {
  padding-right: 0.5rem;
  padding-left: 0.5rem;
  background: #e6e6e6;
}
.chapters-list-cta {
  display: flex;
  flex-flow: row;
  gap: 0.625rem;
  margin-top: 1.25rem;
}
@media (max-width: 959px) {
  .chapters-list {
    font-size: 1.0625rem;
    line-height: 1.29411765;
  }
}
@media (min-width: 960px) {
  .chapters-list {
    column-count: 2;
    column-gap: 1.875rem;
  }
  .chapter-listed {
    margin-bottom: 0.25rem;
  }
  .chapter-listed a,
  .chapter-listed .selected-chapter-listed {
    padding-right: 0.75rem;
    padding-left: 0.75rem;
  }
  .chapters-list-cta {
    display: none;
  }
}
.chapter-arrows {
  display: none;
}
.chapter-arrows .inner {
  position: relative;
  width: 4.875rem;
  margin-left: auto;
}
.chapter-arrows-inner {
  position: absolute;
  display: flex;
  flex-flow: row;
  gap: 0.375rem;
  justify-content: flex-end;
  width: 4.875rem;
}
.chapter-arrow {
  display: block;
  width: 2.25rem;
  height: 2.25rem;
  background: #ffffff;
  border: 1px solid #000000;
  border-radius: 1.25rem;
}
.chapter-arrow:focus,
.chapter-arrow:hover {
  color: #ffffff;
  background: #000000;
}
.chapter-arrow .ico {
  display: block;
  width: 1.625rem;
  height: 1.625rem;
  margin: 0.25rem auto 0;
}
.chapter-arrow .ico svg {
  display: block;
  width: 100%;
  height: 100%;
}
.selected-chapter-arrows {
  display: block;
}
.selected-chapter-arrows .chapter-arrows-inner {
  position: fixed;
  bottom: 1.25rem;
  z-index: 20;
}
@media (min-width: 960px) {
  .chapter-arrows .inner {
    width: 10rem;
  }
  .chapter-arrows-inner {
    gap: 0.625rem;
    width: 10rem;
  }
  .chapter-arrow {
    width: 4.6875rem;
    height: 4.6875rem;
    border-radius: 2.5rem;
  }
  .chapter-arrow .ico {
    width: 3.125rem;
    height: 3.125rem;
    margin-top: 0.75rem;
  }
  .selected-chapter-arrows .chapter-arrows-inner {
    bottom: 1.75rem;
  }
}
.chapter-image {
  display: block;
  width: 100%;
  margin: 0 auto 3rem;
  border-radius: 0.625rem;
}
.notes-list {
  display: flex;
  flex-flow: column;
  gap: 0;
}
.note-listed {
  position: relative;
  padding: 1.25rem 0;
}
.note-listed > .header {
  display: flex;
  flex-flow: row;
  gap: 1rem;
  align-items: flex-start;
  margin-bottom: 0.5rem;
}
.note-listed > .main {
  word-wrap: break-word;
  overflow-wrap: break-word;
}
.note-listed + .note-listed:before {
  content: '';
  position: absolute;
  top: -1px;
  left: 0;
  right: 0;
  display: block;
  height: 2px;
  background: url('../images/dotted-line.svg') repeat-x;
  background-size: auto 2px;
}
.note-page {
  flex: 0 0 auto;
  display: inline-block;
  padding: 0.125rem 0.625rem;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 0.8125rem;
  line-height: 1.92307692;
  background: #e6e6e6;
  border-radius: 1rem;
}
.note-quote {
  flex: 1 1 auto;
  margin-top: 0.125rem;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 1.0625rem;
  line-height: 1.29411765;
  text-transform: uppercase;
}
@media (min-width: 960px) {
  .note-listed > .header {
    gap: 2.125rem;
    margin-bottom: 0.5rem;
  }
  .note-page {
    padding: 0.125rem 0.875rem;
    font-size: 0.9375rem;
    line-height: 1.66666667;
    border-radius: 1rem;
  }
  .note-quote {
    margin-top: 0.125rem;
    font-size: 1.1875rem;
    line-height: 1.31578947;
  }
}
.highlighted {
  background: #ffffb5;
}
.section-author {
  padding-top: 2.25rem;
}
.about-image,
.author-image {
  display: block;
  width: 100%;
  overflow: hidden;
  aspect-ratio: 1;
  object-fit: cover;
}
.about-image {
  border-radius: 0.5rem;
}
.author-image {
  border-radius: 50%;
}
.section-acknowledged,
.section-team {
  padding-top: 1.5rem;
}
@media (min-width: 960px) {
  .section-acknowledged,
  .section-team {
    padding-top: 4.125rem;
  }
}
@media (min-width: 600px) {
  .two-cols {
    column-count: 2;
    column-gap: 2.125rem;
  }
  .two-cols .small-title {
    margin-bottom: 0;
  }
}
.team-list {
  display: flex;
  flex-flow: column;
  gap: 1.5rem;
}
.team-listed .small-title {
  margin: 0 0 0.25rem;
  text-transform: uppercase;
}
.team-listed p {
  max-width: 32.5rem;
  margin-bottom: 0.65789474em;
}
@media (min-width: 600px) {
  .team-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 2.125rem;
  }
}
/* 10. Tables */
table {
  width: 100% !important;
  margin-bottom: 1.31578947em;
  border-collapse: collapse;
  empty-cells: show;
}
table:last-child {
  margin-bottom: 0;
}
.responsive-table {
  margin-bottom: 1.31578947em;
}
.responsive-table table {
  margin-bottom: 0;
}
th,
td {
  padding: 0.5rem;
  text-align: center;
  vertical-align: top;
  border: 0;
}
/* 11. Forms */
.button {
  position: relative;
  display: inline-block;
  height: 1.93333333em;
  overflow: hidden;
  padding: 0 1.5em;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 0.9375rem;
  line-height: 1.8;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  color: #000000;
  background: transparent;
  border: 1px solid currentColor;
  border-radius: 1.5rem;
  cursor: pointer;
  appearance: none;
  transition: all 0.3s;
}
.button:active,
.button:focus,
.button:hover {
  text-decoration: none;
  color: #ffffff;
  background: #000000;
  border-color: #000000;
  outline: none;
}
.large-button,
.primary-button {
  display: block;
  width: 100%;
  height: 2.55em;
  padding: 0.65em 1.5em;
  font-size: 1.25rem;
  line-height: 1.25;
}
.primary-button {
  background: #ef404a;
  border-color: #ef404a;
}
.primary-button:active,
.primary-button:focus,
.primary-button:hover {
  color: #ffffff;
  background: #000000;
  border-color: #000000;
}
.field {
  position: relative;
}
.field > label {
  display: block;
  margin-bottom: 0.375rem;
}
.field + .field,
.field + .checkbox,
.checkbox + .field,
.fields-grid + .field,
.fields-grid + .checkbox {
  margin-top: 0.5rem;
}
.field + .fields-grid,
.checkbox + .fields-grid {
  margin-top: 0.75rem;
}
.field-disabled label {
  color: #b3b3b3;
  cursor: not-allowed !important;
}
.field-short .input {
  max-width: 7.5rem;
}
.fields-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.625rem;
  margin-bottom: 1.5rem;
}
.fields-grid .field-x2 {
  grid-column: span 2;
}
.fields-grid .field + .field {
  margin-top: 0;
}
.input {
  display: block;
  width: 100%;
  height: 2.5rem;
  padding: 0.5rem 0.75rem 0.5rem 1.25rem;
  color: #000000;
  background: #ffffff;
  border: 1px solid #b3b3b3;
  border-radius: 0.3125rem;
  appearance: none;
}
.input:focus {
  outline: none;
}
.input[readonly] {
  cursor: not-allowed;
}
.input[disabled] {
  color: #b3b3b3;
  cursor: not-allowed;
}
.field-invalid .input {
  color: #ef404a;
  border-color: #ef404a;
}
.field-invalid label {
  color: #ef404a;
}
.textarea {
  height: 17.5rem;
  resize: vertical;
}
.select {
  display: block;
  width: 100%;
  height: 2.5rem;
  padding: 0.625em 0.625rem;
  font-size: 0.875rem;
  line-height: 1.42857143;
  text-transform: lowercase;
  color: #808080;
  background: #ffffff;
  border: 1px solid #808080;
  border-radius: 0;
}
.select:focus {
  outline: none;
}
.checkbox {
  position: relative;
}
.checkbox input {
  position: absolute;
  top: 50%;
  left: 0.5rem;
  z-index: 10;
  margin: 0;
  transform: translateY(-50%);
  opacity: 0;
}
.checkbox label {
  display: block;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  padding-left: 3.0625rem;
  cursor: pointer;
}
.checkbox label:before {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 1;
  width: 1.8125rem;
  height: 1.8125rem;
  background: #ffffff;
  border: 1px solid currentColor;
  border-radius: 1rem;
  transform: translateY(-50%);
}
.checkbox label:after {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 2;
  width: 1.3125rem;
  height: 1.3125rem;
  margin-left: 0.25rem;
  background: #ef404a;
  border-radius: 1rem;
  transform: translateY(-50%);
  opacity: 0;
  transition: all 0.3s;
}
.checkbox label a {
  text-decoration: underline;
}
.checked label:after {
  opacity: 1;
}
.checkboxes {
  display: flex;
  flex-flow: column;
  gap: 0.25rem;
  margin-top: -0.5rem;
  margin-bottom: 1.5rem;
}
.checkboxes .checkbox:nth-child(2n) .radio-option {
  background: #e6e6e6;
}
.radio-option {
  display: flex;
  flex-flow: row;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  min-height: 2.5rem;
  margin-left: -0.75rem;
  padding: 0.25rem 0.75rem;
  border-radius: 0.3125rem;
}
.radio-option-price {
  width: 3.5rem;
  text-align: right;
}
.form-cta {
  margin-top: 3.875rem;
  padding: 2rem 1.25rem;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 2.25rem;
  line-height: 1.22222222;
  background: #e6e6e6;
  border-radius: 0.3125rem;
}
.form-cta .grid {
  margin-bottom: 1.25rem;
}
@media (max-width: 959px) {
  .form-cta .grid {
    display: flex;
    flex-flow: row wrap;
    gap: 0 2.125rem;
    align-items: center;
  }
}
.toggle-form-cta {
  position: fixed;
  right: 0;
  bottom: 1.625rem;
  left: 0;
  z-index: 50;
  pointer-events: none;
}
.toggle-form-cta .page-aside,
.toggle-form-cta .page-content {
  min-height: 0;
  padding-top: 0;
  padding-bottom: 0;
  border: none;
}
.toggle-form-cta-button {
  position: relative;
  max-width: 34rem;
  height: 3.05em;
  padding: 0.9em 1.5em;
  margin: 0 auto;
  border-radius: 1.75em;
  pointer-events: initial;
}
.form-cta-button-total-pieces {
  position: absolute;
  top: 0.4375rem;
  right: 0.625rem;
  width: 2.75rem;
  height: 2.75rem;
  padding-top: 0.5rem;
  font-size: 1.1875rem;
  line-height: 1.31578947;
  text-align: center;
  border: 1px solid currentColor;
  border-radius: 1.5rem;
}
.form-cta-button-total-pieces:empty {
  display: none;
}
.order-form .toggle-form-cta {
  display: none;
}
.order-form-closed .toggle-form-cta {
  display: block;
}
.order-form-closed .section-order-form-contact {
  display: none;
}
@media (min-width: 960px) {
  .toggle-form-cta {
    bottom: 3.625rem;
  }
}
.fields-item-pieces {
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  gap: 0;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 2.25rem;
  line-height: 1.22222222;
}
.fields-item-pieces .item-pieces {
  flex: 0 0 auto;
  width: 8rem;
}
.fields-item-pieces .item-pieces-result {
  flex: 0 0 auto;
  width: 2.375rem;
  text-align: center;
}
.fields-item-pieces .item-price {
  flex: 1 1 auto;
  text-align: center;
}
.fields-item-pieces .item-price-muted {
  color: #b3b3b3;
}
.math-field {
  display: flex;
  flex-flow: row;
  gap: 1rem;
  align-items: center;
}
.math-button {
  width: 1.93333333em;
  height: 1.93333333em;
  padding-right: 0;
  padding-left: 0;
}
@media (max-width: 599px) {
  .fields-item-pieces {
    justify-content: space-between;
  }
  .fields-item-pieces:after {
    display: none;
  }
  .fields-item-pieces .item-price {
    flex: 0 0 auto;
    text-align: right;
  }
}
.shop-products-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(20rem, 1fr));
  gap: 2.5rem 1rem;
}
.shop-product-listed {
  display: flex;
  flex-flow: column;
  gap: 1rem;
}
.shop-product-listed > .header {
  position: relative;
  flex: 0 0 auto;
}
.shop-product-listed > .main {
  flex: 1 1 auto;
}
.shop-product-listed > .footer {
  flex: 0 0 auto;
}
.shop-product-listed .section-title {
  margin-bottom: 0.375rem;
  text-align: left;
}
.shop-product-listed-image {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  object-position: 50% 0;
}
.shop-hero-price-per-piece,
.shop-product-listed-price-per-piece {
  position: absolute;
  right: 0.625rem;
  bottom: 0.625rem;
  z-index: 10;
  padding: 0.125rem 0.625rem;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 0.9375rem;
  line-height: 1.46666667;
  text-align: center;
  background: #ffffff;
  border: 1px solid currentColor;
  border-radius: 1rem;
}
.book-search-form {
  position: relative;
}
.field-search label {
  padding: 0.5rem 3.75rem 0.5rem 1.625rem !important;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 1.5rem;
  line-height: 1.25;
}
.field-search .input {
  height: 3.75rem;
  padding: 0.5rem 3.75rem 0.5rem 1.625rem;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  font-size: 1.5rem;
  line-height: 1.25;
  border-radius: 2rem;
}
.book-search-button {
  position: absolute;
  top: 50%;
  right: 1.5rem;
  display: block;
  width: 1.5625rem;
  height: 1.5625rem;
  margin-top: -0.875rem;
}
.book-search-button .ico {
  display: block;
}
@media (min-width: 960px) {
  .field-search label {
    padding: 0.5rem 5rem 0.5rem 2.5rem !important;
    font-size: 2.25rem;
    line-height: 1.22222222;
  }
  .field-search .input {
    padding: 0.5rem 5rem 0.5rem 2.5rem;
    font-size: 2.25rem;
    line-height: 1.22222222;
    border-radius: 2rem;
  }
  .book-search-button {
    right: 1.875rem;
  }
}
/* 12. Modules */
.message {
  margin-bottom: 2rem;
  padding: 1rem 1.5rem;
  font-family: 'Neue Haas Grotesk Display Pro', Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
  text-align: center;
  border: 1px solid currentColor;
  border-radius: 0.3125rem;
}
.message-warning {
  color: #ef404a;
}
.message-error {
  color: #ffffff;
  background: #ef404a;
  border-color: #ef404a;
}
.message-success {
  color: #ffffff;
  background: #1be413;
  border-color: #1be413;
}
.flash-messages {
  position: absolute;
  right: 0;
  left: 0;
  z-index: 20;
}
.flash-message {
  overflow: hidden;
  margin: 0;
  padding: 0;
}
/* 13. SVG */
.svg {
  display: inline-block;
  overflow: hidden;
  transition: all 0.3s;
}
.svg svg {
  display: block;
}
.svg svg g {
  transition: all 0.3s;
}
.ico {
  color: inherit;
  stroke-width: 0;
  stroke: currentColor;
  fill: currentColor;
  vertical-align: middle;
}
/* 14. Themes */
.page-selected--red .page-content {
  border-color: #ef404a;
}
.page-selected--red .book-header {
  background: #ef404a;
}
.page-selected--red .chapters-list-cta .button:focus,
.page-selected--red .chapters-list-cta .button:hover {
  color: #000000;
  background: #ef404a;
  border-color: #ef404a;
}
.page-selected--red .chapters-list-cta .selected-button {
  color: #000000;
  background: #ef404a;
  border-color: #ef404a;
}
.page-selected--red .note-listed a {
  color: #ef404a;
}
.page-selected--blue .page-content {
  border-color: #14b1e7;
}
.page-selected--blue .book-header {
  background: #14b1e7;
}
.page-selected--blue .chapters-list-cta .button:focus,
.page-selected--blue .chapters-list-cta .button:hover {
  color: #000000;
  background: #14b1e7;
  border-color: #14b1e7;
}
.page-selected--blue .chapters-list-cta .selected-button {
  color: #000000;
  background: #14b1e7;
  border-color: #14b1e7;
}
.page-selected--blue .note-listed a {
  color: #14b1e7;
}
.page-selected--purple .page-content {
  border-color: #b41e8e;
}
.page-selected--purple .book-header {
  background: #b41e8e;
}
.page-selected--purple .chapters-list-cta .button:focus,
.page-selected--purple .chapters-list-cta .button:hover {
  color: #000000;
  background: #b41e8e;
  border-color: #b41e8e;
}
.page-selected--purple .chapters-list-cta .selected-button {
  color: #000000;
  background: #b41e8e;
  border-color: #b41e8e;
}
.page-selected--purple .note-listed a {
  color: #b41e8e;
}
/* 15. JavaScript only */
.js .with-overlaid-labels .field {
  position: relative;
}
.js .with-overlaid-labels .field > label {
  top: -1px;
  left: -1px;
  margin: 0;
  padding: 0.5rem 1.25rem;
  cursor: text;
}
.keen-slider:not([data-keen-slider-disabled]) {
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: transparent;
  align-content: flex-start;
  display: flex;
  overflow: hidden;
  position: relative;
  touch-action: pan-y;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -khtml-user-select: none;
  width: 100%;
}
.keen-slider:not([data-keen-slider-disabled]) .keen-slider__slide {
  min-height: 100%;
  overflow: hidden;
  position: relative;
  width: 100%;
}
.keen-slider:not([data-keen-slider-disabled])[data-keen-slider-reverse] {
  flex-direction: row-reverse;
}
.keen-slider:not([data-keen-slider-disabled])[data-keen-slider-v] {
  flex-wrap: wrap;
}
/* 16. Print */
@media print {
  body {
    color: black;
  }
}
