a,
a:link {
  color: #ff86bc;
}
.font-chapter,
.font-series,
.font-title {
  font-weight: 400;
  font-style: normal;
}
.main-container,
.page-header,
hr {
  position: relative;
}
.footer-link,
a {
  text-decoration: none;
}
.footer-logo,
.logo-wrapper {
  left: 50%;
  transform: translateX(-50%);
}
.cl-title,
.nav-link-wn.active {
  color: #ff86bc !important;
}
.body {
  background-image: url(/assets/img/background.svg);
  background-repeat: repeat;
  background-size: 30px 30px;
}
.page-header {
  height: 100px;
  background-color: #fff;
}
.font-title {
  font-family: "Kosugi Maru", sans-serif;
}
.font-series {
  font-family: "Libertinus Serif Display", system-ui;
  font-size: 25px;
}
.font-chapter {
  font-family: "Roboto Mono", monospace;
  font-optical-sizing: auto;
  display: block;
  margin-bottom: 0 !important;
}
ul.list-unstyled li {
  margin-bottom: 0;
}
a.font-chapter {
  line-height: 1.2;
}
hr {
  border: none;
  height: 20px;
}
hr::before {
  content: "──── ˚ʚ♡ɞ˚ ────";
  font-family: Georgia, serif;
  color: #9c9c9cff;
  line-height: 1;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.latest-updates-header {
  display: flex;
  align-items: center;
  text-align: center;
}
.latest-updates-header::after,
.latest-updates-header::before {
  content: "";
  flex-grow: 1;
  height: 1px;
  background-color: #ffd3e7ff;
  margin: 0 1rem;
}
.main-container {
  min-height: 400px;
  background-color: #fff0f7ff;
  z-index: 1;
  margin-top: -50px;
  box-shadow: 0 4px 8px #ff87cb;
}
.logo-wrapper {
  position: absolute;
  top: 40px;
  z-index: 10;
}
.overlapping-logo {
  width: 250px;
  height: auto;
}
.card {
  padding: 0;
}
.card-body {
  padding: 10px;
}
.card-img-wrapper {
  flex-shrink: 0;
  width: 120px;
  padding: 10px 12px 5px 3px;
}
.card-cover-thumb {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 5px;
}
.tag-container {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}
.color-tag {
  color: #3a3a3aff;
  padding: 3px 8px;
  border-radius: 5px;
  font-size: 0.8rem;
}
.bottom-right-icon {
  position: absolute;
  bottom: 0;
  right: 0;
  margin-bottom: 15px;
  margin-right: 20px;
  font-size: 20px;
  color: #f9d38f;
}
.footer-container {
  background-color: #f8f9fa;
  overflow: hidden;
  position: relative;
  z-index: 2;
}
.footer-link {
  color: #6c757d;
  font-weight: 700;
}
.footer-link:hover {
  text-decoration: underline;
}
.footer-logo {
  position: absolute;
  top: -25px;
  width: 100px;
  z-index: 4;
}
.home-hr {
  border-top: 2px dashed #9c9c9cff;
  border-width: 2px;
  padding: 0 !important;
  margin: 0 !important;
}
.home-hr::before,
.novel-hr::before {
  content: none;
}
.navbar-bg-default {
  background-color: #ffffffff !important;
}
.novel-hr {
  border-top: 1px dashed #9c9c9cff;
  border-width: 2px;
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}
.novel-bottom-navbar {
  background: #ffd3e7ff !important;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100vw;
  z-index: 1030;
}
.toc-button-container {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1000;
}
.toc-button-container button {
  background-color: #fff0f7ff;
  border-radius: 50%;
  height: 60px;
  width: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 3px solid #ffd3e7ff;
}
.toc-button-container button:hover {
  background-color: #fff0f7ff !important;
  border-radius: 50%;
  border: 3px solid #ffd3e7ff;
}
.bg-toc {
  background: #fff0f7ff !important;
}
.toc-link {
  color: #000 !important;
}
.ascii-art-container {
  display: flex;
  justify-content: center;
}
.nav-link-wn {
  background-color: #ff86bc !important;
  color: #fff0f7ff !important;
  padding: 10px !important;
  border-radius: 10px 10px 0 0 !important;
}
.nav-link-wn.active,
.tab-pane {
  background-color: #ffffffff !important;
}
.table-details-wn th {
  width: 30%;
}
.table-details-wn td {
  width: 70%;
}
.table-details-wn td,
.table-details-wn th {
  border-bottom: none !important;
  border-top: none !important;
}
.nav-item-wn,
.nav-link-wn,
.nav-link-wn.active,
.nav-tabs-wn {
  border: none !important;
}
.tab-pane {
  border: 2px solid #ffffffff;
  border-radius: 0 15px 15px;
}
