@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
* {
  box-sizing: border-box;
}

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

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

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

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

a {
  color: inherit;
  cursor: pointer;
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 0;
}

select::-ms-expand {
  display: none;
}

input[type=number] {
  -moz-appearance: textfield;
}

input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button {
  -webkit-appearance: none;
}

.reset [type=number] {
  -moz-appearance: spinner-textfield;
}

.reset input[type=number]::-webkit-outer-spin-button,
.reset input[type=number]::-webkit-inner-spin-button {
  -webkit-appearance: spinner-textfield;
}

button,
input {
  outline: none;
  background: none;
  border: none;
}

/* FONTS */
@font-face {
  font-family: "LibreBaskerville";
  src: url("../fonts/libre-baskerville/LibreBaskerville-Regular.woff2") format("woff2"), url("../fonts/libre-baskerville/LibreBaskerville-Regular.woff") format("woff"), url("../fonts/libre-baskerville/LibreBaskerville-Regular.otf") format("opentype"), url("../fonts/libre-baskerville/LibreBaskerville-Regular.ttf") format("truetype");
  font-style: normal;
  font-weight: normal;
}
@font-face {
  font-family: "LibreBaskerville";
  src: url("../fonts/libre-baskerville/LibreBaskerville-Italic.woff2") format("woff2"), url("../fonts/libre-baskerville/LibreBaskerville-Italic.woff") format("woff"), url("../fonts/libre-baskerville/LibreBaskerville-Italic.otf") format("opentype"), url("../fonts/libre-baskerville/LibreBaskerville-Italic.ttf") format("truetype");
  font-style: italic;
  font-weight: normal;
}
@font-face {
  font-family: "LibreBaskerville";
  src: url("../fonts/libre-baskerville/LibreBaskerville-Bold.woff2") format("woff2"), url("../fonts/libre-baskerville/LibreBaskerville-Bold.woff") format("woff"), url("../fonts/libre-baskerville/LibreBaskerville-Bold.otf") format("opentype"), url("../fonts/libre-baskerville/LibreBaskerville-Bold.ttf") format("truetype");
  font-style: normal;
  font-weight: bold;
}
@font-face {
  font-family: "FreeUniversal";
  src: url("../fonts/freeuniversal/FreeUniversal-Regular.woff2") format("woff2"), url("../fonts/freeuniversal/FreeUniversal-Regular.woff") format("woff"), url("../fonts/freeuniversal/FreeUniversal-Regular.ttf") format("truetype");
  font-style: normal;
  font-weight: normal;
}
@font-face {
  font-family: "FreeUniversal";
  src: url("../fonts/freeuniversal/FreeUniversal-Italic.woff2") format("woff2"), url("../fonts/freeuniversal/FreeUniversal-Italic.woff") format("woff"), url("../fonts/freeuniversal/FreeUniversal-Italic.ttf") format("truetype");
  font-style: italic;
  font-weight: normal;
}
@font-face {
  font-family: "FreeUniversal";
  src: url("../fonts/freeuniversal/FreeUniversal-Bold.woff2") format("woff2"), url("../fonts/freeuniversal/FreeUniversal-Bold.woff") format("woff"), url("../fonts/freeuniversal/FreeUniversal-Bold.ttf") format("truetype");
  font-style: normal;
  font-weight: bold;
}
/* VARIABLE */
:root {
  --line-height: 1.6rem;
  --border-thickness: 0.1rem;
}

/* GENERAL */
em {
  font-style: italic;
}

strong {
  font-weight: bold;
}

p {
  width: 95%;
}
p em {
  font-style: italic;
}

.serif,
.headerText,
.quote,
.preface .content,
.booktitle h3 {
  font-family: "LibreBaskerville", Times, serif;
  font-size: 1rem;
}
.serif em,
.headerText em,
.quote em,
.preface .content em,
.booktitle h3 em {
  font-size: 1.07rem;
}

.message {
  position: fixed;
  background: yellow;
  left: 0;
  padding: 1rem 2rem 1rem 1rem;
  bottom: 0;
  width: 100%;
  z-index: 999999;
}
.message a {
  color: blue;
}

body.news main .newsletter,
.newsletter {
  margin-bottom: var(--line-height);
  break-inside: avoid;
}
body.news main .newsletter h4,
.newsletter h4 {
  margin-bottom: 0;
}
body.news main .newsletter input,
.newsletter input {
  font-family: "FreeUniversal";
  font-size: 1.2rem;
}
body.news main .newsletter input[type=email],
.newsletter input[type=email] {
  background: #eee;
  padding: 0.4rem;
  margin-top: calc(var(--line-height) / 2);
  width: 22rem;
}
body.news main .newsletter input[type=submit],
.newsletter input[type=submit] {
  margin-top: calc(var(--line-height) / 2);
  color: blue;
  padding: 0;
  font-weight: normal;
}

html {
  font-size: 1vw;
  scroll-behavior: smooth;
}

body {
  padding: 2rem 0 20vh 0;
  padding: 2rem 0 20dvh 0;
  background: gainsboro;
  font-family: "FreeUniversal", Arial, sans-serif;
  font-size: 1.2rem;
  line-height: 1.6rem;
}
body h1, body h2 {
  display: none;
}
body > header nav {
  position: fixed;
  top: 1.1rem;
  left: 1rem;
  z-index: 9999999;
}
body > header nav #shelf::-webkit-scrollbar {
  display: none;
}
body > header nav #shelf {
  display: flex;
  flex-wrap: wrap;
  width: 8rem;
  padding: calc(var(--line-height) / 2) 0 0 1rem;
  margin-left: -1rem;
  max-height: calc(100vh - 9.5rem);
  max-height: calc(100dvh - 9.5rem);
  overflow: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
body > header nav #shelf figure {
  margin: 0 calc(var(--line-height) / 2) calc(var(--line-height) / 2) 0;
  width: 1.75rem;
  transition: opacity 0.5s;
}
body > header nav #shelf figure img {
  display: block;
  width: 1.75rem;
  box-shadow: 0 0 12px dimgrey;
}
body > header nav #shelf figure.wait {
  cursor: wait;
}
body > header nav #shelf + a {
  padding-top: calc(var(--line-height) / 4);
}
body > header nav a {
  display: block;
  line-height: calc(var(--line-height) - 0.4rem);
  margin: 0 0 calc(0.4rem - var(--border-thickness)) 0;
}
body > header nav a span {
  display: inline-block;
  border-bottom: solid var(--border-thickness) transparent;
}

/* NON CATALOG PAGES */
body.news main a,
body.about main a,
body.rights main a {
  color: blue;
}

body.news,
body.about,
body.rights,
body.error {
  padding: 0 0 0 0;
}
body.news main,
body.about main,
body.rights main,
body.error main {
  padding: 1rem 17.8571428571vw;
}

/* ERROR */
body.error main {
  margin-top: calc(40vh - 3.2rem);
  margin-top: calc(40dvh - 3.2rem);
  font-size: 3rem;
  line-height: 4rem;
  text-align: center;
}

/* RIGHTS */
body.rights .name:not(:last-of-type)::after,
.drawer.rights .name:not(:last-of-type)::after {
  content: ", ";
}
body.rights li::before,
.drawer.rights li::before {
  content: "• ";
}
body.rights .title,
.drawer.rights .title {
  font-family: "FreeUniversalI", Arial, sans-serif;
}

body.rights h3, body.rights h4, body.rights ul {
  margin-bottom: var(--line-height);
}
body.rights .intro {
  margin-bottom: var(--line-height);
}
body.rights .author.multiple .booklist {
  display: none;
}
body.rights .author.multiple.open .booklist {
  display: block;
}
body.rights .letters {
  columns: 2;
}
body.rights .letters .section,
body.rights .letters .letter {
  break-inside: avoid;
}

/* NEWS */
body.news main {
  padding-right: 1rem;
}
body.news main .intro {
  margin-bottom: var(--line-height);
}
body.news main .day.upcoming {
  width: 22rem;
  display: inline-block;
  vertical-align: top;
  margin: 0 calc(var(--line-height) * 1) var(--line-height) 0;
  padding: calc(var(--line-height) / 2);
  background: #eee;
}
body.news main .day.upcoming .content figure,
body.news main .day.upcoming .content {
  margin-bottom: var(--line-height);
}
body.news main .day.upcoming .info {
  position: relative;
  display: flex;
  justify-content: space-between;
}
body.news main .day.upcoming .info figure {
  display: flex;
  flex-wrap: wrap;
  top: 0;
}
body.news main .day.upcoming .info figure a:not(:last-of-type) {
  margin-right: 0.5rem;
}
body.news main .day.upcoming .info figure img {
  box-shadow: 0 0 12px dimgrey;
  display: block;
  width: 1.75rem;
}
body.news main .day.upcoming .content figure img {
  margin: 0 auto;
  display: block;
  max-width: 100%;
  max-height: 400px;
}
body.news main h3, body.news main h3, body.news main .year {
  margin-bottom: var(--line-height);
}
body.news main h4 {
  display: inline-block;
}
body.news main .year table {
  color: grey;
}
body.news main .year table td {
  padding-right: 1.5rem;
}
body.news main .year table td:nth-child(1) {
  width: 9rem;
}
body.news main .year table td:nth-child(2) {
  width: 15rem;
}
body.news main .year table .month-name {
  color: #000;
}
body.news main .year table .month-name td {
  padding-bottom: var(--line-height);
}
body.news main .year table .month-name:not(:first-of-type) td {
  padding-top: var(--line-height);
}
body.news main .year table .cancelled td:nth-child(3) span {
  text-decoration: line-through;
  text-decoration-thickness: 3px;
}
body.news main .year:not(.current) table {
  display: none;
}
body.news main .year.current h4 {
  margin-bottom: var(--line-height);
}

/* ABOUT */
body.about main sup {
  vertical-align: super;
  line-height: 0;
  font-size: 0.75rem;
}
body.about main ul {
  margin-bottom: var(--line-height);
}
body.about main p {
  width: 80%;
  margin-bottom: var(--line-height);
}
body.about main .shortcode {
  margin: 0 0.75rem 0 0;
  display: inline-block;
  width: 4rem;
}
body.about main h3 {
  margin-bottom: var(--line-height);
}
body.about main .credits {
  font-size: 0.8rem;
  line-height: 1rem;
  display: inline-block;
  margin-top: calc(var(--line-height) * 3);
}

body.book-selection .books .book:not(.loaded) {
  opacity: 0;
}
body.book-selection .books .book.loaded {
  min-height: 20vw;
}
body.book-selection .books .book {
  width: 33.3333333333vw;
  margin-top: 0;
  margin-left: 33.3333333333vw;
  break-inside: avoid;
  position: relative;
  transition: margin 1s;
  opacity: 1;
  transition: opacity 0.5s;
  min-height: 20vh;
  min-height: 20dvh;
}
body.book-selection .books .book p:not(:first-of-type) {
  text-indent: 4rem;
}
body.book-selection .books .book .smalltitle {
  display: none;
}
body.book-selection .books .book .booktitle {
  position: absolute;
  opacity: 1;
  transition-property: opacity;
  transition-delay: 1s;
  margin-top: -15.5%;
  margin-left: -17%;
  width: 46.25vw;
  display: flex;
  justify-content: space-between;
}
body.book-selection .books .book .booktitle h3 {
  padding-top: 0.1rem;
  padding-right: 1rem;
}
body.book-selection .books .book .booktitle * {
  display: inline;
}
body.book-selection .books .book .booktitle .title {
  font-style: italic;
  font-size: 1.07rem;
}
body.book-selection .books .book .booktitle .subtitle:not(:nth-child(1))::before {
  content: " ";
}
body.book-selection .books .book .booktitle .authors:not(:nth-child(1))::before,
body.book-selection .books .book .booktitle .credits:not(:nth-child(1))::before {
  content: ", ";
}
body.book-selection .books .book .booktitle .authors span:not(:last-of-type)::after {
  content: " & ";
}
body.book-selection .books .book .booktitle .authors span {
  orphans: 2;
}
body.book-selection .books .book .booktitle .small-price {
  font-family: "FreeUniversal";
}
body.book-selection .books .book .cover.other-size .spine {
  height: 123.5%;
  right: 86%;
  transform: translateY(-9.5%);
  -moz-transform: translateY(-9.5%);
  -webkit-transform: translateY(-9.5%);
}
body.book-selection .books .book .cover.other-size img.front {
  width: 108%;
  max-width: 108%;
}
body.book-selection .books .book .cover {
  width: 75%;
  -webkit-perspective: 50vw;
  -moz-perspective: 50vw;
  -moz-transform: perspective(50vw);
  perspective: 50vw;
  transform-style: preserve-3d;
  -webkit-transform-style: preserve-3d;
  -moz-transform-style: preserve-3d;
  transform: rotate(-90deg) translateY(12.5%);
  transition: transform 1s;
  margin-top: -7.5vw;
}
body.book-selection .books .book .cover img {
  max-height: 100%;
  border: solid 1px transparent;
}
body.book-selection .books .book .cover .slider {
  transform-style: preserve-3d;
  -webkit-transform-style: preserve-3d;
  -moz-transform-style: preserve-3d;
}
body.book-selection .books .book .cover .slider .directions {
  display: none;
}
body.book-selection .books .book .cover .slider .images {
  transform-style: preserve-3d;
  -webkit-transform-style: preserve-3d;
  -moz-transform-style: preserve-3d;
}
body.book-selection .books .book .cover .slider .images img:not(.visible) {
  display: none;
}
body.book-selection .books .book .cover .slider .counter {
  display: none;
}
body.book-selection .books .book .cover .spine {
  position: absolute;
  z-index: 35;
  height: 121.25%;
  display: block;
  opacity: 1;
  right: 93%;
  transform: translateY(-8.75%);
  -moz-transform: translateY(-8.75%);
  -webkit-transform: translateY(-8.75%);
  transition-property: opacity;
  -moz-transition-property: opacity;
  -webkit-transition-property: opacity;
  transition-delay: 1s;
  transform-style: inherit;
}
body.book-selection .books .book .cover .spine img {
  max-height: 100%;
  display: block;
}
body.book-selection .books .book .cover img.front {
  transform: rotateY(45deg) scale(1);
  -moz-transform: rotateY(45deg) scale(1);
  -webkit-transform: rotateY(45deg) scale(1);
  width: 100%;
  display: block;
  max-width: 100%;
  border-left: solid 0.5px lightgrey;
}
body.book-selection .books .book .stockists {
  justify-content: space-between;
  font-family: "FreeUniversal", "Arial", sans-serif;
  font-size: 1.2rem;
}
body.book-selection .books .book .stockists a {
  color: blue;
}
body.book-selection .books .book .stockists a::after {
  color: black;
}
body.book-selection .books .book .stockists a:not(:last-of-type)::after {
  content: ",";
}
body.book-selection .books .book .stockists a:last-of-type::after {
  content: ".";
}
body.book-selection .books .book .stockists label, body.book-selection .books .book .stockists select {
  display: inline-block;
}
body.book-selection .books .book .stockists select {
  padding: 0;
  background: none;
}
body.book-selection .books .book .under {
  width: 100%;
  display: none;
  padding: 1.2rem 11vw 0 1.2rem;
}
body.book-selection .books .book .under .price .figure {
  font-size: 2.4rem;
  line-height: 3.2rem;
  font-family: "FreeUniversal", Arial, sans-serif;
  display: inline-block;
}
body.book-selection .books .book .top {
  display: none;
  width: 50%;
  padding: 0 1rem;
}
body.book-selection .books .book .top .close {
  position: absolute;
  right: 0.75rem;
  font-size: 2.8rem;
  top: 2rem;
  z-index: 999999;
  text-shadow: 2px 2px 2px grey;
}
body.book-selection .books .book .top .close::after {
  content: "×";
  display: inline-block;
  border-radius: 3rem;
  font-family: "FreeUniversal";
}
body.book-selection .books .book .top .about {
  margin: 0 0 2rem 0;
}
body.book-selection .books .book .top .about header {
  margin: calc(var(--line-height) + 1rem) 0 1.6rem 0;
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
}
body.book-selection .books .book .top .about header .title {
  width: 100%;
}
body.book-selection .books .book .top .about header .title .pdf-button {
  position: absolute;
  right: 8rem;
  padding: 0.5rem;
  background: red;
  color: white;
}
body.book-selection .books .book .top .about header .title .pdf-button a {
  color: inherit;
}
body.book-selection .books .book .top .about header .title .pdf-button:hover {
  cursor: pointer;
}
body.book-selection .books .book .top .about header .title h3 {
  max-width: calc(100% - 1.5rem);
  font-size: 2.4rem;
  line-height: 3rem;
  margin-bottom: 0.5rem;
}
body.book-selection .books .book .top .about header .title h4 {
  display: inline-block;
  margin: 0 0 1.6rem 0;
}
body.book-selection .books .book .top .about header .title h5 span {
  display: block;
}
body.book-selection .books .book .top .about header .title h5.multiple {
  columns: 2;
}
body.book-selection .books .book .top .about .headerText {
  margin-right: 15%;
}
body.book-selection .books .book .top .about .headerText .author {
  font-family: "FreeUniversal";
  font-size: 1.2rem;
}
body.book-selection .books .book .top .about .headerText .quote {
  margin-bottom: var(--line-height);
}
body.book-selection .books .book .top .specs {
  margin-top: 1.6rem;
}
body.book-selection .books .book .top .specs ul:not(.block) li {
  display: inline;
}
body.book-selection .books .book .top .specs ul:not(.block) li:not(:last-of-type)::after {
  content: " | ";
}
body.book-selection .books .book .top .drawer {
  width: 90%;
}
body.book-selection .books .book .top .drawer img {
  max-width: 100%;
}
body.book-selection .books .book .top .drawer h3 {
  position: relative;
}
body.book-selection .books .book .top .drawer h3 .subpart .count {
  font-size: 1.1rem;
  display: inline-block;
}
body.book-selection .books .book .top .drawer h3 .subpart::after {
  position: absolute;
  right: 0.25rem;
}
body.book-selection .books .book .top .drawer .content {
  display: none;
}
body.book-selection .books .book .top .drawer.open .content {
  display: block;
  margin: 1.6rem 0;
}
body.book-selection .books .book .top .bios .text figure {
  max-width: 50%;
  margin: var(--line-height) 0;
}
body.book-selection .books .book .top .bios .text figure img {
  display: block;
}
body.book-selection .books .book .top .bios .text figure figcaption {
  font-size: 0.8rem;
}
body.book-selection .books .book .top .drawer.open.specs ul li .name {
  display: inline-block;
  color: darkgrey;
  width: 4.3rem;
}
body.book-selection .books .book .top .drawer.news {
  padding-right: 0;
}
body.book-selection .books .book .top .drawer.news a {
  color: blue;
}
body.book-selection .books .book .top .drawer.news table td {
  padding-right: 1.5rem;
}
body.book-selection .books .book .top .drawer.open.preface .text {
  /* bask */
  /* paragraphs */
}
body.book-selection .books .book .top .drawer.open.press .ref::before {
  content: "* ";
  position: absolute;
  margin-left: -1rem;
  color: #000;
}
body.book-selection .books .book .top .drawer.open.press a {
  color: blue;
}
body.book-selection .books .book .top .drawer.open.press .ref {
  padding: 0 0 0 1rem;
}
body.book-selection .books .book .top .drawer.open.press .ref span:not(:last-of-type)::after {
  content: ", ";
}
body.book-selection .books .book .top .drawer.open.press .ref .author {
  color: #000;
}
body.book-selection .books .book .top .drawer.open.press .ref .title a::after {
  content: "’";
}
body.book-selection .books .book .top .drawer.open.press .ref .title a::before {
  content: "‘";
}
body.book-selection .books .book .top .line.endorsement {
  margin: 0 0 1.6rem 0;
  break-inside: avoid;
  max-width: 80%;
}
body.book-selection .books .book .top .line.endorsement .quote {
  display: inline;
  margin: 0 1rem 0 0;
  /* bask */
}
body.book-selection .books .book .top .line.endorsement .quote p {
  display: inline;
}
body.book-selection .books .book .top .line.endorsement .quote::before {
  content: "“";
}
body.book-selection .books .book .top .line.endorsement .quote::after {
  content: "”";
}
body.book-selection .books .book .top .line.endorsement .author {
  display: block;
  text-align: right;
  padding-right: 0.5rem;
}
body.book-selection .books .book.preview {
  margin-left: 1rem;
  padding-bottom: 1.2rem;
}
body.book-selection .books .book.preview .booktitle {
  display: none;
}
body.book-selection .books .book.preview .cover {
  width: calc(50vw - 1rem);
  transform: rotate(0);
  transition: transform 1s;
  margin-top: 0;
  -webkit-perspective: none;
  -moz-perspective: none;
  -moz-transform: perspective(none);
  perspective: none;
  margin-left: none;
  padding: calc(var(--line-height) + 1rem) 0 1rem 8rem;
}
body.book-selection .books .book.preview .cover .slider .directions {
  position: absolute;
  display: none;
  left: 0;
  z-index: 9;
  width: 100%;
}
body.book-selection .books .book.preview .cover .slider .directions > * {
  width: calc((100% - 2rem) / 2);
  height: 100%;
}
body.book-selection .books .book.preview .cover .slider .directions > *::before {
  content: " ";
  display: block;
}
body.book-selection .books .book.preview .cover .slider .images {
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
body.book-selection .books .book.preview .cover .slider .images img {
  max-height: 65vw;
  max-width: 95%;
}
body.book-selection .books .book.preview .cover .slider .images img.front {
  transform: rotateY(0);
  transition: transform 1s, width 1s;
  max-width: 70%;
  width: unset;
  margin: 0 auto;
}
body.book-selection .books .book.preview .cover .spine {
  transition-property: opacity;
  transition-delay: 0s;
  opacity: 0;
}
body.book-selection .books .book.preview.done.scrolled.cross .close {
  position: absolute;
}
body.book-selection .books .book.preview.done.scrolled.bottom .cover {
  position: absolute;
  top: unset;
  bottom: 0;
}
body.book-selection .books .book.preview.done.scrolled .cover {
  position: fixed;
  top: 0;
}
body.book-selection .books .book.preview.done.scrolled .close {
  position: fixed;
  top: 2rem;
}
body.book-selection .books .book.preview.done.scrolled .top {
  margin-left: calc(50vw - 1rem);
}
body.book-selection .books .book.preview.done {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  align-items: flex-start;
  z-index: 2;
  width: calc(100% - 1rem);
  padding-bottom: unset;
}
body.book-selection .books .book.preview.done .cover {
  border-radius: 2rem;
}
body.book-selection .books .book.preview.done .cover .under {
  display: block;
  z-index: 99;
}
body.book-selection .books .book.preview.done .cover .slider:not(.one) .counter {
  display: block;
  text-align: center;
  margin-top: 0.75rem;
}
body.book-selection .books .book.preview.done .cover .slider:not(.one) .directions {
  display: flex;
}
body.book-selection .books .book.preview.done .top {
  display: block;
}

body.maintenance {
  text-align: center;
}

/*# sourceMappingURL=main_2.9.css.map */
