.sheetbackdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  z-index: 50;
  animation: backdropin 0.2s ease-out;
}
@keyframes backdropin {
  from {opacity: 0}
  to   {opacity: 1}
}

.sheet {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  z-index: 51;
  background: var(--card);
  border-top: 1px solid var(--border); border-top-left-radius: 1.5rem;
  border-top-right-radius: 1.5rem;
  display: flex; flex-direction: column;
  animation: sheetin 0.25s cubic-bezier(0.32, 0.72, 0, 1);
}

@keyframes sheetin {
  from {transform: translateY(100%)}
  to {transform: translateY(0)}
}

.sheetlg {height: 75vh}
.sheetside {height: 70vh}

@media (min-width: 900px) {
  .sheetside {
    top: 0; bottom: 0; right: 0; left: auto;
    width: 25rem; height: 100%;
    border-top-left-radius: 0; border-bottom-left-radius: 1rem;
    border-top-right-radius: 0; border-left: 1px solid var(--border);
    animation: sheetinright 0.25s cubic-bezier(0.32, 0.72, 0, 1);
  }
  @keyframes sheetinright {
    from {transform: translateX(100%)}
    to   {transform: translateX(0)}
  }
}

.sheetheader {
  padding: 1rem 1.25rem;
  position: relative;
}

.sheettitle {
  font-size: 1rem; font-weight: 600;
  margin: 0;
  display: flex; align-items: center; gap: 0.5rem; justify-content: center;
}

.sheetbody {
  flex: 1;
  overflow-y: auto;
  padding: 1rem 1.25rem;
}

.sheetclose {
  position: absolute;
  top: 0.75rem; right: 1rem;
  background: none;
  border: none;
  color: var(--mutedfg);
  cursor: pointer;
}

/*//////////////////////////////////////////////////////////////////////*/

.comment {
  display: grid; grid-template-columns: 2.25rem 1fr auto; gap: 0.625rem;
  align-items: start;
  margin-bottom: 1.25rem;
}

.commentavatar {
  width: 2.25rem; height: 2.25rem;
  border-radius: 999px;
  background: linear-gradient(135deg, hsl(217, 91%, 60%), hsl(340, 82%, 60%));
  display: flex; align-items: center; justify-content: center;
  font-weight: 700;
  color: white;
  font-size: 0.875rem;
}

.commentbubble {
  display: flex; flex-direction: column; gap: 0.125rem;
  min-width: 0;
}

.commenthead {
  display: flex; align-items: center; gap: 0.5rem;
}

.commentname {
  font-size: 0.8125rem; font-weight: 600;
  color: var(--mutedfg);
}

.commentdate {
  font-size: 0.6875rem;
  color: var(--mutedfg);
}

.commentbody {
  font-size: 0.875rem; line-height: 1.4;
  color: var(--fg);
  white-space: pre-wrap;
  margin: 0;
  word-wrap: break-word;
}

.commentside {
  display: flex; flex-direction: column; align-items: center; gap: 0.125rem;
  padding-top: 0.25rem;
}

.commentlike {
  background: none;
  border: none;
  color: var(--mutedfg);
  padding: 0;
  cursor: pointer;
}

.commentlike:hover {
  color: var(--primary);
}

.commentscore {
  font-size: 0.6875rem;
  color: var(--mutedfg);
}

/* Threaded comments: a parent commentitem holds the comment row, the
   "N replies" toggle, and the (initially hidden) reply container. */
.commentitem {
  display: flex; flex-direction: column; gap: 0.25rem;
  margin-bottom: 1.25rem;
}
.commentitem .comment {
  margin-bottom: 0;
}
.commentrepliesbtn {
  align-self: flex-start;
  margin-left: 2.875rem;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--mutedfg);
  font-size: 0.75rem; font-weight: 600;
  padding: 0.125rem 0.375rem;
}
.commentrepliesbtn:hover {
  color: var(--fg);
}
.commentreplies {
  margin-left: 2.875rem;
  display: flex; flex-direction: column; gap: 0.5rem;
  padding: 0.25rem 0 0.25rem 0.75rem;
  border-left: 2px solid var(--border);
}

/*//////////////////////////////////////////////////////////////////////*/

.detailmeta {
  display: flex; flex-wrap: wrap; gap: 0.75rem;
  font-size: 0.75rem;
  color: var(--mutedfg);
  margin-bottom: 1rem;
}

.detailmeta .k {
  font-weight: 500;
  color: var(--fg);
  margin-right: 0.25rem;
}

.detailtaggroup {
  margin-bottom: 1.25rem;
}

.detailtaggroup h4 {
  margin: 0 0 0.5rem;
}

.detailtagrow {
  display: flex; flex-wrap: wrap; gap: 0.375rem;
}

.detailtag {
  padding: 0.25rem 0.5rem;
  border-radius: 0.375rem;
  font-size: 0.75rem;
  border: 1px solid transparent;
  background: var(--secondary); color: var(--fg);
  transition: opacity 0.15s;
}

.detailtag.tagartist {
  background: rgba(242, 172, 8, 0.10); color: var(--tagartist);
  border-color: rgba(242, 172, 8, 0.30);
}
.detailtag.tagcharacter {
  background: rgba(0, 170, 0, 0.10); color: var(--tagcharacter);
  border-color: rgba(0, 170, 0, 0.30);
}
.detailtag.tagcopyright {
  background: rgba(221, 0, 221, 0.10); color: var(--tagcopyright);
  border-color: rgba(221, 0, 221, 0.30);
}
.detailtag.tagspecies {
  background: rgba(237, 93, 31, 0.10); color: var(--tagspecies);
  border-color: rgba(237, 93, 31, 0.30);
}
.detailtag.taggeneral {
  background: rgba(46, 118, 180, 0.10); color: var(--taggeneral);
  border-color: rgba(46, 118, 180, 0.30);
}
.detailtag.tagmeta {
  background: rgba(255, 255, 255, 0.05); color: var(--tagmeta);
  border-color: rgba(255, 255, 255, 0.20);
}
.detailtag.taglore {
  background: rgba(34, 136, 34, 0.10); color: var(--taglore);
  border-color: rgba(34, 136, 34, 0.30);
}

.detailtag:hover {
  opacity: 0.8;
}

.detailsourcelink {
  display: flex; align-items: center; gap: 0.375rem;
  font-size: 0.75rem;
  color: var(--accent);
  text-decoration: none;
  margin-bottom: 0.25rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.detailsourcelink:hover {
  text-decoration: underline;
}

.dtextlink {
  color: var(--accent);
  text-decoration: none; word-break: break-word;
}
.dtextlink:hover {
  text-decoration: underline;
}

.dtextheading {margin: 0.5rem 0 0.25rem; line-height: 1.25; font-weight: 700}
h1.dtextheading {font-size: 1.4rem}
h2.dtextheading {font-size: 1.2rem}
h3.dtextheading {font-size: 1.05rem}
h4.dtextheading {font-size: 0.95rem; color: var(--mutedfg)}
h5.dtextheading {font-size: 0.85rem; color: var(--mutedfg); letter-spacing: 0.04em}
h6.dtextheading {font-size: 0.75rem; color: var(--mutedfg); letter-spacing: 0.06em}

.dtextquote {
  margin: 0.25rem 0 0.5rem; padding: 0.375rem 0.75rem;
  border-left: 3px solid var(--border);
  color: var(--mutedfg);
  font-size: 0.85em;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 0 0.375rem 0.375rem 0;
}

.dtextsection {
  margin: 0.25rem 0;
  background: rgba(255, 255, 255, 0.04);
  border-radius: 0.375rem;
  padding: 0;
  border: 1px solid var(--border);
}

.dtextsection > summary {
  cursor: pointer;
  padding: 0.5rem 0.75rem;
  font-weight: 600; font-size: 0.85em; user-select: none;
  list-style: none;
}

.dtextsection > summary::-webkit-details-marker {
  display: none;
}

.dtextsection > summary::before {
  content: '▸ ';
  display: inline-block;
  margin-right: 0.25rem;
  transition: transform 0.15s;
}

.dtextsection[open] > summary::before {
  transform: rotate(90deg);
}
.dtextsectionbody {
  padding: 0 0.75rem 0.5rem;
}

img.commentavatar {
  object-fit: cover;
  background: var(--secondary);
}

/*//////////////////////////////////////////////////////////////////////*/

.textmuted {
  color: var(--mutedfg);
}
.textxs {
  font-size: 0.75rem;
}
.textsm {
  font-size: 0.875rem;
}.flexwrap {
  flex-wrap: wrap;
}
.relative {
  position: relative;
}
