:root {
  --qno-bg: #f3ead8;
  --qno-footer-surface: #eadfcf;
  --qno-text: #2a2622;
  --qno-muted: rgba(42, 38, 34, 0.72);
  --qno-accent: #6a4b2f;
  --qno-accent-2: #9b7a57;

  --font-body: "Almarai", serif;
  --font-head: "Libre Baskerville", serif;

  --qno-bg-texture: url('/static/sites/quillobscura/images/parchment_bg.png');
  --qno-header-texture: var(--qno-bg-texture);
  --qno-header-height: 118px;
}

body.site-quillobscura {
  background-color: var(--qno-bg);
  background-image: var(--qno-bg-texture);
  background-repeat: repeat;
  background-size: 512px 512px;
  color: var(--qno-text);
  font-family: var(--font-body);
  overflow-x: hidden;
}

body.site-quillobscura img {
  max-width: 100%;
  height: auto;
}

body.site-quillobscura .qno-responsive-image {
  max-width: 560px;
  width: 100%;
  height: auto;
}

body.site-quillobscura .qno-two-thirds-image {
  width: 33.333%;
  max-width: 33.333%;
}

body.site-quillobscura .qno-genesis-centered {
  text-align: center;
}

body.site-quillobscura .qno-genesis-centered h1 {
  font-size: clamp(2.1rem, 2.8vw + 1.2rem, 3.1rem);
}

body.site-quillobscura .qno-genesis-kicker,
body.site-quillobscura .qno-genesis-verse,
body.site-quillobscura .qno-genesis-byline {
  font-family: var(--font-head);
  color: var(--qno-text);
  line-height: 1.1;
  margin: 0.18rem 0;
}

body.site-quillobscura .qno-genesis-kicker {
  font-size: clamp(1.5rem, 1.6vw + 1rem, 2.2rem);
  font-weight: 700;
  margin-top: 0.35rem;
}

body.site-quillobscura .qno-genesis-line2 {
  font-size: clamp(1.05rem, 1.1vw + 0.8rem, 1.45rem);
  font-weight: 700;
}

body.site-quillobscura .qno-genesis-verse,
body.site-quillobscura .qno-genesis-byline {
  font-size: clamp(1.2rem, 1.3vw + 0.95rem, 1.8rem);
  font-weight: 600;
}

body.site-quillobscura .qno-genesis-gap {
  margin-bottom: 1.45rem;
}

body.site-quillobscura .qno-genesis-body-text {
  font-size: 1.5rem;
}

body.site-quillobscura .qno-author-name {
  font-family: var(--font-head);
  font-size: clamp(1.2rem, 1.2vw + 1rem, 1.75rem);
  font-weight: 700;
  color: var(--qno-text);
  margin: 0.05rem 0 0.15rem;
}

body.site-quillobscura a {
  color: var(--qno-accent);
  text-decoration: none;
}

body.site-quillobscura a:hover {
  color: #4b3522;
  text-decoration: underline;
}

body.site-quillobscura h1,
body.site-quillobscura h2,
body.site-quillobscura h3 {
  color: var(--qno-text);
  font-family: var(--font-head);
}

body.site-quillobscura h1 {
  font-size: clamp(1.7rem, 2.0vw + 1.1rem, 2.6rem);
}

body.site-quillobscura h2 {
  font-size: clamp(1.2rem, 1.2vw + 1rem, 1.75rem);
}

body.site-quillobscura .qno-header-banner {
  background-image: var(--qno-header-texture);
  background-repeat: repeat;
  background-size: 512px 512px;
  border-bottom: 0;
  height: var(--qno-header-height);
  min-height: var(--qno-header-height);
}

body.site-quillobscura .qno-header-banner img.qno-nav-wordmark {
  max-width: min(520px, 68vw);
  max-height: calc(var(--qno-header-height) - 24px);
  width: auto;
  height: auto;
}

body.site-quillobscura main section {
  margin: 0.5625rem 0;
  padding: 1.25rem;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 12px;
}

@media (max-width: 576px) {
  body.site-quillobscura main section {
    margin: 0.3125rem 0;
    padding: 1rem;
  }
}

body.site-quillobscura .navbar {
  background: transparent;
  border-bottom: 0;
  /* Keep parchment visible; blur tends to read as an opaque band on some browsers. */
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  position: relative;
  padding-bottom: 0.5rem;
}

body.site-quillobscura .site-nav.navbar,
body.site-quillobscura .site-nav.navbar * {
  background-color: transparent !important;
  background-image: none !important;
}

body.site-quillobscura .site-nav.navbar {
  --bs-navbar-toggler-border-color: rgba(0, 0, 0, 0.95);
  --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.4' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

body.site-quillobscura .site-nav .navbar-toggler {
  border-width: 2px;
}

body.site-quillobscura .site-nav .navbar-toggler-icon {
  background-image: var(--bs-navbar-toggler-icon-bg) !important;
}

body.site-quillobscura .site-nav .navbar-toggler:focus {
  box-shadow: 0 0 0 0.15rem rgba(0, 0, 0, 0.18);
}

body.site-quillobscura .navbar::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 5px;
  background: var(--qno-accent);
}

body.site-quillobscura .navbar .nav-link {
  color: var(--qno-text);
}

body.site-quillobscura .navbar .nav-link:hover,
body.site-quillobscura .navbar .nav-link:focus {
  color: var(--qno-accent);
}

body.site-quillobscura .qno-nav-wordmark {
  height: auto;
  width: min(520px, 60vw);
  max-height: 34px;
}

body.site-quillobscura .site-header,
body.site-quillobscura .site-nav,
body.site-quillobscura .site-content,
body.site-quillobscura .site-footer {
  width: 100%;
}

body.site-quillobscura .site-content-grid {
  display: grid;
  align-items: flex-start;
}

body.site-quillobscura .qno-content-grid--split {
  grid-template-columns: minmax(0, 35%) minmax(0, 65%);
  gap: 1.25rem;
}

body.site-quillobscura .qno-content-grid--qverse {
  grid-template-columns: minmax(0, 65%) minmax(0, 35%);
  gap: 1.25rem;
}

body.site-quillobscura .qno-content-grid--qverse .site-content-secondary {
  order: 0;
}

body.site-quillobscura .qno-content-grid--single {
  grid-template-columns: 1fr;
  gap: 0;
}

body.site-quillobscura .qno-content-grid--single .site-content-secondary {
  display: none;
}

body.site-quillobscura .site-content-primary {
  min-width: 0;
}

body.site-quillobscura .site-content-secondary {
  min-width: 0;
  display: block;
  order: -1;
}

body.site-quillobscura .qno-home-sidebar h2 {
  text-align: center;
}

body.site-quillobscura .qno-home-content-section h2 {
  text-align: center;
}

body.site-quillobscura .site-content .qno-home-content-section {
  font-size: 1.2rem;
}

body.site-quillobscura .qno-links-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  align-items: start;
  text-align: center;
}

body.site-quillobscura .qno-links-left,
body.site-quillobscura .qno-links-right {
  display: grid;
  gap: 0.75rem;
  text-align: center;
}

body.site-quillobscura .qno-links-page-title {
  margin: 0 0 0.85rem;
  text-align: center;
  font-family: var(--font-head);
  color: var(--qno-text);
  font-size: clamp(1.7rem, 2.0vw + 1.1rem, 2.6rem);
}

body.site-quillobscura .qno-links-left ul,
body.site-quillobscura .qno-links-right ul {
  list-style: none;
  padding-left: 0;
  margin-left: 0;
  margin-right: 0;
}

body.site-quillobscura .qno-links-left li,
body.site-quillobscura .qno-links-right li {
  text-align: center;
}

body.site-quillobscura .qno-hamster-content-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  align-items: start;
}

body.site-quillobscura .qno-hamster-cover img {
  width: 100%;
  height: auto;
  display: block;
}

body.site-quillobscura .qno-qverse-intro-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  align-items: start;
}

body.site-quillobscura .qno-qverse-intro-image {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 0.75rem;
}

body.site-quillobscura .qno-qverse-psi-image {
  width: 90%;
  max-width: 90%;
  height: auto;
}

body.site-quillobscura .qno-qverse-actions .qno-sidebar-button {
  width: 80%;
  margin-left: auto;
  margin-right: auto;
  display: block;
  text-align: center;
}

@media (max-width: 767px) {
  body.site-quillobscura .site-content-grid {
    grid-template-columns: 1fr;
  }

  body.site-quillobscura .site-content-primary,
  body.site-quillobscura .site-content-secondary {
    min-width: 0;
  }

  body.site-quillobscura .qno-links-grid {
    grid-template-columns: 1fr;
  }

  body.site-quillobscura .qno-hamster-content-grid {
    grid-template-columns: 1fr;
  }

  body.site-quillobscura .qno-qverse-intro-grid {
    grid-template-columns: 1fr;
  }

  body.site-quillobscura .qno-qverse-intro-image {
    justify-content: center;
  }

  body.site-quillobscura .qno-qverse-psi-image {
    width: 63%;
    max-width: 63%;
  }
}

body.site-quillobscura footer {
  color: var(--qno-muted);
  border-top: 0;
}

body.site-quillobscura .qno-footer-surface {
  background-color: var(--qno-footer-surface);
  background-image: none;
}

/* Ensure the footer itself is an opaque surface; the swoop is the divider. */
body.site-quillobscura .qno-footer-surface footer.site-footer {
  background-color: var(--qno-footer-surface);
  background-image: none;
}

body.site-quillobscura .qno-footer-swoop {
  line-height: 0;
  width: 100%;
}

body.site-quillobscura .qno-footer-swoop svg {
  display: block;
  width: 100%;
  height: 56px;
}

body.site-quillobscura .qno-footer-swoop path {
  fill: var(--qno-footer-surface);
  stroke: none;
}

body.site-quillobscura .qno-ticker {
  position: relative;
  background: transparent;
  margin: 0;
  padding: 0;
  overflow: hidden;
  white-space: nowrap;
  border-bottom: 0;
}

body.site-quillobscura .qno-ticker::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1.6px;
  background: #6a4b2f;
  pointer-events: none;
  z-index: 2;
}

body.site-quillobscura .qno-ticker .container-lg {
  background: transparent;
  padding-right: 0;
  padding-left: 0;
}

body.site-quillobscura .qno-ticker--marquee {
  padding: 0.4em 0;
}

body.site-quillobscura .qno-ticker--marquee .qno-ticker-track {
  display: inline-flex;
  white-space: nowrap;
  font-family: var(--font-head);
  font-size: 1.6em;
  line-height: 1;
  animation: qno-ticker-scroll 18s linear infinite;
  will-change: transform;
}

body.site-quillobscura .qno-ticker-track span {
  display: inline-block;
  padding-right: 3rem;
}

body.site-quillobscura .qno-sidebar-button {
  display: inline-block;
  padding: 0.5rem 0.85rem;
  background: #000;
  color: #fff;
  text-decoration: none;
  border-radius: 8px;
}

body.site-quillobscura .qno-sidebar-button:hover,
body.site-quillobscura .qno-sidebar-button:focus {
  background: #222;
  color: #fff;
}

body.site-quillobscura .qno-sidebar-button--outline {
  background: transparent;
  color: #000;
  border: 1px solid #000;
}

body.site-quillobscura .qno-sidebar-button--outline:hover,
body.site-quillobscura .qno-sidebar-button--outline:focus {
  background: rgba(0, 0, 0, 0.08);
  color: #000;
}

body.site-quillobscura .site-content-sidebar .qno-sidebar-button,
body.site-quillobscura .site-content-secondary .qno-sidebar-button {
  display: block;
  text-align: center;
  width: 80%;
  margin-left: auto;
  margin-right: auto;
}

body.site-quillobscura .qno-hamster-actions .qno-sidebar-button {
  width: 80%;
  margin-left: auto;
  margin-right: auto;
  display: block;
  text-align: center;
}

body.site-quillobscura .qno-hamster-actions p {
  text-align: center;
}

body.site-quillobscura .qno-author-copy {
  text-align: center;
}

body.site-quillobscura .qno-sidebar-actions {
  margin-top: 1rem;
}

body.site-quillobscura .qno-sidebar-actions p {
  margin: 0.15rem 0;
}

body.site-quillobscura .qno-about-content-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  align-items: flex-start;
}

body.site-quillobscura .qno-about-sidebar {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

body.site-quillobscura .qno-about-sidebar > section {
  margin: 0;
  padding: 0;
}

body.site-quillobscura .qno-about-sidebar > section,
body.site-quillobscura .qno-about-sidebar .qno-author-name,
body.site-quillobscura .qno-about-sidebar p,
body.site-quillobscura .qno-about-sidebar li {
  text-align: center;
}

body.site-quillobscura .qno-about-sidebar .qno-author-name {
  margin: 0.05rem 0 0.15rem;
}

body.site-quillobscura .qno-about-sidebar p {
  margin: 0 0 1rem;
}

body.site-quillobscura .qno-about-sidebar-meta {
  margin: 0;
}

body.site-quillobscura .qno-about-sidebar-media {
  line-height: 0;
  margin-bottom: 0.2rem;
}

body.site-quillobscura .qno-about-sidebar-meta {
  margin-top: 0 !important;
}

body.site-quillobscura .qno-about-sidebar img {
  margin-left: auto;
  margin-right: auto;
  display: block;
}

body.site-quillobscura .qno-about-left,
body.site-quillobscura .qno-about-right {
  min-width: 0;
}

body.site-quillobscura .qno-about-accolades {
  list-style: none;
  padding-left: 0;
  margin: 0.2rem 0 0;
  text-align: center;
}

body.site-quillobscura .qno-about-accolades li {
  margin-bottom: 0.25rem;
}

body.site-quillobscura .qno-about-main-content {
  font-size: 1.25rem;
  line-height: 1.7;
}

body.site-quillobscura .qno-about-main-content h2 {
  font-size: 1.8rem;
}

body.site-quillobscura .qno-about-main-content a {
  font-weight: 700;
}

@media (max-width: 767px) {
  body.site-quillobscura .qno-about-content-grid {
    grid-template-columns: 1fr;
  }

  body.site-quillobscura .qno-about-left,
  body.site-quillobscura .qno-about-right {
    width: 100%;
  }
}

body.site-quillobscura .qno-footer-grid {
  display: flex;
  flex-wrap: nowrap;
  gap: 1rem;
}

body.site-quillobscura .qno-footer-left,
body.site-quillobscura .qno-footer-right {
  width: 70%;
}

body.site-quillobscura .qno-footer-right {
  width: 30%;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
}

body.site-quillobscura .qno-footer-right > div {
  width: 50%;
  text-align: center;
}

body.site-quillobscura .qno-footer-left {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
}

body.site-quillobscura .qno-footer-title {
  text-align: left;
}

body.site-quillobscura .qno-footer-title h2 {
  margin-top: 0;
  margin-bottom: 0.35rem;
  font-size: clamp(1.75rem, 2.1vw + 1rem, 2.6rem);
  font-weight: 700;
}

body.site-quillobscura .qno-footer-right strong {
  font-size: 1rem;
  font-weight: 700;
}

body.site-quillobscura .qno-footer-right div {
  font-size: 0.95rem;
}

@media (max-width: 767px) {
  body.site-quillobscura .qno-footer-grid {
    flex-wrap: wrap;
  }

  body.site-quillobscura .qno-footer-left,
  body.site-quillobscura .qno-footer-right {
    width: 100%;
  }

  body.site-quillobscura .qno-footer-right {
    display: block;
  }

  body.site-quillobscura .qno-footer-right > div {
    width: 100%;
    text-align: left;
  }
}

@keyframes qno-ticker-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
