/* ============================================================
   Wiki — shared styles for view, edit, index, recent, history
   ============================================================ */

/* Layout shells -------------------------------------------------- */
.wiki-shell,
.wiki-page,
.wiki-editor-shell {
  max-width: 1180px;
  margin: 0 auto 4rem;
}

/* View: optional left rail + content + right TOC */
.wiki-view-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 260px;
  gap: 2.5rem;
  align-items: start;
}
@media (max-width: 991.98px) {
  .wiki-view-layout { grid-template-columns: 1fr; gap: 1.25rem; }
}

/* Typography & reading ----------------------------------------- */
.wiki-content {
  line-height: 1.75;
  font-size: 1.02rem;
  overflow-wrap: anywhere;
  max-width: 75ch;
}
.wiki-content h1, .wiki-content h2, .wiki-content h3,
.wiki-content h4, .wiki-content h5, .wiki-content h6 {
  text-wrap: balance;
  scroll-margin-top: 88px;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.wiki-content h2 {
  font-size: 1.75rem;
  margin-top: 2.25rem;
  padding-bottom: .4rem;
  border-bottom: 1px solid color-mix(in srgb, var(--bs-border-color) 80%, transparent);
}
.wiki-content h3 { font-size: 1.4rem; margin-top: 1.75rem; }
.wiki-content h4 { font-size: 1.18rem; margin-top: 1.4rem; }
.wiki-content p { margin: 0 0 1rem; }
.wiki-content ul, .wiki-content ol { margin: 0 0 1rem; padding-left: 1.6rem; }
.wiki-content li { margin: .15rem 0; }
.wiki-content blockquote {
  margin: 1.25rem 0;
  padding: .25rem 0 .25rem 1rem;
  border-left: 3px solid var(--bs-primary);
  color: var(--bs-secondary-color);
  font-style: italic;
}
.wiki-content hr {
  margin: 2rem 0;
  border: 0;
  border-top: 1px solid var(--bs-border-color);
}
.wiki-content a {
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}

/* Heading anchor link (added by wiki.js) */
.wiki-content .wiki-anchor {
  margin-left: .4rem;
  opacity: 0;
  text-decoration: none;
  color: var(--bs-secondary-color);
  font-weight: 400;
  font-size: .85em;
  transition: opacity .15s ease;
}
.wiki-content h2:hover .wiki-anchor,
.wiki-content h3:hover .wiki-anchor,
.wiki-content h4:hover .wiki-anchor,
.wiki-content .wiki-anchor:focus {
  opacity: 1;
}

/* Tables -------------------------------------------------------- */
.wiki-content .wiki-table-wrap { overflow-x: auto; margin: 1rem 0; }
.wiki-content table {
  width: auto;
  max-width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin: 1rem 0;
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  overflow: hidden;
}
.wiki-content th, .wiki-content td {
  border-bottom: 1px solid var(--bs-border-color);
  padding: .55rem .75rem;
  vertical-align: top;
}
.wiki-content tr:last-child th,
.wiki-content tr:last-child td { border-bottom: 0; }
.wiki-content th {
  background: color-mix(in srgb, var(--bs-secondary) 14%, transparent);
  font-weight: 600;
  text-align: left;
}
.wiki-content tbody tr:nth-child(even) td {
  background: color-mix(in srgb, var(--bs-secondary) 5%, transparent);
}

/* Images & figures --------------------------------------------- */
.wiki-content img {
  max-width: 100%;
  height: auto;
  border-radius: 6px;
  box-shadow: 0 1px 3px rgba(0,0,0,.08);
  cursor: zoom-in;
}
.wiki-content figure {
  margin: 1.25rem 0;
  display: inline-block;
  max-width: 100%;
}
.wiki-content figcaption {
  font-size: .9rem;
  color: var(--bs-secondary-color);
  text-align: center;
  margin-top: .35rem;
}
.wiki-content .thumb { max-width: 100%; }

/* Inline code & code blocks ------------------------------------ */
.wiki-content code {
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  font-size: .92em;
  padding: .12em .35em;
  background: color-mix(in srgb, var(--bs-secondary) 14%, transparent);
  border-radius: 4px;
}
.wiki-content pre {
  margin: 1rem 0;
  padding: 1rem 1.1rem;
  background: color-mix(in srgb, var(--bs-secondary) 10%, transparent);
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  overflow-x: auto;
  line-height: 1.5;
}
.wiki-content pre code {
  background: transparent;
  padding: 0;
  font-size: .92rem;
}

/* Callouts ------------------------------------------------------ */
.wiki-content .wiki-callout {
  display: flex;
  gap: .75rem;
  margin: 1.25rem 0;
  padding: .85rem 1rem;
  border-radius: 8px;
  border-left: 4px solid var(--bs-primary);
  background: color-mix(in srgb, var(--bs-primary) 10%, transparent);
}
.wiki-content .wiki-callout > .wiki-callout-icon {
  flex: 0 0 auto;
  font-size: 1.15rem;
  margin-top: .15rem;
  color: var(--bs-primary);
}
.wiki-content .wiki-callout > .wiki-callout-body { flex: 1 1 auto; min-width: 0; }
.wiki-content .wiki-callout > .wiki-callout-body > :last-child { margin-bottom: 0; }
.wiki-content .wiki-callout > .wiki-callout-body > strong:first-child {
  display: block;
  margin-bottom: .25rem;
}

.wiki-content .wiki-callout.note    { border-left-color: var(--bs-info); background: color-mix(in srgb, var(--bs-info) 10%, transparent); }
.wiki-content .wiki-callout.note    > .wiki-callout-icon { color: var(--bs-info); }
.wiki-content .wiki-callout.tip     { border-left-color: var(--bs-success); background: color-mix(in srgb, var(--bs-success) 10%, transparent); }
.wiki-content .wiki-callout.tip     > .wiki-callout-icon { color: var(--bs-success); }
.wiki-content .wiki-callout.warn    { border-left-color: var(--bs-warning); background: color-mix(in srgb, var(--bs-warning) 12%, transparent); }
.wiki-content .wiki-callout.warn    > .wiki-callout-icon { color: var(--bs-warning); }
.wiki-content .wiki-callout.danger  { border-left-color: var(--bs-danger); background: color-mix(in srgb, var(--bs-danger) 10%, transparent); }
.wiki-content .wiki-callout.danger  > .wiki-callout-icon { color: var(--bs-danger); }

/* Footnotes ----------------------------------------------------- */
.wiki-content .wiki-footnote-ref,
.wiki-content sup a {
  font-size: .75em;
  text-decoration: none;
  padding: 0 .15em;
}
.wiki-content .wiki-footnotes {
  margin-top: 2.5rem;
  padding-top: 1rem;
  border-top: 1px solid var(--bs-border-color);
  font-size: .92rem;
  color: var(--bs-secondary-color);
}
.wiki-content .wiki-footnotes li { margin: .25rem 0; }

/* Page header metadata ----------------------------------------- */
.wiki-page-meta {
  color: var(--bs-secondary-color);
  font-size: .9rem;
}
.wiki-page-actions .btn { white-space: nowrap; }

/* TOC (right sidebar) ----------------------------------------- */
.wiki-toc {
  position: sticky;
  top: 88px;
  align-self: start;
  max-height: calc(100vh - 110px);
  overflow-y: auto;
  font-size: .9rem;
  border-left: 1px solid var(--bs-border-color);
  padding: 0 0 0 1rem;
}
.wiki-toc-title {
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .75rem;
  font-weight: 700;
  color: var(--bs-secondary-color);
  margin-bottom: .5rem;
}
.wiki-toc ol { list-style: none; padding: 0; margin: 0; }
.wiki-toc li { margin: .25rem 0; line-height: 1.35; }
.wiki-toc li.toc-h3 { padding-left: 1rem; font-size: .85rem; }
.wiki-toc a {
  color: var(--bs-secondary-color);
  text-decoration: none;
  display: block;
  padding: .15rem .35rem;
  border-radius: 4px;
  border-left: 2px solid transparent;
}
.wiki-toc a:hover { color: var(--bs-body-color); background: color-mix(in srgb, var(--bs-primary) 8%, transparent); }
.wiki-toc a.active {
  color: var(--bs-body-color);
  font-weight: 600;
  border-left-color: var(--bs-primary);
  background: color-mix(in srgb, var(--bs-primary) 8%, transparent);
}

/* Mobile TOC: collapsible <details> at top */
.wiki-toc-mobile {
  display: none;
  margin-bottom: 1.25rem;
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  background: var(--bs-body-bg);
}
.wiki-toc-mobile > summary {
  padding: .65rem 1rem;
  cursor: pointer;
  font-weight: 600;
  list-style: none;
}
.wiki-toc-mobile > summary::-webkit-details-marker { display: none; }
.wiki-toc-mobile > summary::before {
  content: "\f0c9";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  margin-right: .5rem;
  color: var(--bs-secondary-color);
}
.wiki-toc-mobile .wiki-toc-inner { padding: .25rem 1rem 1rem; }
@media (max-width: 991.98px) {
  .wiki-toc-mobile.has-toc { display: block; }
  .wiki-toc-desktop { display: none; }
}

/* Backlinks ---------------------------------------------------- */
.wiki-backlinks {
  margin-top: 2.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--bs-border-color);
}
.wiki-backlinks > summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--bs-secondary-color);
  list-style: none;
}
.wiki-backlinks > summary::-webkit-details-marker { display: none; }
.wiki-backlinks > summary::before {
  content: "\f0c1";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  margin-right: .5rem;
  color: var(--bs-secondary-color);
}
.wiki-backlinks ul {
  margin: .75rem 0 0;
  padding-left: 1.25rem;
  columns: 2;
  column-gap: 1.5rem;
}
@media (max-width: 575.98px) { .wiki-backlinks ul { columns: 1; } }
.wiki-backlinks li { margin: .15rem 0; break-inside: avoid; }

/* Back-to-top button ------------------------------------------ */
.wiki-back-to-top {
  position: fixed;
  right: 1.25rem;
  bottom: 1.25rem;
  z-index: 1040;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: none;
  align-items: center;
  justify-content: center;
  background: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
  box-shadow: 0 4px 14px rgba(0,0,0,.18);
  color: var(--bs-body-color);
  cursor: pointer;
  transition: transform .15s ease, opacity .15s ease;
}
.wiki-back-to-top.visible { display: flex; }
.wiki-back-to-top:hover { transform: translateY(-2px); }

/* Lightbox modal ---------------------------------------------- */
.wiki-lightbox-img {
  max-width: 100%;
  max-height: 85vh;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}

/* Index page --------------------------------------------------- */
.wiki-toolbar {
  border: 1px solid var(--bs-border-color);
  background: color-mix(in srgb, var(--bs-secondary) 6%, var(--bs-body-bg));
  border-radius: 12px;
  padding: 1rem;
}
.wiki-results {
  display: grid;
  grid-template-columns: 1fr;
  gap: .85rem;
}
@media (min-width: 992px) {
  .wiki-results { grid-template-columns: 1fr 1fr; }
}
.wiki-result {
  position: relative;
  border: 1px solid var(--bs-border-color);
  background: color-mix(in srgb, var(--bs-secondary) 6%, var(--bs-body-bg));
  border-radius: 10px;
  padding: 1rem 1.1rem;
  padding-right: 5.25rem;
  min-height: 5rem;
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.wiki-result-thumb {
  position: absolute;
  top: .75rem; right: .75rem;
  width: 64px; height: 64px;
  border-radius: 8px;
  object-fit: cover;
  background: color-mix(in srgb, var(--bs-secondary) 12%, transparent);
}
@media (max-width: 575.98px) {
  .wiki-result { padding-right: 4.25rem; }
  .wiki-result-thumb { width: 48px; height: 48px; }
}
.wiki-result:hover {
  border-color: color-mix(in srgb, var(--bs-primary) 55%, var(--bs-border-color));
  box-shadow: 0 4px 18px rgba(0,0,0,.08);
  transform: translateY(-1px);
}
.wiki-result h2 { font-size: 1.15rem; line-height: 1.3; margin: 0 0 .15rem; }
.wiki-result h2 a {
  text-decoration: none;
  color: var(--bs-body-color);
}
.wiki-result h2 a:hover {
  color: var(--bs-link-color);
  text-decoration: underline;
}
.wiki-result-meta {
  font-size: .82rem;
  color: var(--bs-secondary-color);
  margin-bottom: .5rem;
}
.wiki-result-edit {
  position: absolute;
  top: .75rem;
  right: 4.5rem;
  opacity: 0;
  transition: opacity .15s ease;
}
.wiki-result:hover .wiki-result-edit,
.wiki-result:focus-within .wiki-result-edit { opacity: 1; }
@media (max-width: 575.98px) {
  .wiki-result-edit { right: 3.5rem; }
}
.wiki-excerpt {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.5;
  font-size: .92rem;
  color: var(--bs-secondary-color);
  word-break: break-word;
  overflow-wrap: anywhere;
}

/* Search autocomplete (index page) ---------------------------- */
.wiki-search-wrap { position: relative; }
.wiki-suggestions {
  position: absolute;
  z-index: 1050;
  top: calc(100% + .25rem);
  left: 0;
  right: 0;
  display: none;
  max-height: 420px;
  overflow-y: auto;
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  background: var(--bs-body-bg);
  box-shadow: 0 12px 32px rgba(0,0,0,.18);
}
.wiki-suggestion {
  display: block;
  padding: .75rem .85rem;
  color: var(--bs-body-color);
  text-decoration: none;
  border-bottom: 1px solid var(--bs-border-color);
}
.wiki-suggestion:last-child { border-bottom: 0; }
.wiki-suggestion:hover,
.wiki-suggestion.active {
  background: color-mix(in srgb, var(--bs-primary) 12%, transparent);
  color: var(--bs-body-color);
}
.wiki-suggestion {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  padding: .55rem .85rem;
}
.wiki-suggestion-thumb {
  flex: 0 0 auto;
  width: 36px; height: 36px;
  border-radius: 6px;
  object-fit: cover;
  background: color-mix(in srgb, var(--bs-secondary) 12%, transparent);
}
.wiki-suggestion-body { flex: 1 1 auto; min-width: 0; }
.wiki-suggestion-title {
  font-weight: 600;
  line-height: 1.25;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wiki-suggestion-meta {
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--bs-secondary-color);
  margin-top: .1rem;
}
.wiki-suggestion-excerpt {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-size: .85rem;
  color: var(--bs-secondary-color);
  margin-top: .2rem;
  line-height: 1.35;
}

/* Recent changes timeline -------------------------------------- */
.wiki-recent-group { margin-bottom: 1.75rem; }
.wiki-recent-group-date {
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--bs-secondary-color);
  font-weight: 700;
  margin-bottom: .5rem;
  padding-bottom: .35rem;
  border-bottom: 1px solid var(--bs-border-color);
}
.wiki-recent-item {
  display: flex;
  gap: .85rem;
  padding: .65rem .25rem;
  border-radius: 6px;
}
.wiki-recent-item:hover { background: color-mix(in srgb, var(--bs-primary) 6%, transparent); }
.wiki-recent-time {
  flex: 0 0 4.5rem;
  font-variant-numeric: tabular-nums;
  color: var(--bs-secondary-color);
  font-size: .9rem;
  padding-top: .1rem;
}
.wiki-recent-body { flex: 1 1 auto; min-width: 0; }
.wiki-recent-title { font-weight: 600; }
.wiki-recent-title a { text-decoration: none; }
.wiki-recent-title a:hover { text-decoration: underline; }
.wiki-recent-meta {
  font-size: .85rem;
  color: var(--bs-secondary-color);
  margin-top: .1rem;
}
.wiki-recent-summary {
  font-size: .9rem;
  color: var(--bs-body-color);
  margin-top: .25rem;
  font-style: italic;
}

/* ============================================================
   Editor: Trix + preview split
   ============================================================ */

/* Title bar */
.wiki-editor-shell .wiki-editor-titlebar {
  display: flex;
  flex-wrap: wrap;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
}
.wiki-editor-shell .wiki-editor-titlebar h1 {
  font-family: var(--display-font);
  letter-spacing: .03em;
  color: var(--bs-body-color);
  text-shadow: 0 1px 0 rgba(0,0,0,.08);
}
.wiki-editor-shell .wiki-editor-titlebar h1::after {
  content: "";
  display: block;
  width: 4.5rem;
  height: 2px;
  margin-top: .35rem;
  background: linear-gradient(90deg, var(--uo-gold),
    color-mix(in srgb, var(--uo-gold) 30%, transparent));
  border-radius: 2px;
}

/* Title input — display serif, gold focus inherited from global .form-control */
.wiki-editor-shell #wikiTitle {
  font-family: var(--display-font);
  letter-spacing: .015em;
  font-size: 1.35rem;
  font-weight: 600;
}
.wiki-editor-shell #wikiTitle[readonly] {
  background: color-mix(in srgb, var(--bs-secondary) 6%, var(--bs-body-bg));
  color: color-mix(in srgb, var(--bs-body-color) 75%, transparent);
  cursor: not-allowed;
}

/* Mode switcher — pill segmented control */
.wiki-editor-mode {
  display: inline-flex;
  position: relative;
  border: 1px solid color-mix(in srgb, var(--uo-gold) 22%, var(--bs-border-color));
  border-radius: 999px;
  overflow: hidden;
  background: color-mix(in srgb, var(--bs-secondary) 10%, var(--bs-body-bg));
  padding: .2rem;
  gap: .15rem;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.15), 0 1px 0 rgba(255,255,255,.04);
}
.wiki-editor-mode button {
  border: 0;
  background: transparent;
  padding: .4rem 1rem;
  font-size: .88rem;
  font-weight: 600;
  letter-spacing: .02em;
  color: var(--bs-body-color);
  opacity: .75;
  cursor: pointer;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  min-height: 32px;
  transition: background .18s ease, color .18s ease, opacity .18s ease, box-shadow .18s ease;
}
.wiki-editor-mode button + button { border-left: 0; }
.wiki-editor-mode button:hover {
  opacity: 1;
  background: color-mix(in srgb, var(--uo-gold) 10%, transparent);
}
.wiki-editor-mode button.active {
  background: linear-gradient(180deg, #e3c673, #c9a227);
  color: #111;
  opacity: 1;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.35), 0 2px 8px var(--gold-glow);
}
.wiki-editor-mode button i { font-size: .85em; opacity: .85; }
.wiki-editor-mode button.active i { opacity: 1; }

@media (max-width: 575.98px) {
  .wiki-editor-mode button { padding: .4rem .65rem; font-size: .8rem; }
  .wiki-editor-mode button span { display: none; }
}

/* Layout grid (write / split / preview) */
.wiki-editor-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}
.wiki-editor-grid.mode-split { grid-template-columns: 1fr 1fr; }
.wiki-editor-grid.mode-preview .wiki-editor-write { display: none; }
.wiki-editor-grid.mode-write   .wiki-editor-preview { display: none; }
@media (max-width: 991.98px) {
  .wiki-editor-grid.mode-split { grid-template-columns: 1fr; }
}

/* Trix toolbar shell — gold-tinted gradient */
.wiki-editor-write trix-toolbar {
  position: sticky;
  top: 72px;
  z-index: 50;
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--uo-gold) 6%, var(--bs-body-bg)) 0%,
    color-mix(in srgb, var(--bs-secondary) 8%, var(--bs-body-bg)) 100%);
  border: 1px solid color-mix(in srgb, var(--uo-gold) 25%, var(--bs-border-color));
  border-bottom: 0;
  border-radius: var(--soft-radius) var(--soft-radius) 0 0;
  padding: .45rem .65rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 4px 14px rgba(0,0,0,.18);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .25rem;
}

.wiki-editor-write trix-toolbar .trix-button-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .15rem;
  flex: 1 1 auto;
}
.wiki-editor-write trix-toolbar .trix-button-group {
  display: inline-flex;
  align-items: center;
  gap: .15rem;
  margin: 0;
  padding: 0 .35rem;
  border: 0;
  position: relative;
}
.wiki-editor-write trix-toolbar .trix-button-group + .trix-button-group::before {
  content: "";
  position: absolute;
  left: 0; top: 20%; bottom: 20%;
  width: 1px;
  background: linear-gradient(180deg, transparent,
    color-mix(in srgb, var(--uo-gold) 40%, transparent), transparent);
}

/* Individual toolbar buttons — kill Trix's inline SVG, draw FA glyph in ::before */
.wiki-editor-write trix-toolbar .trix-button {
  background: transparent;
  background-image: none !important;
  position: relative;
  min-width: 2rem;
  width: auto !important;
  max-width: none !important;
  height: 2.1rem;
  padding: 0 .55rem;
  margin: 0 !important;
  float: none !important;
  border: 0 !important;
  border-radius: var(--tight-radius);
  color: var(--bs-body-color);
  font-size: 0;
  text-indent: 0 !important;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .15s ease, color .15s ease, box-shadow .15s ease;
}
/* Override Trix's absolute-positioned, opacity-0.6, SVG-background ::before
   so the FA glyph renders inline at full opacity */
.wiki-editor-write trix-toolbar .trix-button::before {
  position: static !important;
  inset: auto !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  opacity: 1 !important;
  background-image: none !important;
  background: transparent !important;
  font-family: "Font Awesome 6 Free" !important;
  font-weight: 900 !important;
  font-size: 1.05rem !important;
  font-style: normal;
  line-height: 1;
  display: inline-block;
  width: auto;
  height: auto;
  color: inherit;
  text-indent: 0;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
}
/* Dark-mode boost: warm cream glyphs on the dark toolbar */
#htmltheme[data-bs-theme="dark"] .wiki-editor-write trix-toolbar .trix-button {
  color: #ebe6d6;
}
#htmltheme[data-bs-theme="dark"] .wiki-editor-write trix-toolbar .trix-button:hover {
  color: var(--uo-gold);
}
#htmltheme[data-bs-theme="dark"] .wiki-editor-write trix-toolbar .trix-button.trix-active {
  color: var(--uo-gold);
}
.wiki-editor-write trix-toolbar .trix-button:hover {
  background: color-mix(in srgb, var(--uo-gold) 14%, transparent);
  color: var(--uo-gold);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--uo-gold) 30%, transparent);
}
.wiki-editor-write trix-toolbar .trix-button:active { transform: translateY(1px); }
.wiki-editor-write trix-toolbar .trix-button.trix-active {
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--uo-gold) 28%, transparent),
    color-mix(in srgb, var(--uo-gold) 18%, transparent));
  color: var(--uo-gold);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 0 0 1px color-mix(in srgb, var(--uo-gold) 45%, transparent),
    0 0 8px var(--gold-glow);
}
.wiki-editor-write trix-toolbar .trix-button:disabled,
.wiki-editor-write trix-toolbar .trix-button[disabled] {
  opacity: .35;
  cursor: not-allowed;
}

/* Font Awesome glyph mapping for each Trix button */
.wiki-editor-write trix-toolbar .trix-button[data-trix-attribute="bold"]::before     { content: "\f032"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-attribute="italic"]::before   { content: "\f033"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-attribute="strike"]::before   { content: "\f0cc"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-attribute="href"]::before     { content: "\f0c1"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-attribute="heading1"]::before { content: "\f1dc"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-attribute="quote"]::before    { content: "\f10e"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-attribute="code"]::before     { content: "\f121"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-attribute="bullet"]::before   { content: "\f0ca"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-attribute="number"]::before   { content: "\f0cb"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-action="decreaseNestingLevel"]::before { content: "\f03b"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-action="increaseNestingLevel"]::before { content: "\f03c"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-action="attachFiles"]::before { content: "\f0c6"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-action="undo"]::before        { content: "\f0e2"; }
.wiki-editor-write trix-toolbar .trix-button[data-trix-action="redo"]::before        { content: "\f01e"; }

/* Link-insertion dialog */
.wiki-editor-write trix-toolbar .trix-dialog {
  background: color-mix(in srgb, var(--bs-secondary) 10%, var(--bs-body-bg));
  border: 1px solid var(--bs-border-color);
  border-radius: var(--tight-radius);
  padding: .5rem .65rem;
  margin-top: .35rem;
  box-shadow: var(--elevation-1);
}
.wiki-editor-write trix-toolbar .trix-input--dialog {
  background: var(--bs-body-bg);
  color: var(--bs-body-color);
  border: 1px solid var(--bs-border-color);
  border-radius: var(--tight-radius);
  padding: .35rem .55rem;
  font: inherit;
}
.wiki-editor-write trix-toolbar .trix-input--dialog:focus {
  outline: none;
  border-color: var(--uo-gold);
  box-shadow: 0 0 0 2px rgba(201,162,39,.18);
}
.wiki-editor-write trix-toolbar .trix-button--dialog {
  background: transparent;
  color: var(--bs-body-color);
  border: 1px solid var(--bs-border-color);
  border-radius: var(--tight-radius);
  padding: .25rem .65rem;
  font-size: .85rem;
  margin-left: .25rem;
}
.wiki-editor-write trix-toolbar .trix-button--dialog:hover {
  background: color-mix(in srgb, var(--uo-gold) 14%, transparent);
  border-color: var(--uo-gold);
  color: var(--uo-gold);
}

/* Trix editor surface */
.wiki-editor-write trix-editor {
  min-height: 560px;
  border: 1px solid color-mix(in srgb, var(--uo-gold) 22%, var(--bs-border-color));
  border-top: 0;
  border-radius: 0 0 var(--soft-radius) var(--soft-radius);
  padding: 1.25rem 1.5rem;
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--bs-secondary) 3%, var(--bs-body-bg)),
    color-mix(in srgb, var(--bs-secondary) 8%, var(--bs-body-bg)));
  color: var(--bs-body-color);
  line-height: 1.75;
  font-size: 1.02rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.02);
}
.wiki-editor-write trix-editor:focus {
  outline: 0;
  border-color: var(--uo-gold);
  box-shadow:
    inset 0 0 0 1px var(--uo-gold),
    0 0 0 3px rgba(201,162,39,.18),
    0 0 18px var(--gold-glow);
}

/* Preview surface */
.wiki-editor-preview {
  min-height: 560px;
  border: 1px solid var(--bs-border-color);
  border-radius: var(--soft-radius);
  padding: 1.25rem 1.5rem;
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--bs-secondary) 3%, var(--bs-body-bg)),
    color-mix(in srgb, var(--bs-secondary) 8%, var(--bs-body-bg)));
  overflow: auto;
  box-shadow: var(--elevation-1);
}
.wiki-editor-preview-empty {
  color: var(--bs-secondary-color);
  font-style: italic;
  font-family: var(--display-font);
  letter-spacing: .02em;
  padding: 2rem 0;
  text-align: center;
  opacity: .7;
}

/* Custom (Callout / Footnote) group — purple accent, pushed to right */
.wiki-editor-custom {
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  margin-left: auto;
  padding-left: .65rem;
  position: relative;
}
.wiki-editor-custom::before {
  content: "";
  position: absolute;
  left: 0; top: 20%; bottom: 20%;
  width: 1px;
  background: linear-gradient(180deg, transparent,
    color-mix(in srgb, var(--uo-aes-sedai) 45%, transparent), transparent);
}
.wiki-editor-custom button,
.wiki-editor-custom .dropdown-toggle {
  border: 0;
  background: transparent;
  color: var(--bs-body-color);
  padding: .35rem .6rem;
  height: 2rem;
  border-radius: var(--tight-radius);
  cursor: pointer;
  font-size: .85rem;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  transition: background .15s ease, color .15s ease;
}
.wiki-editor-custom button:hover,
.wiki-editor-custom .dropdown-toggle:hover {
  background: color-mix(in srgb, var(--uo-aes-sedai) 16%, transparent);
  color: var(--uo-aes-sedai);
}
.wiki-editor-custom .dropdown-toggle::after { margin-left: .15rem; opacity: .7; }
.wiki-editor-custom .dropdown-menu { font-size: .9rem; }

/* Save row */
.wiki-save-row {
  position: sticky;
  bottom: 0;
  background: linear-gradient(180deg, transparent 0%,
    color-mix(in srgb, var(--bs-body-bg) 80%, transparent) 25%,
    var(--bs-body-bg) 100%);
  border-top: 1px solid color-mix(in srgb, var(--uo-gold) 18%, var(--bs-border-color));
  padding: 1rem 0 .75rem;
  margin-top: 1.5rem;
  z-index: 40;
  backdrop-filter: blur(4px);
}

/* Draft restore banner */
.wiki-draft-banner {
  margin: 0 0 1rem;
  padding: .75rem 1rem;
  background: linear-gradient(90deg,
    color-mix(in srgb, var(--bs-warning) 18%, transparent),
    color-mix(in srgb, var(--bs-warning) 6%, transparent));
  border: 1px solid color-mix(in srgb, var(--bs-warning) 40%, transparent);
  border-left: 4px solid var(--uo-gold);
  border-radius: var(--tight-radius);
  font-size: .92rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .65rem;
  box-shadow: 0 4px 14px rgba(0,0,0,.10);
}
.wiki-draft-banner strong { color: var(--uo-gold); font-weight: 700; }

/* Mobile + light theme guards */
@media (max-width: 575.98px) {
  .wiki-editor-write trix-toolbar { top: 60px; padding: .35rem .4rem; }
  .wiki-editor-write trix-toolbar .trix-button { min-width: 1.75rem; padding: 0 .35rem; }
}
#htmltheme[data-bs-theme="light"] .wiki-editor-write trix-toolbar .trix-button.trix-active {
  box-shadow: inset 0 1px 0 rgba(255,255,255,.6),
    0 0 0 1px color-mix(in srgb, var(--uo-gold) 55%, transparent);
}
#htmltheme[data-bs-theme="light"] .wiki-editor-write trix-editor:focus {
  box-shadow: inset 0 0 0 1px var(--uo-gold), 0 0 0 3px rgba(201,162,39,.22);
}

/* Highlight.js theme bridge (dark-aware) ---------------------- */
[data-bs-theme="dark"] .wiki-content pre {
  background: color-mix(in srgb, var(--bs-secondary) 18%, transparent);
}

/* Print -------------------------------------------------------- */
@media print {
  .wiki-toc, .wiki-toc-mobile, .wiki-back-to-top,
  .wiki-page-actions, .wiki-backlinks { display: none !important; }
  .wiki-view-layout { grid-template-columns: 1fr; }
  .wiki-content { max-width: none; }
}
