/* ============================================================
   markus.plus — publish.css
   Features:
     #3  Tag pills (accent colour)
     #5  Last updated date badge
     #7  Copy-to-clipboard button
     #16 Print stylesheet
     #19 Frontmatter accent colour routing
   ============================================================ */


/* ── #3 Tag pills ────────────────────────────────────────────
   Tags are restyled as pill badges using the current accent
   colour (either the site default or a per-page --accent-page).
   -----------------------------------------------------------*/

.tag {
  display: inline-block;
  padding: 0.15em 0.65em;
  border-radius: 999px;
  font-size: 0.78em;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.01em;
  text-decoration: none;

  color: var(--background-primary);
  background-color: var(--accent-page, var(--color-accent));
  border: none;

  transition: background-color 0.15s, opacity 0.15s;
}

/* Hide the leading # character */
.tag::before {
  content: none !important;
}

.tag:hover {
  text-decoration: none;
  opacity: 0.85;
}


/* ── #5 Last updated badge ───────────────────────────────────*/

.markus-last-updated {
  display: block;
  font-size: 0.8em;
  color: var(--text-muted);
  margin-top: -0.4em;
  margin-bottom: 1.8em;
  letter-spacing: 0.01em;
}


/* ── #7 Copy-to-clipboard button ─────────────────────────────
   Hidden by default; fades in on pre:hover.
   -----------------------------------------------------------*/

pre {
  position: relative; /* needed for absolute button placement */
}

.markus-copy-btn {
  position: absolute;
  top: 0.55em;
  right: 0.55em;
  padding: 0.2em 0.65em;
  font-size: 0.72em;
  font-family: inherit;
  line-height: 1.5;
  cursor: pointer;
  border-radius: 4px;
  z-index: 10;

  /* Inherit theme surface colours */
  background: var(--background-secondary);
  color: var(--text-muted);
  border: 1px solid var(--background-modifier-border);

  /* Hidden until hover */
  opacity: 0;
  transition: opacity 0.15s ease, background 0.15s ease, color 0.15s ease;
}

pre:hover .markus-copy-btn {
  opacity: 1;
}

.markus-copy-btn:hover {
  background: var(--background-modifier-hover);
  color: var(--text-normal);
}

.markus-copy-btn--copied {
  color: var(--color-green, #2a9d8f) !important;
}


/* ── #19 Frontmatter accent colour routing ───────────────────
   When publish.js sets --accent-page on :root, reroute the
   Obsidian Publish accent variable so all themed elements
   (links, checkboxes, highlights, etc.) pick it up.
   -----------------------------------------------------------*/

:root[style*="--accent-page"] {
  --color-accent:        var(--accent-page);
  --color-accent-1:      var(--accent-page);
  --color-accent-2:      var(--accent-page);
  --interactive-accent:  var(--accent-page);
  --link-color:          var(--accent-page);
}


/* ── #16 Print stylesheet ────────────────────────────────────
   Strips all site chrome so notes print cleanly.
   -----------------------------------------------------------*/

@media print {

  /* Hide navigation and UI elements */
  .site-header,
  .site-footer,
  .nav-view-outer,
  .sidebar-left,
  .sidebar-right,
  .graph-view-container,
  .backlinks,
  .outline,
  .search-view-outer,
  .theme-toggle,
  .mobile-navbar,
  .markus-copy-btn {
    display: none !important;
  }

  /* Full-width, margin-free content */
  body,
  .app-container,
  .markdown-preview-view {
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0.5cm 1cm !important;
    background: #fff !important;
    color: #000 !important;
  }

  /* Readable body type */
  body {
    font-size: 11pt;
    line-height: 1.5;
  }

  /* Neutral links */
  a {
    color: #000;
    text-decoration: underline;
  }

  /* Show full URL for external links */
  a[href^="http"]::after,
  a[href^="https"]::after {
    content: " (" attr(href) ")";
    font-size: 0.8em;
    color: #555;
    word-break: break-all;
  }

  /* Don't show URL for internal links */
  a[href^="/"]::after {
    content: none;
  }

  /* Avoid breaking code across pages */
  pre, blockquote, table, figure {
    page-break-inside: avoid;
  }

  pre, code {
    border: 1px solid #ccc;
    background: #f5f5f5 !important;
    color: #000 !important;
  }

  h1, h2, h3 {
    page-break-after: avoid;
  }

  .markus-last-updated {
    color: #666;
  }
}