/* ============================================================
   GOLDENHEART — Obsidian Publish Theme
   Inspired by D&D 5e Player's Handbook
   Parchment · Gold · High Fantasy
   ============================================================ */

/* ── Google Fonts ─────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Crimson+Pro:ital,wght@0,400;0,600;1,400;1,600&display=swap');

/* ── Color Tokens ─────────────────────────────────────────── */
:root {
  --gh-parchment:       #f4ead5;
  --gh-parchment-dark:  #e8d9b8;
  --gh-parchment-deep:  #d9c89a;
  --gh-ink:             #1a0f00;
  --gh-ink-muted:       #4a3520;
  --gh-ink-light:       #6b4f35;
  --gh-gold:            #b8860b;
  --gh-gold-bright:     #d4a017;
  --gh-gold-pale:       #f0d080;
  --gh-red:             #8b0000;
  --gh-red-muted:       #a0201a;
  --gh-rule:            #c8a050;
  --gh-shadow:          rgba(26, 15, 0, 0.18);
}

/* ── Base & Body ──────────────────────────────────────────── */
body,
.publish-article-width,
.site-body,
.page-header,
.site-body-left,
.site-body-center,
.site-body-right,
.page-wrapper,
.content-wrapper,
.site-overlay,
.sidebar-right,
.graph-view-outer,
.right-sidebar,
.publish-renderer,
.mod-right-split,
.workspace-leaf,
.workspace-split {
  background-color: var(--gh-parchment) !important;
  color: var(--gh-ink) !important;
  font-family: 'Crimson Pro', Georgia, serif !important;
  font-size: 17px;
  line-height: 1.75;
}

/* Subtle parchment grain texture via repeating gradient */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    repeating-linear-gradient(
      90deg,
      transparent,
      transparent 2px,
      rgba(180, 140, 60, 0.03) 2px,
      rgba(180, 140, 60, 0.03) 4px
    ),
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 3px,
      rgba(140, 100, 40, 0.02) 3px,
      rgba(140, 100, 40, 0.02) 6px
    );
}

/* ── Site Header / Nav ────────────────────────────────────── */
.site-header,
.nav-header {
  background-color: var(--gh-red) !important;
  border-bottom: 3px solid var(--gh-gold) !important;
  box-shadow: 0 2px 12px var(--gh-shadow);
}

.site-header-text,
.site-name,
.site-header a {
  font-family: 'Cinzel', serif !important;
  color: var(--gh-gold-pale) !important;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.site-name {
  font-size: 1.5rem !important;
  text-shadow: 0 1px 3px rgba(0,0,0,0.4);
}

/* ── Sidebar Navigation ───────────────────────────────────── */
.nav-view-outer,
.sidebar-left,
.site-sidebar,
.site-sidebar-left,
.site-sidebar-right,
.sidebar,
.tree-item,
.nav-view,
.mobile-navbar,
.mobile-sidebar,
.site-body-left-column,
.site-body-right-column,
.nav-header,
.nav-buttons-container,
.published-container,
.site-body > div,
.sidebar-left-fixed,
.sidebar-right-fixed {
  background-color: var(--gh-parchment-dark) !important;
}

/* Nuclear option — if white still shows, this catches any unstyled direct child of site-body */
.site-body {
  background-color: var(--gh-parchment) !important;
}
.site-body > * {
  background-color: var(--gh-parchment-dark) !important;
}
/* ...but don't let that override the main content column */
.site-body > .publish-article,
.site-body > .site-body-center,
.site-body > main,
.markdown-preview-view {
  background-color: var(--gh-parchment) !important;
}

.nav-folder-title,
.nav-file-title,
.tree-item-self {
  font-family: 'Crimson Pro', serif !important;
  color: var(--gh-ink-muted) !important;
  font-size: 15px;
  padding: 4px 10px !important;
  transition: color 0.15s, background 0.15s;
}

.nav-file-title:hover,
.tree-item-self:hover,
.nav-folder-title:hover {
  color: var(--gh-red) !important;
  background-color: rgba(184, 134, 11, 0.12) !important;
}

.nav-folder-title {
  font-family: 'Cinzel', serif !important;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--gh-gold) !important;
  margin-top: 8px;
}

.is-active > .tree-item-self,
.nav-file-title.is-active {
  color: var(--gh-red) !important;
  background-color: rgba(139, 0, 0, 0.08) !important;
  border-left: 3px solid var(--gh-red) !important;
}

/* ── Main Content Area ────────────────────────────────────── */
.markdown-preview-view,
.markdown-rendered,
.cm-preview-code-block,
.publish-article {
  background-color: transparent !important;
  color: var(--gh-ink) !important;
  font-family: 'Crimson Pro', Georgia, serif !important;
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 2rem 3rem;
  box-sizing: border-box;
}

/* Constrain line length for readability without hard pixel cap */
.markdown-rendered p,
.markdown-rendered li,
.markdown-rendered blockquote {
  max-width: 72ch;
}

/* ── Headings ─────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6,
.markdown-rendered h1,
.markdown-rendered h2,
.markdown-rendered h3,
.markdown-rendered h4 {
  font-family: 'Cinzel', serif !important;
  color: var(--gh-red) !important;
  line-height: 1.2;
  margin-top: 2rem;
  margin-bottom: 0.5rem;
}

h1, .markdown-rendered h1 {
  font-size: 2.2rem !important;
  font-weight: 700;
  border-bottom: 2px solid var(--gh-gold) !important;
  padding-bottom: 0.4rem;
  letter-spacing: 0.04em;
}

h2, .markdown-rendered h2 {
  font-size: 1.55rem !important;
  font-weight: 600;
  border-bottom: 1px solid var(--gh-parchment-deep) !important;
  padding-bottom: 0.25rem;
  letter-spacing: 0.03em;
}

h3, .markdown-rendered h3 {
  font-size: 1.25rem !important;
  font-weight: 600;
  color: var(--gh-ink-muted) !important;
}

h4, .markdown-rendered h4 {
  font-size: 1.05rem !important;
  font-weight: 600;
  color: var(--gh-gold) !important;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* ── Decorative Rule After H1 ─────────────────────────────── */
h1::after,
.markdown-rendered h1::after {
  content: '';
  display: block;
  height: 3px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    var(--gh-gold) 20%,
    var(--gh-gold-bright) 50%,
    var(--gh-gold) 80%,
    transparent 100%
  );
  margin-top: 6px;
  border-radius: 2px;
}

/* ── Paragraphs & Body Text ───────────────────────────────── */
p, .markdown-rendered p {
  color: var(--gh-ink) !important;
  font-size: 17px;
  margin-bottom: 1em;
  text-align: justify;
  hyphens: auto;
}

/* ── Links ────────────────────────────────────────────────── */
a, .markdown-rendered a {
  color: var(--gh-red) !important;
  text-decoration: none;
  border-bottom: 1px dotted var(--gh-gold);
  transition: color 0.15s, border-color 0.15s;
}

a:hover, .markdown-rendered a:hover {
  color: var(--gh-gold) !important;
  border-bottom-color: var(--gh-red);
}

/* ── Blockquotes — Flavor Text Style ─────────────────────── */
blockquote,
.markdown-rendered blockquote {
  background-color: var(--gh-parchment-dark) !important;
  border-left: 4px solid var(--gh-gold) !important;
  border-radius: 0 4px 4px 0;
  margin: 1.5rem 0;
  padding: 1rem 1.5rem;
  color: var(--gh-ink-muted) !important;
  font-style: italic;
  font-size: 16px;
  box-shadow: inset 0 0 0 1px rgba(184, 134, 11, 0.15);
}

blockquote p {
  text-align: left !important;
  margin-bottom: 0 !important;
}

/* ── Stat Block Style Callouts ────────────────────────────── */
.callout,
.markdown-rendered .callout {
  background-color: var(--gh-parchment-dark) !important;
  border: 1px solid var(--gh-rule) !important;
  border-top: 3px solid var(--gh-red) !important;
  border-radius: 4px;
  box-shadow: 2px 2px 8px var(--gh-shadow);
  padding: 1rem 1.25rem;
  margin: 1.5rem 0;
}

.callout-title {
  font-family: 'Cinzel', serif !important;
  color: var(--gh-red) !important;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-bottom: 0.5rem;
}

.callout[data-callout="info"] {
  border-top-color: var(--gh-gold) !important;
}
.callout[data-callout="info"] .callout-title {
  color: var(--gh-gold) !important;
}

.callout[data-callout="warning"],
.callout[data-callout="danger"] {
  border-top-color: var(--gh-red) !important;
}

/* ── Tables — Stat Block Inspired ────────────────────────── */
table,
.markdown-rendered table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0;
  font-size: 15px;
  background-color: var(--gh-parchment-dark);
  border: 1px solid var(--gh-rule);
  box-shadow: 2px 2px 8px var(--gh-shadow);
}

thead tr {
  background-color: var(--gh-red) !important;
}

thead th {
  font-family: 'Cinzel', serif !important;
  color: var(--gh-gold-pale) !important;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 8px 12px;
  text-align: left;
  border-bottom: 2px solid var(--gh-gold);
}

tbody tr {
  border-bottom: 1px solid var(--gh-parchment-deep);
}

tbody tr:nth-child(even) {
  background-color: rgba(200, 160, 80, 0.1);
}

tbody tr:hover {
  background-color: rgba(139, 0, 0, 0.06);
}

td, th {
  padding: 7px 12px;
  color: var(--gh-ink) !important;
  vertical-align: top;
}

/* ── Horizontal Rules — Ornamental ───────────────────────── */
hr,
.markdown-rendered hr {
  border: none;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    var(--gh-rule) 20%,
    var(--gh-gold-bright) 50%,
    var(--gh-rule) 80%,
    transparent 100%
  );
  margin: 2rem auto;
  position: relative;
}

hr::before,
.markdown-rendered hr::before {
  content: '❧';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: var(--gh-parchment);
  color: var(--gh-gold);
  padding: 0 8px;
  font-size: 14px;
}

/* ── Code Blocks ──────────────────────────────────────────── */
code,
.markdown-rendered code {
  font-family: 'Courier New', monospace;
  background-color: var(--gh-parchment-deep) !important;
  color: var(--gh-red) !important;
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 14px;
  border: 1px solid var(--gh-rule);
}

pre,
.markdown-rendered pre {
  background-color: var(--gh-parchment-dark) !important;
  border: 1px solid var(--gh-rule);
  border-left: 4px solid var(--gh-gold);
  border-radius: 4px;
  padding: 1rem 1.25rem;
  overflow-x: auto;
}

pre code {
  background-color: transparent !important;
  border: none !important;
  padding: 0 !important;
  color: var(--gh-ink-muted) !important;
}

/* ── Bold & Italic ────────────────────────────────────────── */
strong, .markdown-rendered strong {
  color: var(--gh-ink) !important;
  font-weight: 700;
}

em, .markdown-rendered em {
  color: var(--gh-ink-light) !important;
}

/* ── Lists ────────────────────────────────────────────────── */
ul, ol,
.markdown-rendered ul,
.markdown-rendered ol {
  padding-left: 1.5rem;
  margin: 0.75rem 0;
}

li, .markdown-rendered li {
  margin-bottom: 0.35rem;
  color: var(--gh-ink);
}

ul li::marker {
  color: var(--gh-gold);
  content: '⚜ ';
}

/* ── Tags ─────────────────────────────────────────────────── */
.tag,
a.tag {
  background-color: var(--gh-red) !important;
  color: var(--gh-gold-pale) !important;
  font-family: 'Cinzel', serif !important;
  font-size: 11px !important;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 2px 8px !important;
  border-radius: 3px !important;
  border: 1px solid var(--gh-gold) !important;
  text-decoration: none !important;
}

.tag:hover, a.tag:hover {
  background-color: var(--gh-gold) !important;
  color: var(--gh-ink) !important;
}

/* ── Search ───────────────────────────────────────────────── */
.search-input,
input[type="search"],
input[type="text"] {
  background-color: var(--gh-parchment-dark) !important;
  border: 1px solid var(--gh-rule) !important;
  color: var(--gh-ink) !important;
  font-family: 'Crimson Pro', serif !important;
  border-radius: 3px;
  padding: 5px 10px;
}

.search-input:focus,
input:focus {
  border-color: var(--gh-gold) !important;
  outline: none;
  box-shadow: 0 0 0 2px rgba(184, 134, 11, 0.2);
}

/* ── Scrollbar ────────────────────────────────────────────── */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
::-webkit-scrollbar-track {
  background: var(--gh-parchment-dark);
}
::-webkit-scrollbar-thumb {
  background: var(--gh-rule);
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--gh-gold);
}

/* ── Images ───────────────────────────────────────────────── */
.markdown-rendered img {
  border: 2px solid var(--gh-rule);
  border-radius: 4px;
  box-shadow: 3px 3px 10px var(--gh-shadow);
  max-width: 100%;
}

/* ── Footer / Page Metadata ───────────────────────────────── */
.page-footer,
.publish-footer {
  border-top: 1px solid var(--gh-rule);
  color: var(--gh-ink-light) !important;
  font-size: 13px;
  font-family: 'Crimson Pro', serif;
  padding-top: 1rem;
  margin-top: 3rem;
}

/* ── Backlinks Section ────────────────────────────────────── */
.backlinks,
.outgoing-links {
  background-color: var(--gh-parchment-dark);
  border: 1px solid var(--gh-rule);
  border-top: 3px solid var(--gh-gold);
  border-radius: 4px;
  padding: 1rem 1.25rem;
  margin-top: 2rem;
}

.backlinks-header {
  font-family: 'Cinzel', serif !important;
  color: var(--gh-gold) !important;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

/* ── Graph View — Parchment Map Style ─────────────────────── */
.graph-view-outer,
.graph-view-container,
.mod-right-split .workspace-leaf-content,
.sidebar-right-ribbon {
  background-color: var(--gh-parchment) !important;
  border-left: none !important;
  border: 2px solid var(--gh-gold) !important;
  border-radius: 4px;
}

/* CSS variable approach — what Publish actually reads for canvas rendering */
:root {
  --graph-color-fill:            #8b0000;
  --graph-color-fill-attachment: #b8860b;
  --graph-color-fill-focused:    #d4a017;
  --graph-color-fill-unresolved: #c8a050;
  --graph-color-circle:          #8b0000;
  --graph-color-line:            #c8a050;
  --graph-color-text:            #4a3520;
  --graph-color-background:      #e8d9b8;
  --graph-color-background-dark: #e8d9b8;
}

/* Class approach — belt AND suspenders */
.graph-view.color-fill-background { color: #e8d9b8; }
.graph-view.color-fill            { color: #8b0000; }
.graph-view.color-circle          { color: #8b0000; }
.graph-view.color-fill-highlight  { color: #d4a017; }
.graph-view.color-fill-focused    { color: #d4a017; }
.graph-view.color-line            { color: #c8a050; }
.graph-view.color-line-highlight  { color: #d4a017; }
.graph-view.color-text            { color: #4a3520; }

/* Graph panel header */
.graph-controls,
.graph-view-header {
  background-color: var(--gh-parchment-dark) !important;
  border-bottom: 1px solid var(--gh-rule) !important;
  font-family: 'Cinzel', serif !important;
  font-size: 11px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--gh-gold) !important;
}

/* Hide global graph button — local graph stays visible */
div.graph-icon.graph-global {
  display: none !important;
}

/* "Interactive Graph" label */
.graph-view-header span,
.sidebar-right .view-header-title {
  font-family: 'Cinzel', serif !important;
  color: var(--gh-gold) !important;
  letter-spacing: 0.06em;
  font-size: 11px;
  text-transform: uppercase;
}

/* ============================================================
   ITS THEME INFOBOX COMPATIBILITY
   Matches SlRvb's [!infobox] callout structure, reskinned
   for Goldenheart's parchment/red/gold palette
   ============================================================ */

/* ── Core Infobox Layout ──────────────────────────────────── */
.callout[data-callout~="infobox"] {
  float: right !important;
  clear: right !important;
  width: 300px !important;
  max-width: 40% !important;
  margin: 0 0 1.5rem 2rem !important;
  padding: 0 !important;
  border: 2px solid var(--gh-rule) !important;
  border-top: 4px solid var(--gh-red) !important;
  border-radius: 4px !important;
  background-color: var(--gh-parchment-dark) !important;
  box-shadow: 3px 3px 10px var(--gh-shadow) !important;
  font-size: 14px !important;
  overflow: hidden !important;
}

/* Left-aligned variant */
.callout[data-callout~="infobox"][data-callout-metadata~="left"] {
  float: left !important;
  clear: left !important;
  margin: 0 2rem 1.5rem 0 !important;
}

/* Center variant */
.callout[data-callout~="infobox"][data-callout-metadata~="center"] {
  float: none !important;
  margin: 1.5rem auto !important;
  max-width: 60% !important;
}

/* ── Infobox Title (hidden by default, ITS behavior) ──────── */
.callout[data-callout~="infobox"] > .callout-title {
  display: none !important;
}

/* Show title when explicitly set with show-title / s-t */
.callout[data-callout~="infobox"][data-callout-metadata~="show-title"] > .callout-title,
.callout[data-callout~="infobox"][data-callout-metadata~="s-t"] > .callout-title {
  display: flex !important;
  background-color: var(--gh-red) !important;
  color: var(--gh-gold-pale) !important;
  font-family: 'Cinzel', serif !important;
  font-size: 12px !important;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 6px 10px !important;
  border-bottom: 1px solid var(--gh-gold) !important;
}

/* ── Infobox Content Area ─────────────────────────────────── */
.callout[data-callout~="infobox"] > .callout-content {
  padding: 0 !important;
  margin: 0 !important;
}

/* ── Infobox Headings — Section Dividers ──────────────────── */
.callout[data-callout~="infobox"] h1,
.callout[data-callout~="infobox"] h2,
.callout[data-callout~="infobox"] h3,
.callout[data-callout~="infobox"] h4,
.callout[data-callout~="infobox"] h5,
.callout[data-callout~="infobox"] h6 {
  font-family: 'Cinzel', serif !important;
  background-color: var(--gh-red) !important;
  color: var(--gh-gold-pale) !important;
  font-size: 13px !important;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin: 0 !important;
  padding: 5px 10px !important;
  border: none !important;
  border-bottom: 1px solid var(--gh-gold) !important;
  border-radius: 0 !important;
}

/* H1 specifically — usually the entity name, slightly larger */
.callout[data-callout~="infobox"] h1 {
  font-size: 15px !important;
  background-color: var(--gh-red) !important;
  color: var(--gh-gold-pale) !important;
  text-align: center;
  padding: 8px 10px !important;
  border-bottom: 2px solid var(--gh-gold) !important;
}

/* Remove the decorative gradient line under h1 inside infobox */
.callout[data-callout~="infobox"] h1::after {
  display: none !important;
}

/* ── Infobox Tables ───────────────────────────────────────── */
.callout[data-callout~="infobox"] table {
  width: 100% !important;
  border-collapse: collapse !important;
  margin: 0 !important;
  font-size: 13px !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

.callout[data-callout~="infobox"] thead {
  display: none !important;
}

.callout[data-callout~="infobox"] tbody tr {
  border-bottom: 1px solid var(--gh-parchment-deep) !important;
}

.callout[data-callout~="infobox"] tbody tr:last-child {
  border-bottom: none !important;
}

.callout[data-callout~="infobox"] tbody tr:nth-child(even) {
  background-color: rgba(200, 160, 80, 0.08) !important;
}

.callout[data-callout~="infobox"] td {
  padding: 4px 10px !important;
  color: var(--gh-ink) !important;
  vertical-align: top;
  border: none !important;
}

/* First column = label, styled like a stat block key */
.callout[data-callout~="infobox"] td:first-child {
  font-family: 'Cinzel', serif !important;
  font-size: 11px !important;
  font-weight: 600;
  color: var(--gh-ink-muted) !important;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  white-space: nowrap;
  width: 40%;
}

/* table-border metadata variant */
.callout[data-callout~="infobox"][data-callout-metadata~="table-border"] td:first-child,
.callout[data-callout~="infobox"][data-callout-metadata~="table-border"] th:first-child {
  border-right: 1px solid var(--gh-rule) !important;
}

/* ── Infobox Images ───────────────────────────────────────── */
.callout[data-callout~="infobox"] img,
.callout[data-callout~="infobox"] .internal-embed {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  border-radius: 0 !important;
  border: none !important;
  box-shadow: none !important;
}

/* cover modifier — fills width, cropped */
.callout[data-callout~="infobox"] img[alt~="cover"],
.callout[data-callout~="infobox"] .internal-embed[alt~="cover"] img {
  object-fit: cover !important;
  width: 100% !important;
  height: 180px !important;
}

/* icon modifier — small circular portrait */
.callout[data-callout~="infobox"] img[alt~="icon"],
.callout[data-callout~="infobox"] .internal-embed[alt~="icon"] img {
  width: 72px !important;
  height: 72px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  margin: 8px auto !important;
  border: 2px solid var(--gh-gold) !important;
}

/* Image size modifiers (ITS standard) */
.callout[data-callout~="infobox"] img[alt~="htiny"]  { height: 60px !important; }
.callout[data-callout~="infobox"] img[alt~="hsmall"] { height: 100px !important; }
.callout[data-callout~="infobox"] img[alt~="hmed"]   { height: 150px !important; }
.callout[data-callout~="infobox"] img[alt~="hlarge"] { height: 220px !important; }

/* ── Width Modifiers (ITS standard) ───────────────────────── */
.callout[data-callout~="infobox"][data-callout-metadata~="wtiny"]  { width: 20% !important; }
.callout[data-callout~="infobox"][data-callout-metadata~="wsmall"] { width: 30% !important; }
.callout[data-callout~="infobox"][data-callout-metadata~="ws-med"] { width: 40% !important; }
.callout[data-callout~="infobox"][data-callout-metadata~="wm-sm"]  { width: 50% !important; }
.callout[data-callout~="infobox"][data-callout-metadata~="wmed"]   { width: 60% !important; }
.callout[data-callout~="infobox"][data-callout-metadata~="wm-tl"]  { width: 80% !important; }
.callout[data-callout~="infobox"][data-callout-metadata~="wtall"]  { width: 95% !important; }
.callout[data-callout~="infobox"][data-callout-metadata~="wfull"]  { width: 100% !important; }

/* ── Nested Infobox (infobox inside infobox) ──────────────── */
.callout[data-callout~="infobox"] .callout-content > .callout[data-callout~="infobox"] {
  float: none !important;
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  border: none !important;
  border-top: 2px solid var(--gh-rule) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.callout[data-callout~="infobox"] .callout-content > .callout[data-callout~="infobox"] > .callout-title {
  display: none !important;
}

/* ── Infobox Paragraphs ───────────────────────────────────── */
.callout[data-callout~="infobox"] p {
  font-size: 13px !important;
  padding: 6px 10px !important;
  margin: 0 !important;
  text-align: left !important;
  max-width: 100% !important;
  color: var(--gh-ink) !important;
  hyphens: none !important;
}

/* ── Mobile: unstack infobox ──────────────────────────────── */
@media (max-width: 600px) {
  .callout[data-callout~="infobox"]:not([data-callout-metadata~="mobile"]) {
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 1.5rem 0 !important;
  }
}

/* ── Mobile Responsive ────────────────────────────────────── */
@media (max-width: 768px) {
  .markdown-preview-view,
  .publish-article {
    padding: 1rem 1.25rem;
  }

  .markdown-rendered p,
  .markdown-rendered li,
  .markdown-rendered blockquote {
    max-width: 100%;
  }

  h1, .markdown-rendered h1 {
    font-size: 1.7rem !important;
  }

  h2, .markdown-rendered h2 {
    font-size: 1.3rem !important;
  }

  table {
    font-size: 13px;
  }

  thead th {
    font-size: 11px;
  }
}

/* ── DM Callout — Hidden on Publish ──────────────────────────
   Hides the entire [!dm] callout block on the published site.
   In your vault it remains fully visible and editable.
─────────────────────────────────────────────────────────────── */

.callout[data-callout="dm"] {
  display: none !important;
}

/* BEGIN TTRPGTOOLS_ZOOMMAP_PUBLISH */

/* ZoomMap Publish runtime CSS (generated). */
:root{--ttrpgtools-hover-popover-max-width:720px;}
.zm-root{position:relative;width:100%;height:480px;background:var(--background-secondary,#1e1e1e);border:1px solid var(--background-modifier-border,#444);border-radius:6px;overflow:hidden;}
.zm-viewport{position:absolute;inset:0;overflow:hidden;touch-action:none;background:var(--background-primary,#111);}

/* Viewport frame (optional) */
.zm-root.zm-root--framepad{background:transparent;border:none;}
.zm-root.zm-root--framepad .zm-viewport{border:1px solid var(--background-modifier-border,#444);border-radius:6px;}
.zm-frame-layer{position:absolute;inset:0;pointer-events:none;z-index:40;}
.zm-viewport-frame{position:absolute;inset:0;width:100%;height:100%;object-fit:fill;object-position:center;pointer-events:none;user-select:none;-webkit-user-drag:none;}

.zm-hud-layer{position:absolute;inset:0;pointer-events:none;z-index:60;}
.zm-world{position:absolute;left:0;top:0;transform-origin:0 0;will-change:transform;}
.zm-image{display:block;user-select:none;-webkit-user-drag:none;pointer-events:none;}
.zm-overlays{position:absolute;left:0;top:0;pointer-events:none;z-index:5;}
.zm-overlay-image{position:absolute;left:0;top:0;width:100%;height:100%;object-fit:fill;pointer-events:none;user-select:none;-webkit-user-drag:none;}
.zm-markers{position:absolute;left:0;top:0;z-index:20;}
.zm-hud-markers{position:absolute;inset:0;pointer-events:none;z-index:25;}
.zm-marker{position:absolute;transform-origin:0 0;cursor:pointer;user-select:none;touch-action:none;}
.zm-hud-marker{position:absolute;transform-origin:0 0;pointer-events:auto;cursor:pointer;touch-action:none;user-select:none;z-index:30;}
.zm-marker-inv{transform-origin:0 0;}
.zm-marker-anchor{transform-origin:0 0;}
.zm-marker-icon{pointer-events:none;user-select:none;-webkit-user-drag:none;display:block;}

/* Always-visible marker label (tooltip caption) */
.zm-marker-label{position:absolute;left:0;top:0;transform-origin:0 0;pointer-events:none;z-index:35;max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px;line-height:1.2;padding:2px 6px;border-radius:6px;background:var(--background-primary,#111);border:1px solid var(--background-modifier-border,#444);box-shadow:0 8px 24px rgba(0,0,0,0.35);}
.zm-hidden{display:none!important;}

/* Tooltip */
.zm-tooltip{position:absolute;z-index:9999;max-width:360px;max-height:260px;overflow:auto;background:var(--background-primary,#111);border:1px solid var(--background-modifier-border,#444);border-radius:6px;padding:8px;box-shadow:0 8px 24px rgba(0,0,0,0.35);display:none;}
.zm-tooltip.zm-tooltip-visible{display:block;}
.zm-tooltip__title{font-weight:600;margin-bottom:6px;}
.zm-tooltip__body{white-space:pre-wrap;}

/* Context menu */
.zm-menu,.zm-submenu{position:fixed;z-index:10000;min-width:220px;max-width:340px;background:var(--background-primary,#111);border:1px solid var(--background-modifier-border,#444);border-radius:6px;box-shadow:0 10px 28px rgba(0,0,0,0.45);padding:4px;user-select:none;}
.zm-submenu{z-index:10001;}
.zm-menu__sep{height:1px;margin:4px;background:var(--background-modifier-border,#444);}
.zm-menu__item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:4px;color:var(--text-normal,#ddd);}
.zm-menu__item:hover{background:var(--background-modifier-hover,rgba(255,255,255,0.06));}
.zm-menu__label{flex:1;white-space:nowrap;text-align:left;}
.zm-menu__right{display:inline-flex;align-items:center;gap:8px;}
.zm-menu__check{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-accent,#6aa9ff);font-size:16px;}
.zm-menu__arrow{color:var(--text-muted,#aaa);}
.zm-menu__icon{width:18px;height:18px;object-fit:contain;}

/* Obsidian Publish hover popovers must be above viewport frames. */
.popover.hover-popover{z-index:9990!important;}
.hover-popover{z-index:9990!important;}

/* Publish hover popover sizing (configurable via plugin settings) */
.popover.hover-popover,.hover-popover{
  --popover-width:min(var(--ttrpgtools-hover-popover-max-width,720px),92vw);
  width:var(--popover-width)!important;
  max-width:var(--popover-width)!important;
  max-height:92vh!important;
  height:auto!important;
  overflow:hidden!important;
  display:flex!important;
  flex-direction:column!important;
}

.popover.hover-popover .hover-popover-content,
.hover-popover .hover-popover-content,
.popover.hover-popover .popover-content,
.hover-popover .popover-content,
.popover.hover-popover .markdown-preview-view,
.hover-popover .markdown-preview-view,
.popover.hover-popover .markdown-preview-section,
.hover-popover .markdown-preview-section{
  width:100%!important;
  max-width:100%!important;
  height:auto!important;
  max-height:100%!important;
}

.popover.hover-popover .hover-popover-content,
.hover-popover .hover-popover-content,
.popover.hover-popover .popover-content,
.hover-popover .popover-content{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow:auto!important;
}

.popover.hover-popover .markdown-preview-view,
.hover-popover .markdown-preview-view,
.popover.hover-popover .markdown-preview-section,
.hover-popover .markdown-preview-section{
  overflow:auto!important;
}

/* Measure overlay */
.zm-measure{position:absolute;left:0;top:0;pointer-events:none;z-index:18;}
.zm-measure__svg{width:100%;height:100%;overflow:visible;}
.zm-measure__path{stroke:var(--zm-measure-color,var(--text-accent,#6aa9ff));stroke-width:var(--zm-measure-width,2px);fill:none;vector-effect:non-scaling-stroke;}
.zm-measure__dot{fill:var(--zm-measure-color,var(--text-accent,#6aa9ff));stroke:var(--background-primary,#111);stroke-width:var(--zm-measure-width,2px);vector-effect:non-scaling-stroke;}
.zm-measure-hud{position:absolute;left:8px;top:8px;z-index:20;background:var(--background-primary,#111);border:1px solid var(--background-modifier-border,#444);border-radius:6px;padding:4px 8px;box-shadow:0 8px 24px rgba(0,0,0,0.35);font-size:12px;white-space:pre-line;pointer-events:none;display:none;}
.zm-measure-hud.zm-measure-hud-visible{display:block;}
.zm-toast{position:absolute;right:8px;bottom:8px;z-index:25;background:var(--background-primary,#111);border:1px solid var(--background-modifier-border,#444);border-radius:6px;padding:6px 10px;box-shadow:0 8px 24px rgba(0,0,0,0.35);font-size:12px;white-space:pre-line;pointer-events:none;display:none;max-width:min(520px,92vw);}
.zm-toast.zm-toast-visible{display:block;}

/* Drawings */
.zm-draw{position:absolute;left:0;top:0;pointer-events:none;z-index:10;}
.zm-draw__svg{width:100%;height:100%;overflow:visible;pointer-events:none;}
.zm-draw__shape{vector-effect:non-scaling-stroke;pointer-events:none;}
.zm-draw__label{font-size:12px;paint-order:stroke;stroke:var(--background-primary,#111);stroke-width:3px;}

/* Text layers (static render only) */
.zm-text{position:absolute;left:0;top:0;pointer-events:none;z-index:12;}
.zm-text__svg{width:100%;height:100%;overflow:visible;pointer-events:none;}

/* Canvas base */
.zm-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;}

/* =========================================================
   Timeline Publish runtime CSS (generated).
   Supports: ```timeline-cal and ```timeline-h
   ========================================================= */
.tl-controls{display:flex;gap:8px;align-items:center;margin:6px 0 10px;}
.tl-controls button{font:inherit;padding:6px 10px;border-radius:6px;border:1px solid var(--background-modifier-border,#444);background:var(--background-primary,#111);color:var(--text-normal,#ddd);}
.tl-controls button:hover{background:var(--background-modifier-hover,rgba(255,255,255,0.06));}

.tl-wrapper.tl-cross-mode{display:grid;gap:20px;}
.tl-row{width:100%;margin:0;}
.tl-grid{display:grid;align-items:center;column-gap:0;row-gap:0;}
.tl-grid.has-media{grid-template-columns:var(--tl-media-w,200px) 1fr;grid-template-areas:'media box';}
.tl-row.tl-align-right .tl-grid.has-media{grid-template-columns:1fr var(--tl-media-w,200px);grid-template-areas:'box media';}
.tl-grid.no-media{grid-template-columns:1fr;grid-template-areas:'box';}
.tl-media{grid-area:media;position:relative;overflow:hidden;border-radius:8px;background:var(--background-modifier-border,#444);z-index:2;}
.tl-box{grid-area:box;position:relative;box-sizing:border-box;padding:10px 12px;margin:0;background:var(--tl-bg,var(--background-primary,#111));border:1px solid var(--tl-accent,var(--background-modifier-border,#444));border-radius:10px;display:flex;flex-direction:column;overflow:hidden;}
.tl-row:not(.tl-align-right) .tl-box.has-media{border-left:none;border-top-left-radius:0;border-bottom-left-radius:0;}
.tl-row.tl-align-right .tl-box.has-media{border-right:none;border-top-right-radius:0;border-bottom-right-radius:0;}
.tl-box h1,.tl-box h4{margin:0 0 6px;}
.tl-title{font-size:1.3em;line-height:1.15;}
.tl-date{opacity:.85;font-weight:600;}
.tl-summary{line-height:1.4;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word;}
.tl-summary.tl-clamp{max-height:calc(var(--tl-summary-lines,6) * 1.4em);}
.tl-hover-anchor.internal-link{position:absolute;inset:0;z-index:5;text-decoration:none!important;color:transparent!important;background:transparent;cursor:pointer;}
.tl-media:hover + .tl-box,.tl-box:hover{background:var(--tl-hover,var(--background-modifier-hover,rgba(255,255,255,0.06)));}

/* Horizontal */
.tl-h-scroller{--tl-h-col-w:600px;--tl-h-gap:0px;--tl-h-stack-gap:26px;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;padding-bottom:8px;}
.tl-h-content.tl-h-mixed{display:flex;flex-direction:row;align-items:stretch;gap:var(--tl-h-gap,0px);}
.tl-h-content.tl-h-stacked{display:flex;flex-direction:column;gap:var(--tl-h-stack-gap,26px);}
.tl-h-item{flex:0 0 auto;width:var(--tl-h-col-w,600px);padding-left:0!important;padding-right:0!important;}
.tl-h-item .tl-grid.no-media{grid-template-columns:var(--tl-h-col-w,600px);}
.tl-h-item .tl-grid.has-media{grid-template-columns:var(--tl-media-w,200px) max(160px,calc(var(--tl-h-col-w,600px) - var(--tl-media-w,200px)));}
.tl-h-item.tl-align-right .tl-grid.has-media{grid-template-columns:max(160px,calc(var(--tl-h-col-w,600px) - var(--tl-media-w,200px))) var(--tl-media-w,200px);}
.tl-h-timeline{display:block;}
.tl-h-row{display:grid;grid-template-columns:repeat(var(--tl-h-cols,1),var(--tl-h-col-w,600px));column-gap:var(--tl-h-gap,0px);row-gap:12px;align-items:start;}
.tl-h-slot{grid-column-start:var(--tl-h-col);display:flex;flex-direction:column;gap:12px;}

@media (max-width:900px){
  .tl-h-scroller{--tl-h-col-w:420px;}
  .tl-grid.has-media{grid-template-columns:1fr!important;grid-template-areas:'media' 'box'!important;}
  .tl-media{width:100%!important;height:auto!important;border-radius:10px 10px 0 0;}
  .tl-media img{width:100%;height:auto!important;object-fit:cover;display:block;border-radius:10px 10px 0 0;}
  .tl-box.has-media{border-radius:0 0 10px 10px;border:1px solid var(--tl-accent,var(--background-modifier-border,#444));border-top:none;}
}

/* END TTRPGTOOLS_ZOOMMAP_PUBLISH */
