/* Minimal reset */
*, *::before, *::after { box-sizing: border-box; }

html {
  height: 100%;
  background-color: #000;
}

body::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100lvh;
  background-image: url("../images/efbackground2.jpg");
  background-position: 40%;
  background-size: cover;
  z-index: -1;
}

body { margin: 0; }

a { background-color: transparent; }
a:active, a:hover { outline: 0; }

b, strong { font-weight: bold; }

img { border: 0; vertical-align: middle; max-width: 100%; display: inline-block; }

h1, h2, h3, h4, h5, h6 { margin-bottom: 10px; font-weight: bold; }
h1 { margin-top: 20px; font-size: 38px; line-height: 44px; }
h2 { margin-top: 20px; font-size: 32px; line-height: 36px; }
h3 { margin-top: 20px; font-size: 24px; line-height: 30px; }
h4 { margin-top: 10px; font-size: 18px; line-height: 24px; }
h5 { margin-top: 10px; font-size: 14px; line-height: 20px; }
h6 { margin-top: 10px; font-size: 12px; line-height: 18px; }

p { margin-top: 0; margin-bottom: 10px; }

ul, ol { margin-top: 0; margin-bottom: 10px; padding-left: 40px; }

/* iOS: disable fixed backgrounds on touch devices */
html.touch-device * { background-attachment: scroll !important; }

/* =====================
   Page transition
   ===================== */

.page-overlay {
  position: fixed;
  inset: 0;
  background: #000;
  opacity: 1;
  transition: opacity 1.2s cubic-bezier(.645, .045, .355, 1);
  pointer-events: none;
  z-index: 9999;
}

/* =====================
   Site styles
   ===================== */

@font-face {
  font-family: Soehne;
  src: url("../fonts/soehne-leicht.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Soehne;
  src: url("../fonts/soehne-leicht-kursiv.woff2") format("woff2");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Soehne;
  src: url("../fonts/soehne-buch.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Soehne;
  src: url("../fonts/soehne-buch-kursiv.woff2") format("woff2");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Tiempos Text;
  src: url("../fonts/tiempos-text-regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Tiempos Text;
  src: url("../fonts/tiempos-text-italic.woff2") format("woff2");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Tiempos Text;
  src: url("../fonts/tiempos-text-medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Tiempos Text;
  src: url("../fonts/tiempos-text-medium-italic.woff2") format("woff2");
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Tiempos Text;
  src: url("../fonts/tiempos-text-semibold.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Tiempos Text;
  src: url("../fonts/tiempos-text-semibold-italic.woff2") format("woff2");
  font-weight: 600;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Tiempos Text;
  src: url("../fonts/tiempos-text-bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Tiempos Text;
  src: url("../fonts/tiempos-text-bold-italic.woff2") format("woff2");
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}

.site-wrapper {
  background-color: #bdb9b900;
  display: block;
  position: relative;
}

.site-wrapper.dark-mode {
  color: #e5e5e5;
  background-color: #0e0e0e;
}

.content-column {
  width: 100%;
  max-width: 30rem;
  margin-left: auto;
  margin-right: auto;
  padding-top: 0;
  padding-bottom: 0;
  position: relative;
}

.heading-main {
  text-align: center;
  text-indent: -.01em;
  margin-bottom: 1rem;
  font-size: 2.5rem;
  font-weight: 500;
  line-height: 1.2em;
}

.paragraph {
  text-align: center;
}

.paragraph.text-body {
  margin-top: 1rem;
  margin-bottom: 2rem;
  font-size: 1.125rem;
}

.paragraph.text-body.subtitle {
  letter-spacing: 0;
  margin-top: .1rem;
  font-size: .89rem;
  font-style: italic;
  font-weight: 400;
  line-height: 1.6em;
}

.body {
  color: #000;
  letter-spacing: -.003em;
  background-color: transparent;
  font-family: Tiempos Text, Georgia, sans-serif;
  font-size: .81rem;
  line-height: 2.44em;
}


.card {
  aspect-ratio: 129 / 198;
  background-color: #f6f4ee;
  border-radius: 5px;
  flex-flow: column;
  justify-content: space-between;
  align-items: center;
  margin: 2rem auto;
  display: flex;
  position: static;
}

.card.title-page-padding.right-page-corners, .card.recto-page-corners {
  border-radius: 0 5px 5px 0;
}

.card.verso-page-corners {
  border-radius: 5px 0 0 5px;
}

.extended-title {
  text-align: center;
  letter-spacing: -.6px;
  margin-top: 9.3rem;
  margin-bottom: 0;
  font-size: 2.27rem;
  font-weight: 500;
}

.extended-title.preface-book-title {
  color: #fff;
  text-align: left;
  letter-spacing: -.002em;
  margin-top: 2.1rem;
  margin-bottom: 0;
  margin-left: -2px;
  font-family: Inter, sans-serif;
  font-size: 1.45rem;
  font-weight: 500;
  line-height: 2.2rem;
}

.author-name {
  text-align: center;
  letter-spacing: .008em;
  font-size: .7rem;
}

.author-wrap {
  margin-bottom: 4.2rem;
}

.contents-item {
  letter-spacing: .2em;
  font-size: .8rem;
}

.contents-wrapper {
  width: 100%;
  max-width: 14rem;
  margin-top: 11rem;
}

.contents-row {
  justify-content: space-between;
  align-items: center;
  line-height: 1.6em;
  display: flex;
}

.contents-title {
  letter-spacing: .46em;
  margin-bottom: 0;
  font-size: .64rem;
  font-weight: 500;
  line-height: 3.2em;
}

.contents-title.premise {
  letter-spacing: .46em;
}

.contents-number {
  text-align: right;
  min-width: 2.2em;
  margin-bottom: 0;
  font-size: .74em;
  font-weight: 500;
  line-height: 2.9em;
}

.axiom-wrapper {
  text-align: center;
  letter-spacing: 0;
  margin-top: 11rem;
  font-size: 1.27em;
  font-weight: 500;
}

.axiom-block {
  font-size: .81em;
  font-weight: 400;
}

.margin-wrapper {
  width: 100%;
  height: 100%;
  flex: 1;
  margin-left: auto;
  margin-right: auto;
  padding: 2.4rem 3.6rem 4.9rem;
  position: relative;
}

.margin-wrapper.section-divider {
  flex-flow: column;
  justify-content: space-between;
  align-items: stretch;
  display: flex;
  position: relative;
}

.part-title {
  letter-spacing: .8em;
  font-size: .68rem;
  font-weight: 500;
}

.part-title.part-title-smaller {
  letter-spacing: .46em;
  margin-top: 1.8em;
  font-size: .64rem;
}

.textus-block {
  letter-spacing: 0;
  font-size: .96em;
  line-height: 2.4em;
}

.textus-block.textus-padding {
  padding-top: 1.3rem;
}

.cortex-block {
  letter-spacing: 0;
  margin-top: .2em;
  margin-bottom: .6em;
}

.cortex-block.textus-padding {
  padding-top: 1.3rem;
}

.cortex-block.prologue-italics {
  letter-spacing: 0;
}

.cortex-block.cortex-list {
  margin-top: -.8em;
  margin-bottom: 1em;
}

.cortex-block._136 {
  letter-spacing: -.012em;
}

.cortex-block.corex-religion {
  margin-top: 2em;
}

.cortex-wrapper.prologue-section {
  margin-top: 6.3em;
  margin-bottom: .5em;
}

.cortex-wrapper.immanence-section {
  margin-top: 4.6em;
}

.cortex-wrapper.return-section {
  margin-top: 6.3em;
  margin-bottom: 1.2em;
}

.section-title {
  margin-top: 1em;
  margin-bottom: 0;
  font-size: 1.3em;
  font-weight: 500;
  line-height: 1.8em;
}

.spacer {
  width: 100%;
}

.chapter-title {
  letter-spacing: -.02em;
  margin-top: 0;
  margin-bottom: -.3em;
  font-size: 2em;
  font-weight: 500;
  line-height: 1.2em;
}

.line-spacer {
  width: 100%;
}

.italic-text, .section-italics {
  letter-spacing: -.02em;
}

.medium-span {
  font-weight: 500;
}

.section-title-copy {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1.3em;
  font-weight: 500;
  line-height: 2em;
}

._14-6 {
  letter-spacing: -.02em;
}

.line-spacer-copy {
  width: 100%;
  line-height: 1.2em;
}

.page-number {
  text-align: center;
  min-width: 100%;
  font-size: .6rem;
  position: absolute;
  inset: auto 0% 3.2em;
}

.inscription-wrapper {
  text-align: center;
  padding-top: 9rem;
}

.inscription-title {
  color: #fffffff0;
  font-family: Inter, sans-serif;
  font-size: 0.52rem;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  line-height: 1.5;
  margin-bottom: 0.3rem;
}

.inscription-subtitle {
  color: #ffffff90;
  font-family: Inter, sans-serif;
  font-size: 0.6rem;
  font-weight: 300;
  font-style: normal;
  letter-spacing: 0.01em;
  line-height: 1.5;
  margin-bottom: 0;
}

.end-wrapper {
  text-align: center;
  padding-top: 0;
  padding-bottom: 0.8rem;
  margin-bottom: 0;
}

.end-text-line {
  color: #ffffff70;
  font-family: Inter, sans-serif;
  font-size: .6rem;
  font-weight: 300;
  letter-spacing: 0;
  line-height: 1.5;
  margin-bottom: 0.3rem;
}

.end-link {
  color: #ffffff70;
  text-decoration: none;
  border-bottom: .03em dotted #8e87a4c2;
  padding-bottom: .05em;
}

.end-link:hover {
  color: #ffffffcc;
  border-bottom-color: #ffffffcc;
}

.end-text {
  color: #8e87a4c2;
  text-align: center;
  letter-spacing: 0;
  margin-bottom: .864rem;
  font-family: Arimo, sans-serif;
  font-size: .6rem;
  font-weight: 300;
  position: absolute;
  inset: auto 0% 0%;
}

.nav-link {
  color: #fff;
  letter-spacing: 0;
  border-bottom: .03em dotted #ffffffd6;
  border-radius: 0;
  font-family: Inter, sans-serif;
  font-size: .76rem;
  font-weight: 300;
  line-height: 1.4em;
  text-decoration: none;
}

.nav-link.link-var {
  border-bottom-color: #d9cba2;
}

.nav-link.link-var2 {
  border-bottom-color: #e0d9c6;
}

.nav-link.nav-link-below {
  padding-left: .4em;
  padding-right: .4em;
}

.nav-wrapper {
  text-align: center;
  margin-top: 1.6rem;
  margin-bottom: 5.5rem;
}

.reddit-link {
  letter-spacing: .1em;
}

.card-wrapper {
  margin-top: 1.2em;
  position: relative;
}

.contents-axiom-span {
  letter-spacing: .69em;
}

.field-section {
  width: 88%;
  margin-left: 1.2rem;
  margin-right: auto;
  padding-top: 1.1rem;
  position: sticky;
}

.heading-preface {
  color: #fff;
  text-align: left;
  letter-spacing: .2em;
  -webkit-text-stroke-color: #fff;
  text-shadow: none;
  margin-top: 0;
  margin-bottom: -2px;
  padding-top: 0;
  font-family: Inter, sans-serif;
  font-size: .68rem;
  font-weight: 500;
  line-height: 1.9rem;
}

.preface-text {
  color: #fff;
  text-align: left;
  letter-spacing: 0;
  text-shadow: none;
  font-family: Inter, sans-serif;
  font-size: .76rem;
  font-weight: 300;
  line-height: 2.2em;
}

.preface-text.preface-subtitle {
  margin-top: .55rem;
  margin-bottom: 1.1rem;
  font-family: Inter, sans-serif;
  font-size: .76rem;
  font-style: normal;
  font-weight: 300;
  line-height: 1em;
}

.preface-wrapper {
  opacity: 0;
  border: 1px #000;
  border-left: .03em dashed #ffffffd6;
  border-radius: 6px;
  padding: 100vh 4.1em 5.4em 3em;
}

.preface-line-height {
  min-height: .1em;
}

.link {
  color: #fff;
}

.link.link-support {
  border-bottom: 1px dashed #ffffff70;
  text-decoration: none;
  display: inline;
}

.of-language-span {
  letter-spacing: -.002em;
}

.text-span {
  border-bottom: 1px dashed #fff;
  line-height: 2.3em;
}

.link-seperator {
  color: #9fb3a9ed;
  -webkit-text-stroke-color: #7d9a8ca3;
  background-image: url("../images/separator.png");
  background-position: 0 0;
  background-size: contain;
  padding-bottom: .1em;
  font-size: 1.4rem;
  line-height: 1em;
}

.ef-button {
  color: #ffffffbb;
  font-family: Inter, sans-serif;
  font-size: 1.22rem;
  font-weight: 500;
  font-style: italic;
  letter-spacing: -.01em;
  line-height: 1;
  display: inline-block;
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.08s linear;
}

.ef-button:hover {
  transform: scale(1.12);
  transition: transform 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.ef-button .ef-e {
  font-family: "Tiempos Text", Georgia, serif;
  font-weight: 500;
}

.ef-button .ef-f {
  font-family: "Tiempos Text", Georgia, serif;
  font-weight: 400;
}

.ef-button .ef-colon {
  font-family: Inter, sans-serif;
  font-weight: 300;
  font-style: normal;
  display: inline-block;
  opacity: 0;
}

.link-block {
  width: 100%;
  height: 100%;
  display: inline-block;
  position: relative;
}

.text-span-3 {
  font-family: Figtree, sans-serif;
}

@media screen and (max-width: 991px) {
  .content-column {
    max-width: 658px;
  }

  .paragraph.text-body.subtitle {
    letter-spacing: 0;
    margin-top: 0;
    font-size: .91rem;
  }

  .body {
    background-position: 50%;
    font-size: 1.11rem;
  }

  .extended-title {
    letter-spacing: -.2px;
    margin-top: 12.8rem;
  }

  .extended-title.preface-book-title {
    margin-bottom: 0;
    font-size: 1.6rem;
  }

  .author-name {
    font-size: 1rem;
  }

  .author-wrap {
    margin-bottom: 6.4rem;
  }

  .title-wrapper {
    transform: scale(1.35);
  }

  .contents-wrapper {
    max-width: 19.7rem;
    margin-top: 15.8rem;
  }

  .contents-title {
    font-size: .9rem;
    font-weight: 500;
    line-height: 3em;
  }

  .contents-number {
    margin-bottom: 0;
    font-size: .8em;
    font-weight: 400;
    line-height: 3em;
  }

  .axiom-wrapper {
    margin-top: 15.4rem;
    font-size: 1.09em;
  }

  .margin-wrapper {
    padding: 3.3rem 4.9rem 6.7rem;
  }

  .part-title.part-title-smaller {
    font-size: .9rem;
  }

  .textus-block {
    font-size: .86em;
  }

  .cortex-block {
    letter-spacing: -.001em;
    font-size: 1.09rem;
  }

  .cortex-block.cortex-list {
    margin-top: -.7em;
  }

  .cortex-wrapper.immanence-section {
    margin-top: 3em;
  }

  .chapter-title {
    font-size: 1.9em;
  }

  .page-number {
    font-size: .78rem;
  }

  .end-text {
    font-size: .7rem;
  }

  ._13-6 {
    letter-spacing: -.011em;
  }

  .nav-link {
    font-size: .9rem;
  }


  .field-section {
    width: 80%;
  }

  .heading-preface {
    font-size: .82rem;
  }

  .preface-text {
    letter-spacing: -.001em;
    font-size: .92rem;
    line-height: 2.32em;
  }

  .preface-text.preface-subtitle {
    margin-bottom: 1.8rem;
    font-size: .92rem;
  }

  .preface-wrapper {
    padding-bottom: 5em;
    padding-left: 2.6em;
    padding-right: 4.8em;
  }
}

@media screen and (max-width: 767px) {
  .content-column {
    max-width: 480px;
  }

  .paragraph.text-body.subtitle {
    margin-top: .04rem;
    font-size: .68rem;
    line-height: .9em;
  }

  .card {
    border-radius: 4px;
  }

  .card.title-page-padding.right-page-corners, .card.recto-page-corners {
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px;
  }

  .card.verso-page-corners {
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px;
  }

  .extended-title {
    margin-top: 9rem;
    font-size: 1.7rem;
  }

  .author-name {
    font-size: .64rem;
  }

  .author-wrap {
    margin-bottom: 3.8rem;
  }

  .contents-wrapper {
    max-width: 14.6rem;
    margin-top: 10.6rem;
  }

  .contents-title {
    font-size: .7rem;
    line-height: 2.8em;
  }

  .contents-number {
    font-size: .52em;
    line-height: 2.8em;
  }

  .axiom-wrapper {
    margin-top: 10rem;
  }

  .axiom-block {
    letter-spacing: 0;
    font-size: .65em;
  }

  .margin-wrapper {
    padding: 2rem 4rem 5.6rem;
  }

  .part-title.part-title-smaller {
    margin-top: 2.4em;
    font-size: .64rem;
    line-height: 2.4em;
  }

  .textus-block {
    margin-bottom: 2.2em;
    font-size: .6em;
  }

  .textus-block.textus-padding {
    padding-top: 2.4rem;
  }

  .cortex-block {
    letter-spacing: 0;
    font-size: .65em;
    line-height: 2.6em;
  }

  .cortex-block.prologue-italics {
    font-size: .65em;
    line-height: 2.6em;
  }

  .cortex-wrapper.prologue-section {
    margin-top: 4.8em;
  }

  .cortex-wrapper.immanence-section {
    margin-top: 3em;
  }

  .cortex-wrapper.return-section {
    margin-top: 4.8em;
    margin-bottom: .6em;
  }

  .section-title {
    font-size: 1em;
    line-height: 1.8em;
  }

  .chapter-title {
    margin-bottom: -.3em;
    font-size: 1.4em;
  }

  .page-number {
    font-size: .61rem;
  }

  .end-wrapper {
    margin-bottom: 1em;
  }

  .nav-link {
    font-size: .8rem;
  }


  .field-section {
    width: 92%;
  }

  .heading-preface {
    font-size: .62em;
  }

  .preface-text {
    letter-spacing: -.001em;
    font-size: .8rem;
  }

  .preface-text.preface-subtitle {
    margin-bottom: 1rem;
    font-size: .8rem;
  }

  .preface-wrapper {
    padding-bottom: 4.4em;
    padding-left: 2.4em;
    padding-right: 3.1em;
  }

}

@media screen and (max-width: 479px) {
  .content-column {
    width: 346px;
  }

  .paragraph.text-body.subtitle {
    margin-top: .12rem;
    font-size: .48rem;
    line-height: 0;
  }

  .body {
    background-color: transparent;
  }

  .card {
    background-color: #fffefb;
    border-radius: 3px;
    margin-top: 1.84rem;
    margin-bottom: 1.84rem;
  }

  .card.title-page-padding {
    width: 100%;
  }

  .card.title-page-padding.right-page-corners, .card.recto-page-corners {
    border-top-right-radius: 4px;
    border-bottom-right-radius: 4px;
  }

  .card.verso-page-corners {
    border-top-left-radius: 4px;
    border-bottom-left-radius: 4px;
  }

  .extended-title {
    margin-top: 6.1rem;
    margin-bottom: -3px;
    font-size: 1.18rem;
    line-height: 2em;
  }

  .extended-title.preface-book-title {
    font-size: 1.35rem;
    line-height: 1.9rem;
  }

  .author-name {
    font-size: .55rem;
  }

  .author-wrap {
    margin-bottom: 2.4rem;
  }

  .contents-wrapper {
    max-width: 10.2rem;
    margin-top: 8rem;
  }

  .contents-title {
    font-size: .51rem;
  }

  .contents-number {
    font-size: .42em;
  }

  .axiom-wrapper {
    margin-top: 6.2rem;
  }

  .axiom-block {
    font-size: .49em;
  }

  .margin-wrapper {
    padding: 1.95rem 2.6rem .46rem;
  }

  .margin-wrapper.section-divider {
    padding-bottom: 3.9rem;
    padding-left: 2.3rem;
  }

  .part-title.part-title-smaller {
    margin-top: 2em;
    font-size: .469rem;
  }

  .textus-block {
    font-size: .477em;
  }

  .textus-block.textus-padding {
    padding-top: 1rem;
  }

  .cortex-block {
    margin-top: .1em;
    margin-bottom: .5em;
    font-size: .49em;
    line-height: 2.5em;
  }

  .cortex-block.prologue-italics {
    font-size: .483em;
  }

  .cortex-block.cortex-list {
    margin-bottom: 1.16em;
  }

  .cortex-wrapper.prologue-section {
    margin-top: 3.4em;
    margin-bottom: 0;
  }

  .cortex-wrapper.immanence-section {
    margin-top: 2.2em;
  }

  .cortex-wrapper.return-section {
    margin-top: 3.6em;
    margin-bottom: .1em;
  }

  .section-title {
    margin-top: .8em;
    margin-bottom: .1em;
    font-size: .684em;
    line-height: 1.5em;
  }

  .chapter-title {
    margin-bottom: -.3em;
    font-size: 1.054em;
  }

  .line-spacer {
    line-height: 1.5em;
  }

  .page-number {
    font-size: .46rem;
    bottom: 1.4em;
  }

  .end-text {
    margin-bottom: .164rem;
    font-size: .5rem;
  }

  .nav-link {
    border-bottom-width: .04em;
    font-size: .68rem;
  }

  .nav-link.nav-link-below {
    border-bottom-width: .04em;
  }

  .inscription-wrapper {
    padding-top: 7.3rem;
  }

  .inscription-title {
    font-size: 0.42rem;
  }

  .inscription-subtitle {
    font-size: 0.49rem;
  }

  .nav-wrapper {
    margin-top: 1.3rem;
    margin-bottom: 4.5rem;
  }

  .end-text-line {
    font-size: 0.49rem;
  }



  .field-section {
    width: 100%;
    margin-left: .6rem;
  }

  .heading-preface {
    font-size: .58em;
  }

  .preface-text {
    letter-spacing: -.001em;
    margin-bottom: 8px;
    font-size: .68rem;
    line-height: 2.14em;
  }

  .preface-text.preface-subtitle {
    font-size: .7rem;
  }

  .preface-wrapper {
    border-left-color: #fffffff0;
    padding-bottom: 3.5em;
    padding-left: 1.75em;
    padding-right: .6em;
  }

  .of-language-span {
    letter-spacing: -.006em;
  }

  .text-span-2 {
    letter-spacing: .001em;
  }

}
