/* Design tokens mirrored from the dashboard
   (assets/host/frontend/src/styles/theme.ts) — the docs and the UI share
   one visual language: ink text, a single near-black accent, two slate
   hairline weights, white panels, no gradients or shadows. */
:root {
  --ink: #101214;
  --ink-soft: #3f4753;
  --muted: #5d6570;
  --accent: #111827;
  --accent-hover: #1f2937;
  --line: rgba(148, 163, 184, 0.45);
  --line-strong: rgba(148, 163, 184, 0.55);
  --bg: #f2f3f5;
  --warning-text: #b45309;
  --font-mono: "SFMono-Regular", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  --radius: 12px;
  --radius-lg: 16px;

  /* Map tokens onto Material's variables. */
  --md-primary-fg-color: var(--accent);
  --md-primary-fg-color--light: var(--accent-hover);
  --md-primary-fg-color--dark: var(--ink);
  --md-accent-fg-color: var(--accent-hover);
  --md-accent-fg-color--transparent: rgba(17, 24, 39, 0.07);
  --md-typeset-a-color: var(--accent);
  --md-default-fg-color: var(--ink);
  --md-default-fg-color--light: var(--muted);
  --md-default-fg-color--lighter: rgba(93, 101, 112, 0.6);
  --md-default-fg-color--lightest: rgba(93, 101, 112, 0.25);
  --md-code-bg-color: var(--bg);
  --md-code-fg-color: var(--ink);
  --md-code-font: "SFMono-Regular";
  --md-typeset-table-color: var(--line);
  --md-footer-bg-color: #ffffff;
  --md-footer-bg-color--dark: #ffffff;
  --md-footer-fg-color: var(--ink);
  --md-footer-fg-color--light: var(--muted);
  --md-footer-fg-color--lighter: var(--muted);
}

/* ---------------------------------------------------------------- header */

.md-header {
  background-color: #ffffff;
  color: var(--ink);
  box-shadow: none;
  border-bottom: 1px solid var(--line-strong);
}

/* Show the logo SVG in the header with a baseline-aligned subtitle. */
.md-header__button.md-logo {
  display: inline-flex;
  align-items: flex-end;
  gap: 8px;
  padding: 0.2rem 0;
  margin-right: 0.4rem;
}

.md-header__button.md-logo img {
  height: 26px;
  width: auto;
}

/* No subtitle in header — logo only. */

/* Hide the site-name text — the logo replaces it — but keep the container
   visible so the version selector (appended by mike JS) can render. */
.md-header__topic:first-child > .md-ellipsis {
  display: none;
}

.md-header__title {
  font-weight: 300;
}

/* ------------------------------------------------ version selector (mike) */

.md-version__current {
  color: var(--muted);
  font-size: 0.6rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.md-version__current::after {
  background-color: var(--muted);
}

.md-version__current:hover {
  color: var(--ink);
}

.md-version__current:hover::after {
  background-color: var(--ink);
}

.md-version__list {
  background-color: #ffffff;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.md-version__link {
  color: var(--muted);
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.02em;
}

.md-version__link:hover {
  color: var(--ink);
}

.md-search__form {
  background-color: rgba(16, 18, 20, 0.05);
  border-radius: 8px;
  transition: background-color 120ms ease;
}

.md-search__form:hover {
  background-color: rgba(16, 18, 20, 0.08);
}

.md-search__input {
  color: var(--ink);
}

.md-search__input::placeholder,
.md-search__icon {
  color: var(--muted);
}

/* Tablet/phone: keep the slide-out nav header white instead of primary. */
@media screen and (max-width: 76.1875em) {
  .md-nav--primary .md-nav__title {
    background-color: #ffffff;
    color: var(--ink);
  }
}

/* ----------------------------------------------------------------- links */

.md-typeset a {
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--line-strong);
  transition: text-decoration-color 120ms ease, color 120ms ease;
}

.md-typeset a:hover {
  text-decoration-color: currentColor;
}

/* ------------------------------------------------------- nav sidebar/toc */

.md-nav__link {
  color: var(--muted);
}

.md-nav__link--active,
.md-nav__link--active code {
  color: var(--ink);
  font-weight: 600;
}

.md-nav__title {
  color: var(--muted);
  font-size: 0.6rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* ------------------------------------------------------------ code blocks */

.md-typeset pre > code {
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.md-typeset code {
  border-radius: 6px;
}

.md-clipboard {
  color: var(--muted);
  transition: color 120ms ease;
}

.md-clipboard:hover {
  color: var(--ink);
}

/* ------------------------------------------------------------ admonitions */

.md-typeset .admonition,
.md-typeset details,
.md-typeset .admonition.note,
.md-typeset .admonition.tip,
.md-typeset .admonition.warning,
.md-typeset .admonition.info,
.md-typeset .admonition.danger {
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  background-color: #ffffff;
  box-shadow: none;
}

.md-typeset .admonition > .admonition-title,
.md-typeset details > summary {
  background-color: transparent;
  color: var(--muted);
  font-size: 0.6rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* Semantic color lives only in the icon. */
.md-typeset .admonition > .admonition-title::before,
.md-typeset details > summary::before {
  background-color: var(--ink-soft);
}

.md-typeset .admonition.warning > .admonition-title::before,
.md-typeset .admonition.danger > .admonition-title::before {
  background-color: var(--warning-text);
}

/* ----------------------------------------------------------------- tables */

.md-typeset table:not([class]) {
  border: 1px solid var(--line-strong);
  border-radius: var(--radius);
  box-shadow: none;
}

.md-typeset table:not([class]) th {
  background-color: transparent;
  color: var(--muted);
  font-size: 0.6rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-bottom: 1px solid var(--line-strong);
}

.md-typeset table:not([class]) tbody tr {
  transition: background-color 120ms ease;
}

.md-typeset table:not([class]) tbody tr:hover {
  background-color: rgba(16, 18, 20, 0.025);
  box-shadow: none;
}

/* ----------------------------------------------------------------- footer */

.md-footer {
  border-top: 1px solid var(--line-strong);
}

.md-footer-meta {
  border-top: 1px solid var(--line);
}

/* ------------------------------------------------------------- hero/index */

.hero {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  align-items: center;
  margin: 1.5rem 0 2rem;
}

.hero-card {
  background-color: #ffffff;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
}

.hero-card h2 {
  margin-top: 0;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.hero-image {
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.hero-image img {
  display: block;
}

.grid-2 {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

/* ---------------------------------------------------------- screenshots */

.screenshot {
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin: 1.25rem 0;
}

.screenshot img {
  display: block;
  width: 100%;
  height: auto;
  cursor: zoom-in;
}

.screenshot-narrow {
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}

/* ------------------------------------------------- index page brand title */

/* Hide auto-generated page title on the index page (brand replaces it). */
.md-content__inner > h1:first-child:has(~ .docs-brand) {
  display: none;
}

.docs-brand {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  margin: 0 0 1.5rem;
}

.docs-brand > p,
.docs-brand a.glightbox {
  display: contents;
}

.md-typeset .docs-brand img.docs-brand-logo {
  height: clamp(52px, 7.5vw, 96px);
  width: auto;
  max-width: none;
}

.md-typeset .docs-brand .docs-brand-subtitle {
  font-size: clamp(14px, 2.1vw, 24px);
  font-weight: 300;
  letter-spacing: 0.05em;
  opacity: 0.4;
  padding-bottom: 0.45em;
  white-space: nowrap;
}
