/* =========================================
   Explorer Theme - Noir
   $B>\:Y%Z!<%8@lMQ(B
   $B?'!&<A46!&J8;z!&H/8w$@$1(B
   ========================================= */

/* =========================================
   0. $B%F!<%^JQ?t(B
   $B8DJL%"%/%;%s%H(B --accent $B$O>e=q$-$7$J$$(B
   ========================================= */

:root {
  --exp-bg-main: #0b0d10;
  --exp-panel: rgba(15, 17, 20, 0.78);
  --exp-panel-2: rgba(15, 17, 20, 0.62);

  --exp-line-1: rgba(255, 255, 255, 0.10);
  --exp-line-2: rgba(255, 255, 255, 0.06);

  --exp-text-1: rgba(255, 255, 255, 0.92);
  --exp-text-2: rgba(255, 255, 255, 0.72);
  --exp-text-3: rgba(255, 255, 255, 0.48);

  --exp-shadow-1: 0 20px 60px rgba(0, 0, 0, 0.35);
  --exp-shadow-2: 0 24px 90px rgba(0, 0, 0, 0.45);
}


/* =========================================
   1. $B>\:Y%Z!<%8A4BN$N6u5$46(B
   explorer-detail $B$@$1$K8z$+$;$kA[Dj(B
   ========================================= */

body {
  color: var(--exp-text-2);
}

/* $B$4$/Gv$$%9%-%c%s@~(B */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    repeating-linear-gradient(
      0deg,
      rgba(255,255,255,0.02),
      rgba(255,255,255,0.02) 1px,
      transparent 1px,
      transparent 3px
    ),
    repeating-linear-gradient(
      90deg,
      rgba(255,255,255,0.015),
      rgba(255,255,255,0.015) 1px,
      transparent 1px,
      transparent 3px
    );
  opacity: 0.12;
}

/* $B>e2<$N6u5$46(B */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,0.03), transparent 60%),
    radial-gradient(circle at 70% 80%, rgba(0,0,0,0.25), transparent 60%);
  opacity: .9;
}

/* $BHy:Y%N%$%:(B */
html::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image: radial-gradient(rgba(255,255,255,0.10) 1px, transparent 1px);
  background-size: 3px 3px;
  opacity: 0.03;
}


/* =========================================
   2. $B>\:Y%+!<%I(B
   ========================================= */

.card {
  color: var(--exp-text-2);
  background: var(--exp-panel);
  border: 1px solid var(--exp-line-2);
  box-shadow: var(--exp-shadow-2);
}

.card h2 {
  color: var(--exp-text-1);
}

/* $B%+!<%IA4BN$N%0%i%G6u5$46(B */
.card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background:
    radial-gradient(
      circle at 72% 18%,
      color-mix(in srgb, var(--accent-safe) 16%, transparent) 0%,
      transparent 58%
    ),
    linear-gradient(
      to bottom,
      rgba(0,0,0,0) 70%,
      rgba(0,0,0,0.30) 84%,
      rgba(0,0,0,0.82) 100%
    );
}

.card > * {
  z-index: 2;
}


/* =========================================
   3. CLASSIFIED
   ========================================= */

.classified {
  top: 34px !important;
  right: 48px !important;
  z-index: 3 !important;

  opacity: 0.12 !important;
  transform: rotate(-18deg) !important;

  color: color-mix(in srgb, var(--accent-safe) 22%, transparent) !important;
  font-size: 44px;
  letter-spacing: .38em;
}


/* =========================================
   4. $B%?%V(B
   ========================================= */

.tab-menu {
  border-bottom: 1px solid var(--exp-line-2);
}

.tab-btn {
  color: var(--exp-text-2);
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--accent-safe) 35%, rgba(255,255,255,0.10));
}

.tab-btn.active {
  color: var(--exp-text-1);
  background: color-mix(in srgb, var(--accent-safe) 22%, transparent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent-safe) 45%, transparent) inset;
}


/* =========================================
   5. $BL>A0$^$o$j(B
   ========================================= */

.name-sub .roman {
  color: rgba(255,255,255,0.55);
}

.name-sub .name-line {
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--accent-safe) 55%, transparent),
    transparent
  );
  box-shadow: 0 0 12px color-mix(in srgb, var(--accent-safe) 18%, transparent);
  opacity: .9;
}


/* =========================================
   6. NOTES
   ========================================= */

.note {
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(0,0,0,0.06);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent-safe) 10%, transparent) inset;
}

.note-head {
  border-bottom: 1px solid rgba(255,255,255,0.10);
}

.note-title {
  color: rgba(255,255,255,0.55);
}

.note-rule {
  display: none;
}

.note .intro {
  color: rgba(255,255,255,0.86);
}


/* =========================================
   7. $B>pJsI=(B
   ========================================= */

.info-grid {
  border-top: 1px solid var(--exp-line-2);
  border-bottom: 1px solid var(--exp-line-2);
}

.info-grid .k {
  color: rgba(255,255,255,0.38);
}

.info-grid .v {
  color: rgba(255,255,255,0.82);
}

.info-grid .row::before {
  background: rgba(255,255,255,0.08);
}


/* =========================================
   8. SAN$B%P!<(B
   ========================================= */

.san-label {
  color: var(--exp-text-2);
}

.san-value {
  color: var(--exp-text-1);
}

.san-max {
  color: var(--exp-text-3);
}

.san-bar {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
}

.san-fill {
  background: linear-gradient(
    90deg,
    rgba(255,255,255,0.95),
    color-mix(in srgb, var(--accent-safe) 78%, rgba(255,255,255,0.6)) 45%,
    color-mix(in srgb, var(--accent-safe) 55%, transparent)
  ) !important;
  box-shadow: 0 0 8px color-mix(in srgb, var(--accent-safe) 18%, transparent);
}

.san-fill::after {
  content: none !important;
}


/* =========================================
   9. $B%l!<%@!<$N%+%P!<(B
   ========================================= */

.radar-cover {
  background:
    radial-gradient(
      circle at center,
      rgba(8,10,14,0.85) 0%,
      rgba(8,10,14,0.65) 55%,
      rgba(8,10,14,0.0) 100%
    );
  backdrop-filter: blur(18px) saturate(0.7) brightness(0.7);
  -webkit-backdrop-filter: blur(18px) saturate(0.7) brightness(0.7);

  -webkit-mask-image: radial-gradient(
    circle at center,
    rgba(0,0,0,1) 55%,
    rgba(0,0,0,0.6) 75%,
    rgba(0,0,0,0) 100%
  );
  mask-image: radial-gradient(
    circle at center,
    rgba(0,0,0,1) 55%,
    rgba(0,0,0,0.6) 75%,
    rgba(0,0,0,0) 100%
  );
}

.radar-cover-title {
  color: rgba(255,255,255,0.92);
}

.radar-cover-desc {
  color: rgba(255,255,255,0.62);
}


/* =========================================
   10. $BN)$A3((B / $BGX7J(B
   ========================================= */

/* =========================================
   10. $BN)$A3((B / $BGX7J(B
   $BGX7J%U%'!<%I=$@5HG(B
   ========================================= */

.profile-right,
.portrait,
.profile-bg {
  overflow: visible !important;
}

.portrait {
  position: relative !important;
  z-index: 2 !important;
}

.portrait::before {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 38% !important;
  transform: translate(-50%, -50%) !important;
  width: 70% !important;
  height: 70% !important;
  border-radius: 50% !important;
  z-index: 0 !important;
  pointer-events: none !important;

  background: radial-gradient(
    circle,
    color-mix(in srgb, var(--accent-safe) 18%, transparent) 0%,
    color-mix(in srgb, var(--accent-safe) 8%, transparent) 38%,
    transparent 75%
  ) !important;

  filter: blur(18px) !important;
}

.portrait img {
  position: relative !important;
  z-index: 1 !important;

  -webkit-mask-image: linear-gradient(
    to bottom,
    rgba(0,0,0,1) 0%,
    rgba(0,0,0,1) 72%,
    rgba(0,0,0,0.55) 86%,
    rgba(0,0,0,0) 100%
  ) !important;

  mask-image: linear-gradient(
    to bottom,
    rgba(0,0,0,1) 0%,
    rgba(0,0,0,1) 72%,
    rgba(0,0,0,0.55) 86%,
    rgba(0,0,0,0) 100%
  ) !important;

  filter:
    drop-shadow(0 0 5px color-mix(in srgb, var(--accent-safe) 20%, transparent))
    drop-shadow(0 0 25px color-mix(in srgb, var(--accent-safe) 6%, transparent)) !important;
}

.portrait::after {
  content: "" !important;
  position: absolute !important;
  left: -16% !important;
  right: -16% !important;
  bottom: -12% !important;
  height: 46% !important;
  pointer-events: none !important;
  z-index: 3 !important;

  background: radial-gradient(
    ellipse at 50% 30%,
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,0.35) 55%,
    rgba(0,0,0,0.85) 100%
  ) !important;
}
/* =========================================
   11. $B%j%s%/%\%?%s(B
   ========================================= */

.profile-links {
  opacity: 0.75;
}

.profile-link {
  color: rgba(255,255,255,0.70);
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.08);
}

.profile-link:hover {
  color: #fff;
  border-color: var(--accent-safe);
}

.link-icon {
  fill: rgba(255,255,255,0.7);
}

.profile-link:hover .link-icon {
  fill: var(--accent-safe);
}


/* =========================================
   12. spoiler $B%?%V(B
   ========================================= */

.spoiler-box {
  background: rgba(0,0,0,0.22);
  border: 1px solid rgba(255,255,255,0.08);
}

.spoiler-content {
  color: rgba(255,255,255,0.78);
  filter: blur(10px);
  opacity: 0.35;
}

.spoiler-cover {
  background: rgba(0,0,0,0.35);
  backdrop-filter: blur(6px);
}

.spoiler-title {
  color: rgba(255,255,255,0.92);
}

.spoiler-desc {
  color: rgba(255,255,255,0.62);
}

.spoiler-box.open .spoiler-content {
  filter: none;
  opacity: 1;
}


/* =========================================
   13. VISUAL $B%a%$%s(B
   ========================================= */

.visual-lock-card {
  color: rgba(255,255,255,0.94);
  border: 1px solid rgba(255,255,255,0.16);
  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.05) 0%,
      rgba(255,255,255,0.02) 100%
    ),
    rgba(18, 14, 22, 0.28);
  box-shadow:
    0 8px 24px rgba(0,0,0,0.18),
    0 0 24px rgba(255,255,255,0.04);
}

.visual-lock-title {
  color: rgba(255,255,255,0.92);
}

.visual-lock-sub {
  color: rgba(255,255,255,0.72);
}


/* =========================================
   14. VISUAL $B1&%5%`%M(B
   $B?'$@$1(B
   ========================================= */

.visual-side-thumbs.has-scroll.can-scroll-top::before,
.visual-side-thumbs.has-scroll.can-scroll-bottom::after {
  color: rgba(255,255,255,0.72) !important;
  text-shadow: 0 0 8px rgba(0,0,0,0.45) !important;
}

.visual-side-thumbs.is-locked .visual-side-thumb img {
  filter: blur(10px) !important;
  -webkit-filter: blur(10px) !important;
  opacity: 0.5 !important;
}

button.visual-side-thumb,
button.visual-side-thumb:focus,
button.visual-side-thumb:focus-visible,
button.visual-side-thumb:active,
button.visual-side-thumb.is-active {
  appearance: none !important;
  -webkit-appearance: none !important;
  -webkit-tap-highlight-color: transparent !important;
  outline: none !important;
  background: transparent !important;
  border: 1px solid rgba(255,255,255,0.20) !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.12) !important,
    0 0 10px rgba(255,255,255,0.08) !important,
    0 0 16px rgba(255,255,255,0.04) !important;
  filter: none !important;
}

button.visual-side-thumb img,
button.visual-side-thumb:focus img,
button.visual-side-thumb:focus-visible img,
button.visual-side-thumb:active img,
button.visual-side-thumb.is-active img {
  box-shadow: none !important;
  filter: none !important;
}

.visual-side-thumb.is-active img {
  border: 1.5px solid rgba(255,255,255,0.75) !important;
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.25),
    0 0 10px rgba(255,255,255,0.15),
    0 0 24px rgba(255,255,255,0.08) !important;
  transform: scale(1.07);
}


/* =========================================
   15. $B%5%`%M%m%C%/%+!<%I(B
   ========================================= */

.thumb-lock-overlay {
  background: rgba(18, 14, 22, 0.34) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

.thumb-lock-text {
  color: rgba(255,255,255,0.94) !important;
  border: 1px solid rgba(255,255,255,0.24) !important;
  background: rgba(18, 14, 22, 0.32) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.18) !important;
}

.lock-icon {
  color: rgba(255,255,255,0.96) !important;
  text-shadow:
    0 0 8px rgba(255,255,255,0.20),
    0 0 14px rgba(255,255,255,0.08);
}

.thumb-lock-text .lock-sub {
  opacity: 0.88 !important;
}

.thumb-lock-text .lock-tags {
  opacity: 0.80 !important;
}


/* =========================================
   16. $B:9J,%"%$%3%s(B
   ========================================= */

.variation-heading span {
  opacity: 0.55;
}

.variation-thumb {
  border: 1px solid rgba(255,255,255,.28);
  background: rgba(255,255,255,.05);
  box-shadow: 0 6px 18px rgba(0,0,0,.16);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.variation-label {
  color: rgba(255,255,255,.82);
}

.variation-item.is-active .variation-thumb {
  border-color: rgba(255,255,255,.88);
  box-shadow:
    0 0 0 1px rgba(255,255,255,.2),
    0 8px 22px rgba(255,255,255,.12);
  transform: translateY(-2px);
}


/* =========================================
   17. Works
   ========================================= */

.related-works-title {
  color: rgba(255,255,255,0.94);
}

.related-works-subtitle {
  color: rgba(255,255,255,0.48);
}

.related-work-card {
  color: inherit;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01)),
    rgba(10,10,14,0.96);
  border: 1px solid rgba(255,255,255,0.09);
  box-shadow:
    0 10px 30px rgba(0,0,0,0.28),
    inset 0 1px 0 rgba(255,255,255,0.04);
}

.related-work-card:hover {
  border-color: rgba(255,255,255,0.18);
  box-shadow:
    0 16px 34px rgba(0,0,0,0.34),
    0 0 0 1px rgba(255,255,255,0.03) inset;
}

.related-work-thumb {
  background:
    radial-gradient(circle at 70% 20%, rgba(255,255,255,0.06), transparent 38%),
    linear-gradient(160deg, rgba(25,25,32,1), rgba(8,8,12,1));
}

.related-work-card:hover .related-work-thumb img {
  filter: brightness(0.92);
}

.related-work-type,
.related-work-spoiler {
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.related-work-type {
  color: rgba(255,255,255,0.95);
  background: rgba(44,50,78,0.74);
  border: 1px solid rgba(255,255,255,0.14);
}

.related-work-type--illust {
  background: rgba(87, 62, 124, 0.72);
}

.related-work-type--novel {
  background: rgba(120, 57, 89, 0.74);
}

.related-work-type--log {
  background: rgba(58, 79, 122, 0.76);
}

.related-work-type--other {
  background: rgba(92, 92, 92, 0.76);
}

.related-work-type--music {
  background: rgba(54, 96, 120, 0.76);
}

.related-work-spoiler {
  color: rgba(255,255,255,0.96);
  background: rgba(142, 28, 47, 0.82);
  border: 1px solid rgba(255,255,255,0.14);
}

.related-work-overlay {
  opacity: 0.82;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.00) 45%, rgba(0,0,0,0.72) 100%);
  transition: opacity .24s ease, background .24s ease;
}

.related-work-card:hover .related-work-overlay {
  opacity: 1;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.05) 38%, rgba(0,0,0,0.78) 100%);
}

.related-work-title {
  color: rgba(255,255,255,0.94);
  opacity: 0;
  text-shadow: 0 1px 6px rgba(0,0,0,0.35);
}

.related-work-card:hover .related-work-title {
  opacity: 1;
}

.related-work-thumb--novel {
  background:
    radial-gradient(circle at 50% 30%, rgba(255,255,255,0.08), transparent 34%),
    linear-gradient(145deg, rgba(10,8,12,1), color-mix(in srgb, var(--work-accent, #8f6b7a) 22%, #0b0b10));
}

.related-work-thumb--log {
  background:
    radial-gradient(circle at 50% 30%, rgba(255,255,255,0.06), transparent 34%),
    linear-gradient(145deg, rgba(8,10,18,1), color-mix(in srgb, var(--work-accent, #5a6c95) 18%, #0a0d14));
}

.related-work-thumb--other {
  background:
    radial-gradient(circle at 50% 30%, rgba(255,255,255,0.05), transparent 34%),
    linear-gradient(145deg, rgba(14,14,16,1), color-mix(in srgb, var(--work-accent, #666) 14%, #101014));
}

.related-work-thumb--music {
  background:
    radial-gradient(circle at 50% 30%, rgba(255,255,255,0.07), transparent 34%),
    linear-gradient(145deg, rgba(8,12,18,1), color-mix(in srgb, var(--work-accent, #557a96) 20%, #091018));
}

.related-work-thumb--illust,
.related-work-thumb--textcard {
  background:
    radial-gradient(circle at 50% 30%, rgba(255,255,255,0.08), transparent 34%),
    linear-gradient(145deg, rgba(8,8,12,1), color-mix(in srgb, var(--work-accent, #8f6b7a) 20%, #0b0b10));
}

.related-work-thumb--novel::after,
.related-work-thumb--log::after,
.related-work-thumb--illust::after,
.related-work-thumb--textcard::after {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.02), transparent 28%),
    repeating-linear-gradient(
      0deg,
      rgba(255,255,255,0.015) 0px,
      rgba(255,255,255,0.015) 1px,
      transparent 1px,
      transparent 3px
    );
  opacity: 0.75;
}

.related-work-thumb-novel-title,
.related-work-thumb-textcard-title {
  color: rgba(255,255,255,0.92);
  text-shadow: 0 1px 10px rgba(0,0,0,0.35);
}

.related-work-thumb-novel-label,
.related-work-thumb-textcard-label,
.related-work-thumb-fallback-label {
  color: rgba(255,255,255,0.40);
}

.related-works-empty,
.related-works-loading {
  color: rgba(255,255,255,0.42);
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06);
}


/* =========================================
    $BD4@0%Q%C%A!J%U%'!<%I!&GX7J!&(Bspoiler$B=$@5!K(B
   ========================================= */

/* ===== $B%5%`%M7Y9p%+!<%I$rGrOH$G$O$J$/F)$1$?%,%i%9Iw$KLa$9(B ===== */
.thumb-lock-overlay {
  background: rgba(18, 14, 22, 0.28) !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

.thumb-lock-text {
  background: rgba(190, 190, 198, 0.18) !important;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  box-shadow:
    0 8px 24px rgba(0, 0, 0, 0.18),
    inset 0 0 0 1px rgba(255, 255, 255, 0.06) !important;
  color: rgba(255, 255, 255, 0.92) !important;
}

.thumb-lock-text::after {
  display: none !important;
}


/* ===== $B%5%`%M7Y9p$N30B&$K=P$kGr$$H"$r>C$9(B ===== */
button.thumb-lock-overlay,
button.thumb-warning-float,
.thumb-lock-overlay,
.thumb-warning-float {
  appearance: none !important;
  -webkit-appearance: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  outline: none !important;
  padding: 0 !important;
}

.thumb-lock-overlay {
  background: rgba(18, 14, 22, 0.24) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
}

.thumb-lock-text {
  background: rgba(190, 190, 198, 0.16) !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;
  box-shadow:
    0 8px 24px rgba(0, 0, 0, 0.18),
    inset 0 0 0 1px rgba(255, 255, 255, 0.05) !important;
  color: rgba(255, 255, 255, 0.92) !important;
}


.character-relations {
  border-top: 1px solid rgba(255,255,255,0.12);
}

.character-relations-eyebrow {
  color: rgba(255,255,255,0.7);
  letter-spacing: 0.18em;
}

.character-relations-count {
  color: rgba(255,255,255,0.45);
}

.character-relation-link {
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: #fff;
  transition: all 0.2s ease;
}

.character-relation-link:hover {
  background: rgba(255,255,255,0.07);
  border-color: rgba(255,255,255,0.22);
}

.character-relation-desc {
  color: rgba(255,255,255,0.65);
}

.character-relation-note {
  color: rgba(255,255,255,0.5);
}


/* =========================================
   detail $BGX7J$\$+$7!\B-85%U%'!<%I(B $B:G=*HG(B
   $B8+$?L\$O(B noir $B$K=8Ls(B
   ========================================= */

.profile-right,
.portrait,
.profile-bg {
  overflow: visible !important;
}

.profile-right{
  position: relative !important;
  z-index: 2 !important;
}


/* $BGX7J$,9u$K5^$K@Z$l$J$$$h$&<~JU$r$J$8$^$;$k(B */

/* $BN)$A3($^$o$j(B */
.portrait{
  position: relative !important;
  z-index: 2 !important;
}

/* $BN)$A3($NGX8e$K$&$C$9$i?'8w(B */
.portrait::before{
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 38% !important;
  transform: translate(-50%, -50%) !important;
  width: 70% !important;
  height: 70% !important;
  border-radius: 50% !important;
  z-index: 0 !important;
  pointer-events: none !important;

  background: radial-gradient(
    circle,
    color-mix(in srgb, var(--accent-safe) 18%, transparent) 0%,
    color-mix(in srgb, var(--accent-safe) 8%, transparent) 38%,
    transparent 75%
  ) !important;

  filter: blur(18px) !important;
}

/* $BB-85$r<+A3$KMO$+$7$F>C$9(B */
.portrait::after{
  content:"";
  position:absolute;
  left:-8%;
  right:-8%;
  bottom:-10%;
  height:24%;
  pointer-events:none;
  z-index:1;
  background: radial-gradient(
    ellipse at center bottom,
    rgba(0,0,0,.42) 0%,
    rgba(0,0,0,.18) 45%,
    rgba(0,0,0,0) 100%
  );
  filter: blur(18px);
}


  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,0) 72%,
    rgba(0,0,0,0.10) 82%,
    rgba(0,0,0,0.32) 90%,
    rgba(0,0,0,0.74) 97%,
    rgba(0,0,0,0.96) 100%
  ) !important;
}


.portrait img{
  position:relative;
  z-index:2;
  width:100%;
  height:auto;
  max-height:clamp(440px, 72vh, 920px);
  object-fit:contain;
  object-position:center bottom;
  display:block;
  filter: drop-shadow(0 24px 44px rgba(0,0,0,.42));

  -webkit-mask-image: linear-gradient(
    to bottom,
    rgba(0,0,0,1) 0%,
    rgba(0,0,0,1) 78%,
    rgba(0,0,0,.82) 88%,
    rgba(0,0,0,.36) 95%,
    rgba(0,0,0,0) 100%
  );
  mask-image: linear-gradient(
    to bottom,
    rgba(0,0,0,1) 0%,
    rgba(0,0,0,1) 78%,
    rgba(0,0,0,.82) 88%,
    rgba(0,0,0,.36) 95%,
    rgba(0,0,0,0) 100%
  );
}

/* ===== $BGX7J<L??!'<~0O$rF)L@2=$9$k:G=*HG(B ===== */

.profile-bg{
  position:absolute !important;
  inset:-30% -24% 5% -14% !important;
  z-index:0 !important;
  pointer-events:none !important;
  overflow:visible !important;
  background:none !important;
}

.profile-bg::before{
  content:"" !important;
  position:absolute !important;
  inset:-6% 0 -20% 0 !important;
  background:var(--bg) center 12% / cover no-repeat !important;
  background-size:135% auto !important;
  opacity:.96 !important;
  filter:none !important;

  transform: translateY(0%) scale(1.2) !important;
  transform-origin: 50% 34% !important;

  -webkit-mask-image: radial-gradient(
    ellipse 58% 50% at 50% 48%,
    rgba(0,0,0,1) 0%,
    rgba(0,0,0,1) 24%,
    rgba(0,0,0,.82) 40%,
    rgba(0,0,0,.40) 54%,
    rgba(0,0,0,.10) 68%,
    rgba(0,0,0,.02) 78%,
    rgba(0,0,0,0) 86%
  ) !important;
  mask-image: radial-gradient(
    ellipse 58% 50% at 50% 48%,
    rgba(0,0,0,1) 0%,
    rgba(0,0,0,1) 24%,
    rgba(0,0,0,.82) 40%,
    rgba(0,0,0,.40) 54%,
    rgba(0,0,0,.10) 68%,
    rgba(0,0,0,.02) 78%,
    rgba(0,0,0,0) 86%
  ) !important;
}

.profile-bg::after{
  content:none !important;
}


/* =========================
   $B%7%J%j%*(BFA$B%j%s%/!J(BFA$B%Z!<%8MQ!K(B
   ========================= */

.page .scenario-fa-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:24px 0 0;
}

.page .scenario-fa-link{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  text-decoration:none;
  font-size:12px;
  letter-spacing:.08em;

  color:rgba(255,255,255,.85);
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);

  transition:.2s ease;
}

.page .scenario-fa-link:hover{
  color:#fff;
  background:rgba(255,255,255,.09);
  border-color:rgba(255,255,255,.2);
}


.scenario-fa-links{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:10px !important;
  margin:24px 0 0 !important;
}

.scenario-fa-link{
  display:inline-flex !important;
  align-items:center !important;
  padding:8px 12px !important;
  border-radius:999px !important;
  text-decoration:none !important;
  font-size:12px !important;
  letter-spacing:.08em !important;

  color:rgba(255,255,255,.85) !important;
  background:rgba(255,255,255,.05) !important;
  border:1px solid rgba(255,255,255,.12) !important;

  transition:.2s ease !important;
}

.scenario-fa-link:hover{
  color:#fff !important;
  background:rgba(255,255,255,.09) !important;
  border-color:rgba(255,255,255,.2) !important;
}


/* =========================
   TRPG TOP - noir/theme
   ========================= */

.trpg-top-section {
  color: #e9e5e8;
}

.trpg-top-heading-en,
.trpg-top-card-en,
.trpg-banner-en {
  color: rgba(233, 229, 232, 0.62);
}

.trpg-top-heading h2,
.trpg-top-heading h3,
.trpg-top-card h3,
.trpg-top-mini-block h3,
.trpg-banner strong {
  color: #f7f3f6;
}

.trpg-top-heading p,
.trpg-top-card p,
.trpg-top-card li,
.trpg-banner small {
  color: rgba(245, 239, 243, 0.82);
}

.trpg-wave-divider {
  background:
    radial-gradient(120% 100% at 50% 0%, rgba(255,255,255,0.05) 0%, rgba(255,255,255,0) 70%),
    linear-gradient(to bottom, rgba(255,255,255,0.03), rgba(255,255,255,0));
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'%3E%3Cpath fill='black' d='M0,48 C160,100 320,100 480,68 C640,36 800,8 960,26 C1120,44 1280,108 1440,76 L1440,120 L0,120 Z'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 120' preserveAspectRatio='none'%3E%3Cpath fill='black' d='M0,48 C160,100 320,100 480,68 C640,36 800,8 960,26 C1120,44 1280,108 1440,76 L1440,120 L0,120 Z'/%3E%3C/svg%3E");
  mask-repeat: no-repeat;
  mask-size: 100% 100%;
}

.trpg-banner,
.trpg-top-card,
.trpg-top-mini-block {
  border: 1px solid rgba(255, 255, 255, 0.09);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.08) 0%, rgba(255,255,255,0.03) 100%),
    rgba(14, 16, 22, 0.72);
  box-shadow:
    0 14px 34px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255,255,255,0.08);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.trpg-banner::before,
.trpg-top-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(8,10,16,0.18) 0%, rgba(8,10,16,0.62) 100%);
  z-index: 1;
}

.trpg-top-card::after,
.trpg-banner::after {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(255,255,255,0.10) 0%, rgba(255,255,255,0) 45%);
  pointer-events: none;
  z-index: 1;
}

.trpg-banner-main {
  background:
    linear-gradient(135deg, rgba(120, 14, 36, 0.92) 0%, rgba(167, 14, 54, 0.92) 55%, rgba(95, 8, 30, 0.92) 100%);
}

.trpg-banner-main::before {
  background:
    linear-gradient(180deg, rgba(25, 7, 12, 0.08) 0%, rgba(25, 7, 12, 0.34) 100%);
}

.trpg-banner-sub {
  background:
    linear-gradient(135deg, rgba(70, 12, 28, 0.78) 0%, rgba(120, 16, 40, 0.74) 100%);
}

.trpg-banner-links a,
.trpg-top-links a {
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.05);
  color: #f1eaf0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
  transition: 0.25s ease;
}

.trpg-banner-links a:hover,
.trpg-top-links a:hover {
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.18);
  color: #fff;
}

.trpg-top-card-arrow {
  color: rgba(248, 240, 245, 0.84);
}

.trpg-top-card ul {
  color: rgba(245, 239, 243, 0.78);
}

.trpg-top-mini-block {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.025) 100%),
    rgba(17, 18, 25, 0.62);
}

.trpg-top-mini-block .trpg-top-links a {
  background: rgba(255,255,255,0.035);
}

/* $B%+!<%I$4$H$N$[$s$N>/$7$N?':9(B */
.trpg-card-explorers {
  background-color: rgba(33, 36, 48, 0.36);
}

.trpg-card-relations {
  background-color: rgba(46, 34, 48, 0.34);
}

.trpg-card-records {
  background-color: rgba(28, 36, 42, 0.34);
}

.trpg-card-works {
  background-color: rgba(42, 36, 32, 0.34);
}

/* $BGX7J2hA|$,L$@_Dj$G$b<d$7$/$J$i$J$$$h$&$K(B */
.trpg-card-explorers .trpg-top-card-bg {
  background-image:
    radial-gradient(circle at 75% 25%, rgba(211, 219, 255, 0.18) 0%, rgba(211, 219, 255, 0) 24%),
    linear-gradient(135deg, rgba(77, 86, 120, 0.40), rgba(24, 28, 40, 0.10));
}

.trpg-card-relations .trpg-top-card-bg {
  background-image:
    radial-gradient(circle at 70% 30%, rgba(255, 201, 223, 0.16) 0%, rgba(255, 201, 223, 0) 24%),
    linear-gradient(135deg, rgba(115, 70, 96, 0.38), rgba(28, 22, 35, 0.12));
}

.trpg-card-records .trpg-top-card-bg {
  background-image:
    radial-gradient(circle at 72% 25%, rgba(194, 236, 255, 0.16) 0%, rgba(194, 236, 255, 0) 24%),
    linear-gradient(135deg, rgba(55, 89, 101, 0.38), rgba(20, 27, 31, 0.10));
}

.trpg-card-works .trpg-top-card-bg {
  background-image:
    radial-gradient(circle at 72% 25%, rgba(255, 224, 190, 0.16) 0%, rgba(255, 224, 190, 0) 24%),
    linear-gradient(135deg, rgba(106, 82, 60, 0.35), rgba(32, 26, 22, 0.10));
}

/* $B8+=P$72<$N$&$C$9$i@~(B */
.trpg-top-heading h2,
.trpg-top-heading h3 {
  position: relative;
  padding-bottom: 10px;
}

.trpg-top-heading h2::after,
.trpg-top-heading h3::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 64px;
  height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, rgba(255,255,255,0), rgba(210, 176, 195, 0.7), rgba(255,255,255,0));
}

/* hover */
.trpg-banner,
.trpg-top-card,
.trpg-top-links a,
.trpg-banner-links a {
  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    border-color 0.25s ease,
    background 0.25s ease;
}

.trpg-banner:hover,
.trpg-top-card:hover {
  transform: translateY(-2px);
  box-shadow:
    0 18px 38px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255,255,255,0.09);
  border-color: rgba(255,255,255,0.14);
}

/* $B%9%^%[$G$O(Bhover$B46$r95$($a$K(B */
@media (max-width: 767px) {
  .trpg-banner:hover,
  .trpg-top-card:hover {
    transform: none;
  }

  .trpg-top-heading h2::after,
  .trpg-top-heading h3::after {
    width: 52px;
  }
}


/* ===== Works$B%?%0!'$5$j$2$J$/!&$O$_=P$7KI;_(B ===== */

.related-work-tags {
  left: clamp(8px, 4%, 14px) !important;
  right: clamp(8px, 4%, 14px) !important;
  bottom: clamp(8px, 4%, 14px) !important;
  top: auto !important;

  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-start !important;
  align-items: flex-end !important;
  gap: clamp(4px, 1.5vw, 7px) !important;

  max-width: calc(100% - clamp(16px, 8%, 28px)) !important;
}

/* $B%?%06&DL!'N)BN46$r>C$7$FGv$/(B */
.related-work-type,
.related-work-spoiler {
  min-height: clamp(20px, 6vw, 26px) !important;
  max-width: 100% !important;

  padding: 0 clamp(7px, 2.2vw, 11px) !important;
  border-width: 1px !important;
  border-color: rgba(255,255,255,0.08) !important;

  font-size: clamp(8px, 2.4vw, 10px) !important;
  line-height: 1 !important;
  letter-spacing: 0.10em !important;
  font-weight: 500 !important;

  opacity: 0.78 !important;
  box-shadow: none !important;
  text-shadow: none !important;

  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* $B:9$7?'$O;D$7$D$DF)L@EY$r>e$2$k(B */
.related-work-type--illust {
  background: rgba(87, 62, 124, 0.42) !important;
}

.related-work-type--novel {
  background: rgba(120, 57, 89, 0.42) !important;
}

.related-work-type--log {
  background: rgba(58, 79, 122, 0.42) !important;
}

.related-work-type--other {
  background: rgba(92, 92, 92, 0.40) !important;
}

.related-work-type--music {
  background: rgba(54, 96, 120, 0.42) !important;
}

.related-work-spoiler {
  background: rgba(142, 28, 47, 0.46) !important;
}


/* ===== Works$B!'%[%P!<;~%?%$%H%kI=<($rI|3h(B ===== */

.related-work-overlay {
  display: flex !important;
}

.related-work-title {
  display: -webkit-box !important;
  opacity: 0 !important;
}

.related-work-card:hover .related-work-title {
  opacity: 1 !important;
  transform: translateY(0) !important;
}


