/* ─────────────────────────────────────────────────────────────────────────
 * dockersnap docs — design overrides
 *
 * Ports the dashboard's "amber CRT meets Linear" language onto MkDocs
 * Material. See docs/DASHBOARD-DESIGN.md §3b for the source of truth on
 * tokens, palette rationale, and visual rules.
 *
 * Hard rules (carried over from the dashboard):
 *   - Sharp corners (≤ 2px). No rounded-xl, no pill buttons.
 *   - Single amber accent on interactive elements only — never on chrome.
 *   - Status colors (sage, slate-blue, terracotta) live on their own
 *     conceptual territory; admonitions get coloured left borders, not
 *     filled backgrounds that compete with the page.
 *   - Identifiers, command samples, and table numerics in JetBrains Mono.
 *   - Density over whitespace: tight tables, single-pixel borders.
 *   - Flat surfaces; no gradients, no atmospheric textures.
 * ───────────────────────────────────────────────────────────────────────── */

/* ── 1. Self-hosted typography (no Google Fonts) ──────────────────────── */
@font-face {
  font-family: "Geist";
  src: url("../assets/fonts/Geist-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Geist";
  src: url("../assets/fonts/Geist-Medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Geist";
  src: url("../assets/fonts/Geist-SemiBold.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "JetBrains Mono";
  src: url("../assets/fonts/JetBrainsMono-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "JetBrains Mono";
  src: url("../assets/fonts/JetBrainsMono-Medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

/* ── 2. Mode-invariant tokens ─────────────────────────────────────────── */
:root {
  /* Amber accent (h=75) — distinct from Tailwind-blue, terminal heritage. */
  --ds-accent: oklch(0.78 0.16 75);
  --ds-accent-hover: oklch(0.84 0.16 75);
  --ds-accent-muted: oklch(0.78 0.16 75 / 0.18);
  --ds-accent-fg: oklch(0.18 0.02 60);
  --ds-focus-ring: oklch(0.78 0.16 75 / 0.45);
  --ds-selection: oklch(0.78 0.16 75 / 0.3);

  /* Status semantics (admonition borders). */
  --ds-status-running: oklch(0.72 0.13 155); /* sage emerald  */
  --ds-status-stopped: oklch(0.62 0.02 240); /* slate blue    */
  --ds-status-error: oklch(0.62 0.18 25); /* terracotta    */
  --ds-status-unknown: oklch(0.55 0.005 60); /* warm grey     */

  /* Material font tokens — Geist for prose, JetBrains Mono for code. */
  --md-text-font: "Geist", ui-sans-serif, system-ui, sans-serif;
  --md-code-font: "JetBrains Mono", ui-monospace, "Menlo", "Consolas", monospace;
}

/* ── 3. Dark scheme (Material's "slate") ──────────────────────────────── */
[data-md-color-scheme="slate"] {
  color-scheme: dark;

  --md-default-bg-color: oklch(0.18 0.005 60);
  --md-default-bg-color--light: oklch(0.205 0.005 60);
  --md-default-bg-color--lighter: oklch(0.22 0.005 60);
  --md-default-bg-color--lightest: oklch(0.255 0.005 60);

  --md-default-fg-color: oklch(0.96 0.005 60);
  --md-default-fg-color--light: oklch(0.78 0.005 60);
  --md-default-fg-color--lighter: oklch(0.58 0.005 60);
  --md-default-fg-color--lightest: oklch(0.42 0.005 60);

  /* Header / footer chrome — surface, not amber. The amber is reserved
     for interactive moments; the chrome stays quiet. */
  --md-primary-fg-color: oklch(0.22 0.005 60);
  --md-primary-fg-color--light: oklch(0.255 0.005 60);
  --md-primary-fg-color--dark: oklch(0.14 0.005 60);
  --md-primary-bg-color: oklch(0.96 0.005 60);
  --md-primary-bg-color--light: oklch(0.78 0.005 60);

  --md-accent-fg-color: var(--ds-accent);
  --md-accent-fg-color--transparent: var(--ds-accent-muted);
  --md-accent-bg-color: var(--ds-accent-fg);
  --md-accent-bg-color--light: var(--ds-accent-fg);

  --md-typeset-color: oklch(0.96 0.005 60);
  --md-typeset-a-color: var(--ds-accent);
  --md-typeset-mark-color: oklch(0.78 0.16 75 / 0.35);
  --md-typeset-kbd-color: oklch(0.22 0.005 60);
  --md-typeset-kbd-border-color: oklch(0.3 0.005 60);
  --md-typeset-kbd-accent-color: oklch(0.42 0.005 60);
  --md-typeset-table-color: oklch(0.3 0.005 60);
  --md-typeset-table-color--light: oklch(0.205 0.005 60);

  --md-code-bg-color: oklch(0.14 0.005 60);
  --md-code-fg-color: oklch(0.96 0.005 60);

  --md-footer-bg-color: oklch(0.14 0.005 60);
  --md-footer-bg-color--dark: oklch(0.11 0.005 60);
  --md-footer-fg-color: oklch(0.78 0.005 60);
  --md-footer-fg-color--light: oklch(0.58 0.005 60);
  --md-footer-fg-color--lighter: oklch(0.42 0.005 60);
}

/* ── 4. Light scheme (Material's "default") ───────────────────────────── */
[data-md-color-scheme="default"] {
  color-scheme: light;

  --md-default-bg-color: oklch(0.985 0.003 60);
  --md-default-bg-color--light: oklch(0.975 0.003 60);
  --md-default-bg-color--lighter: oklch(1 0 0);
  --md-default-bg-color--lightest: oklch(0.96 0.003 60);

  --md-default-fg-color: oklch(0.2 0.01 60);
  --md-default-fg-color--light: oklch(0.45 0.005 60);
  --md-default-fg-color--lighter: oklch(0.62 0.005 60);
  --md-default-fg-color--lightest: oklch(0.78 0.003 60);

  --md-primary-fg-color: oklch(0.985 0.003 60);
  --md-primary-fg-color--light: oklch(1 0 0);
  --md-primary-fg-color--dark: oklch(0.96 0.003 60);
  --md-primary-bg-color: oklch(0.2 0.01 60);
  --md-primary-bg-color--light: oklch(0.45 0.005 60);

  /* On a light background the same amber goes muddy; pull lightness down a
     touch and shift hue slightly toward orange so links stay legible at
     body-copy size. */
  --md-accent-fg-color: oklch(0.6 0.18 65);
  --md-accent-fg-color--transparent: oklch(0.78 0.16 75 / 0.18);

  --md-typeset-color: oklch(0.2 0.01 60);
  --md-typeset-a-color: oklch(0.55 0.17 65);
  --md-typeset-mark-color: oklch(0.78 0.16 75 / 0.35);
  --md-typeset-table-color: oklch(0.9 0.003 60);
  --md-typeset-table-color--light: oklch(0.975 0.003 60);

  --md-code-bg-color: oklch(0.96 0.003 60);
  --md-code-fg-color: oklch(0.2 0.01 60);

  /* Footer always dark — operator tools belong on dark chrome, even when
     the body is light. */
  --md-footer-bg-color: oklch(0.18 0.005 60);
  --md-footer-bg-color--dark: oklch(0.14 0.005 60);
  --md-footer-fg-color: oklch(0.78 0.005 60);
  --md-footer-fg-color--light: oklch(0.58 0.005 60);
  --md-footer-fg-color--lighter: oklch(0.42 0.005 60);
}

/* ── 5. Sharp corners everywhere ──────────────────────────────────────── */
.md-typeset code,
.md-typeset pre,
.md-typeset pre > code,
.md-typeset .highlight,
.md-typeset .highlight pre,
.md-typeset .highlighttable,
.md-typeset .admonition,
.md-typeset details,
.md-typeset .tabbed-set > input + label,
.md-typeset .md-button,
.md-typeset table:not([class]),
.md-typeset .keys kbd,
.md-search__form,
.md-search__input,
.md-search__output,
.md-search-result__article,
.md-nav__source,
.md-tag,
.md-typeset blockquote {
  border-radius: 2px;
}

/* ── 6. Header chrome — quiet surface, single-pixel underline ─────────── */
.md-header {
  background-color: var(--md-primary-fg-color);
  color: var(--md-default-fg-color);
  border-bottom: 1px solid var(--md-typeset-table-color);
  box-shadow: none;
}
.md-header[data-md-state="shadow"] {
  box-shadow: 0 1px 0 0 var(--md-typeset-table-color);
}
.md-header__title {
  font-weight: 600;
  letter-spacing: -0.01em;
}

/* ── 7. Tabs — amber underline on the active tab, never a fill ────────── */
.md-tabs {
  background: transparent;
  color: var(--md-default-fg-color--light);
  border-bottom: 1px solid var(--md-typeset-table-color);
}
.md-tabs__link {
  color: var(--md-default-fg-color--light);
  opacity: 1;
  margin-top: 0.6rem;
}
.md-tabs__link:hover {
  color: var(--ds-accent);
}
.md-tabs__item--active > .md-tabs__link,
.md-tabs__link--active {
  color: var(--ds-accent);
}
.md-tabs__item--active {
  position: relative;
}
.md-tabs__item--active::after {
  content: "";
  position: absolute;
  left: 0.8rem;
  right: 0.8rem;
  bottom: 0;
  height: 2px;
  background: var(--ds-accent);
}

/* ── 8. Sidebar nav — amber for the active leaf, no chevron weight ────── */
.md-nav__title {
  font-weight: 600;
  font-size: 0.74rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--md-default-fg-color--lighter);
}
.md-nav__link {
  color: var(--md-default-fg-color--light);
}
.md-nav__link:focus,
.md-nav__link:hover {
  color: var(--ds-accent);
}
.md-nav__item .md-nav__link--active,
.md-nav__item .md-nav__link--active code {
  color: var(--ds-accent);
  font-weight: 500;
}

/* ── 9. Code blocks — inline gets a subtle border, blocks stay flat ───── */
.md-typeset code {
  font-family: var(--md-code-font);
  font-size: 0.85em;
  font-feature-settings: "ss01", "cv01";
}
.md-typeset :not(pre) > code {
  background: var(--md-code-bg-color);
  border: 1px solid var(--md-typeset-table-color);
  padding: 0.05em 0.35em;
  color: var(--md-code-fg-color);
}
.md-typeset pre > code {
  border: 1px solid var(--md-typeset-table-color);
  font-size: 0.82em;
  line-height: 1.55;
}
.md-typeset .highlight {
  border-radius: 2px;
}

/* ── 10. Tables — single-pixel grid, tabular numerics ─────────────────── */
.md-typeset table:not([class]) {
  font-size: 0.78rem;
  border: 1px solid var(--md-typeset-table-color);
  font-feature-settings: "tnum";
}
.md-typeset table:not([class]) th {
  background: var(--md-default-bg-color--light);
  font-weight: 600;
  letter-spacing: 0.01em;
  border-bottom: 1px solid var(--md-typeset-table-color);
}
.md-typeset table:not([class]) td,
.md-typeset table:not([class]) th {
  padding: 0.5rem 0.75rem;
  border-color: var(--md-typeset-table-color--light);
}
.md-typeset table:not([class]) tr:hover td {
  background: var(--md-default-bg-color--light);
}
.md-typeset table:not([class]) code {
  font-size: 0.85em;
}

/* ── 11. Admonitions — flat, with a 3px left border by status ─────────── */
.md-typeset .admonition,
.md-typeset details {
  border: 1px solid var(--md-typeset-table-color);
  border-left: 3px solid var(--ds-accent);
  background: var(--md-default-bg-color--light);
  box-shadow: none;
  font-size: 0.78rem;
}
.md-typeset .admonition-title,
.md-typeset summary {
  background: transparent;
  border-bottom: 1px solid var(--md-typeset-table-color);
  font-weight: 600;
}
.md-typeset .admonition-title::before,
.md-typeset summary::before {
  background-color: var(--ds-accent);
}

/* Note / info / abstract — slate-blue (the "stopped" idle territory) */
.md-typeset .admonition.note,
.md-typeset details.note,
.md-typeset .admonition.info,
.md-typeset details.info,
.md-typeset .admonition.abstract,
.md-typeset details.abstract {
  border-left-color: var(--ds-status-stopped);
}
.md-typeset .admonition.note > .admonition-title::before,
.md-typeset details.note > summary::before,
.md-typeset .admonition.info > .admonition-title::before,
.md-typeset details.info > summary::before,
.md-typeset .admonition.abstract > .admonition-title::before,
.md-typeset details.abstract > summary::before {
  background-color: var(--ds-status-stopped);
}

/* Tip / success / hint — sage emerald (the "running" healthy state) */
.md-typeset .admonition.tip,
.md-typeset details.tip,
.md-typeset .admonition.success,
.md-typeset details.success,
.md-typeset .admonition.hint,
.md-typeset details.hint {
  border-left-color: var(--ds-status-running);
}
.md-typeset .admonition.tip > .admonition-title::before,
.md-typeset details.tip > summary::before,
.md-typeset .admonition.success > .admonition-title::before,
.md-typeset details.success > summary::before,
.md-typeset .admonition.hint > .admonition-title::before,
.md-typeset details.hint > summary::before {
  background-color: var(--ds-status-running);
}

/* Warning — amber (already accent — pairs naturally with caution copy) */
.md-typeset .admonition.warning,
.md-typeset details.warning,
.md-typeset .admonition.caution,
.md-typeset details.caution {
  border-left-color: var(--ds-accent);
}

/* Danger / failure / bug — terracotta */
.md-typeset .admonition.danger,
.md-typeset details.danger,
.md-typeset .admonition.failure,
.md-typeset details.failure,
.md-typeset .admonition.bug,
.md-typeset details.bug,
.md-typeset .admonition.error,
.md-typeset details.error {
  border-left-color: var(--ds-status-error);
}
.md-typeset .admonition.danger > .admonition-title::before,
.md-typeset details.danger > summary::before,
.md-typeset .admonition.failure > .admonition-title::before,
.md-typeset details.failure > summary::before,
.md-typeset .admonition.bug > .admonition-title::before,
.md-typeset details.bug > summary::before,
.md-typeset .admonition.error > .admonition-title::before,
.md-typeset details.error > summary::before {
  background-color: var(--ds-status-error);
}

/* ── 12. Headings — tight, semibold, hairline rule under H1 ───────────── */
.md-typeset h1,
.md-typeset h2,
.md-typeset h3,
.md-typeset h4 {
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--md-default-fg-color);
}
.md-typeset h1 {
  font-size: 1.85rem;
  border-bottom: 1px solid var(--md-typeset-table-color);
  padding-bottom: 0.4rem;
  margin-bottom: 1.2rem;
}
.md-typeset h2 {
  font-size: 1.3rem;
  margin-top: 2.2rem;
}
.md-typeset h3 {
  font-size: 1.05rem;
}

/* ── 13. Buttons — sharp; primary fills with amber ────────────────────── */
.md-typeset .md-button {
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 2px;
  font-weight: 500;
  letter-spacing: 0.01em;
}
.md-typeset .md-button--primary {
  background: var(--ds-accent);
  color: var(--ds-accent-fg);
  border-color: var(--ds-accent);
}
.md-typeset .md-button--primary:focus,
.md-typeset .md-button--primary:hover {
  background: var(--ds-accent-hover);
  color: var(--ds-accent-fg);
  border-color: var(--ds-accent-hover);
}

/* ── 14. Search — amber accents, sharp container ──────────────────────── */
.md-search__form {
  background-color: var(--md-default-bg-color--light);
  border: 1px solid var(--md-typeset-table-color);
}
.md-search__form:hover {
  background-color: var(--md-default-bg-color--lightest);
}
.md-search-result mark {
  background-color: var(--ds-accent-muted);
  color: var(--ds-accent);
  padding: 0 1px;
}
[data-md-toggle="search"]:checked ~ .md-header .md-search__form {
  border-color: var(--ds-accent);
}

/* ── 15. Selection + focus halo ───────────────────────────────────────── */
::selection {
  background-color: var(--ds-selection);
}
.md-typeset a:focus-visible,
.md-button:focus-visible,
.md-tabs__link:focus-visible,
.md-nav__link:focus-visible,
.md-search__input:focus-visible {
  outline: 2px solid var(--ds-focus-ring);
  outline-offset: 2px;
  border-radius: 2px;
}

/* ── 16. Footer — terminal-dark even in light mode (per design doc) ──── */
.md-footer {
  background-color: var(--md-footer-bg-color);
  color: var(--md-footer-fg-color);
}
.md-footer-meta {
  background-color: var(--md-footer-bg-color--dark);
}
.md-footer__link:hover .md-footer__title {
  color: var(--ds-accent);
}

/* ── 17. Body link underline — present but quiet, amber on hover ──────── */
.md-typeset a {
  text-decoration: none;
  border-bottom: 1px solid var(--md-typeset-table-color);
  transition: color 80ms ease, border-color 80ms ease;
}
.md-typeset a:hover {
  color: var(--ds-accent);
  border-bottom-color: var(--ds-accent);
}

/* ── 18. Blockquotes — left rule in amber-muted, no italic ────────────── */
.md-typeset blockquote {
  border-left: 3px solid var(--ds-accent-muted);
  color: var(--md-default-fg-color--light);
  padding-left: 1rem;
  font-style: normal;
  margin-left: 0;
}

/* ── 19. Mark + kbd — small terminal-adjacent flourishes ──────────────── */
.md-typeset mark {
  background-color: var(--ds-accent-muted);
  color: var(--md-default-fg-color);
  padding: 0 2px;
}
.md-typeset kbd {
  font-family: var(--md-code-font);
  font-size: 0.78em;
  border: 1px solid var(--md-typeset-kbd-border-color);
  border-bottom-width: 2px;
  padding: 0.1em 0.4em;
  background: var(--md-typeset-kbd-color);
}
