/* ─────────────────────────────────────────────────────────────────────────
   Ogur · MkDocs Material override layer
   Source of truth: ogur-brand-foundations (v2)
   Three faces, three jobs · hairlines, not shadows · editorial software
   ───────────────────────────────────────────────────────────────────────── */

@import url('https://api.fontshare.com/v2/css?f[]=switzer@200,300,400,500,600,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,opsz,wght@0,8..60,200..900;1,8..60,200..900&family=JetBrains+Mono:wght@400;500&display=swap');

/* ─────────────────────────────────────────────────────────────────────────
   Brand tokens — warm-neutral foundation + three semantic accents
   ───────────────────────────────────────────────────────────────────────── */
:root {
  /* Warm neutrals — 13 stops, paper not steel */
  --warm-25:  #FCFCFA;
  --warm-50:  #FAFAF7;
  --warm-100: #F4F4EE;
  --warm-150: #ECECE4;
  --warm-200: #E0E0D8;
  --warm-300: #C8C8BE;
  --warm-400: #A8A89E;
  --warm-500: #82827A;
  --warm-600: #5C5C56;
  --warm-700: #3E3E3A;
  --warm-800: #262624;
  --warm-900: #161614;
  --warm-950: #0E0E0E;

  /* Eclipse — primary brand accent · indigo */
  --eclipse-50:  #E9EAF1;
  --eclipse-100: #CACDDC;
  --eclipse-300: #555E82;
  --eclipse-500: #2A3052;
  --eclipse-700: #14182E;
  --eclipse-900: #080B1A;

  /* Oxblood — criticality · red */
  --oxblood-50:  #FBEEEB;
  --oxblood-100: #F2D2CC;
  --oxblood-300: #B85248;
  --oxblood-500: #8B2820;
  --oxblood-700: #5B1A1F;
  --oxblood-900: #2E0D10;

  /* Cellar — confirmation · green */
  --cellar-50:  #ECF0EC;
  --cellar-100: #D4DDD3;
  --cellar-300: #6B8C75;
  --cellar-500: #345042;
  --cellar-700: #1E3A2C;
  --cellar-900: #0E1F17;

  /* Semantic — what the product actually consumes */
  --bg:        var(--warm-50);
  --surface:   #FFFFFF;
  --surface-2: var(--warm-100);
  --ink:       var(--warm-950);
  --ink-2:     var(--warm-700);
  --ink-3:     var(--warm-600);
  --ink-4:     var(--warm-500);
  --ink-5:     var(--warm-400);
  --rule:      var(--warm-200);
  --rule-2:    var(--warm-150);

  --accent:    var(--eclipse-700);
  --accent-on: #FAFAF7;
  --critical:  var(--oxblood-700);
  --success:   var(--cellar-700);

  /* Type stacks */
  --sans:  'Switzer', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --serif: 'Source Serif 4', Iowan Old Style, Apple Garamond, Baskerville, Georgia, serif;
  --mono:  'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;

  /* Spacing — 4-pixel rhythm */
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-6:  24px;
  --space-8:  32px;
  --space-12: 48px;
  --space-16: 64px;

  /* Radius */
  --r-xs:   2px;
  --r-sm:   4px;
  --r-md:   6px;
  --r-lg:   8px;
  --r-xl:   12px;
  --r-full: 9999px;

  /* Motion */
  --t-instant: 100ms;
  --t-quick:   150ms;
  --t-gentle:  220ms;
  --t-breathe: 320ms;
  --ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.45, 0, 0.55, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Elevation — hairlines first, shadows for floating only */
  --shadow-popover: 0 1px 2px rgba(14,14,14,0.04), 0 4px 12px rgba(14,14,14,0.06);
  --shadow-modal:   0 4px 12px rgba(14,14,14,0.06), 0 24px 48px rgba(14,14,14,0.14);
}

/* ─────────────────────────────────────────────────────────────────────────
   Light scheme — Material variable overrides
   ───────────────────────────────────────────────────────────────────────── */
[data-md-color-scheme="ogur"] {
  --md-default-bg-color:           var(--bg);
  --md-default-bg-color--light:    var(--bg);
  --md-default-bg-color--lighter:  var(--bg);
  --md-default-fg-color:           var(--ink);
  --md-default-fg-color--light:    var(--ink-2);
  --md-default-fg-color--lighter:  var(--ink-3);
  --md-default-fg-color--lightest: var(--ink-4);

  --md-primary-fg-color:           var(--ink);
  --md-primary-fg-color--light:    var(--ink-2);
  --md-primary-fg-color--dark:     var(--ink);
  --md-primary-bg-color:           var(--bg);
  --md-primary-bg-color--light:    var(--surface-2);

  --md-accent-fg-color:            var(--accent);
  --md-accent-fg-color--transparent: rgba(20, 24, 46, 0.10);
  --md-accent-bg-color:             var(--bg);
  --md-accent-bg-color--light:      var(--surface-2);

  --md-typeset-color:    var(--ink);
  --md-typeset-a-color:  var(--ink);
  --md-typeset-mark-color: rgba(20, 24, 46, 0.12);

  --md-code-bg-color:   var(--surface-2);
  --md-code-fg-color:   var(--ink);

  --md-footer-bg-color:          var(--bg);
  --md-footer-bg-color--dark:    var(--surface-2);
  --md-footer-fg-color:          var(--ink);
  --md-footer-fg-color--light:   var(--ink-2);
  --md-footer-fg-color--lighter: var(--ink-4);

  --md-admonition-bg-color: var(--surface-2);
  --md-admonition-fg-color: var(--ink);

  color-scheme: light;
}

/* ─────────────────────────────────────────────────────────────────────────
   Dark scheme — invert ink / surface
   ───────────────────────────────────────────────────────────────────────── */
[data-md-color-scheme="ogur-dark"] {
  --bg:        var(--warm-950);
  --surface:   var(--warm-900);
  --surface-2: var(--warm-800);
  --ink:       var(--warm-50);
  --ink-2:     var(--warm-200);
  --ink-3:     var(--warm-300);
  --ink-4:     var(--warm-400);
  --ink-5:     var(--warm-500);
  --rule:      var(--warm-700);
  --rule-2:    var(--warm-800);
  --accent:    var(--eclipse-300);

  --md-default-bg-color:           var(--bg);
  --md-default-bg-color--light:    var(--surface);
  --md-default-bg-color--lighter:  var(--surface-2);
  --md-default-fg-color:           var(--ink);
  --md-default-fg-color--light:    var(--ink-2);
  --md-default-fg-color--lighter:  var(--ink-3);
  --md-default-fg-color--lightest: var(--ink-4);

  --md-primary-fg-color:           var(--ink);
  --md-primary-bg-color:           var(--bg);

  --md-accent-fg-color:            var(--accent);
  --md-accent-fg-color--transparent: rgba(85, 94, 130, 0.18);

  --md-typeset-color:    var(--ink);
  --md-typeset-a-color:  var(--ink);

  --md-code-bg-color:   var(--surface-2);
  --md-code-fg-color:   var(--ink);

  --md-footer-bg-color:          var(--bg);
  --md-footer-bg-color--dark:    var(--warm-950);
  --md-footer-fg-color:          var(--ink);
  --md-footer-fg-color--light:   var(--ink-2);
  --md-footer-fg-color--lighter: var(--ink-4);

  --md-admonition-bg-color: var(--surface-2);
  --md-admonition-fg-color: var(--ink);

  color-scheme: dark;
}

/* ─────────────────────────────────────────────────────────────────────────
   Typography — three faces, three jobs
   ───────────────────────────────────────────────────────────────────────── */
body,
.md-typeset {
  font-family: var(--sans);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

.md-typeset {
  font-size: 0.9375rem;     /* 15px */
  line-height: 1.5;
  color: var(--ink);
}

/* H1 — page title · editorial scale */
.md-typeset h1 {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 4rem;            /* 64px (smaller than cover's 180px, larger than section's 72px clamp) */
  line-height: 0.96;
  letter-spacing: -0.04em;
  color: var(--ink);
  margin: 0 0 1.6rem;
}

/* H1 lead — first paragraph after a page H1 = serif reading-mode signal */
.md-typeset h1 + p {
  font-family: var(--serif);
  font-variation-settings: "opsz" 19, "wght" 400;
  font-size: 1.1875rem;       /* 19px */
  line-height: 1.55;
  color: var(--ink-2);
  letter-spacing: -0.005em;
  max-width: 42rem;
  margin-bottom: 2.5rem;
}

/* H2 — section header */
.md-typeset h2 {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 2rem;            /* 32px */
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin: 4rem 0 1rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--rule);
}

/* H3 — sub-section */
.md-typeset h3 {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 1.25rem;         /* 20px */
  line-height: 1.25;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 2.4rem 0 0.6rem;
}

/* H4 — minor */
.md-typeset h4 {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 0.9375rem;       /* 15px */
  letter-spacing: 0;
  color: var(--ink);
  margin: 1.6rem 0 0.4rem;
}

/* Body */
.md-typeset p {
  margin: 0 0 1rem;
  color: var(--ink-2);
  max-width: 70ch;
}

/* Strong inside body → ink, weight 500 */
.md-typeset strong {
  font-weight: 500;
  color: var(--ink);
}

/* Italic — keep regular italic, body-color */
.md-typeset em {
  color: var(--ink-2);
}

/* Lead utility — explicit reading-mode prose anywhere */
.md-typeset .lead,
.md-typeset p.lead {
  font-family: var(--serif);
  font-variation-settings: "opsz" 19, "wght" 400;
  font-size: 1.1875rem;
  line-height: 1.55;
  color: var(--ink-2);
  letter-spacing: -0.005em;
  max-width: 42rem;
}

/* Eyebrow — uppercase mono labels with leading rule */
.md-typeset .eyebrow {
  font-family: var(--mono);
  font-size: 0.6875rem;       /* 11px */
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin: 2.5rem 0 1.25rem;
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 500;
}

.md-typeset .eyebrow::before {
  content: "";
  width: 24px;
  height: 1px;
  background: var(--ink-3);
  flex: 0 0 auto;
}

/* Links — ink default, accent on hover, no underline rot */
.md-typeset a {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-color: var(--rule);
  text-underline-offset: 3px;
  transition: color var(--t-quick) var(--ease-out),
              text-decoration-color var(--t-quick) var(--ease-out);
}

.md-typeset a:hover,
.md-typeset a:focus {
  color: var(--accent);
  text-decoration-color: var(--accent);
}

/* Selection */
::selection {
  background: var(--ink);
  color: var(--bg);
}

/* ─────────────────────────────────────────────────────────────────────────
   Code — JetBrains Mono · trust signal
   ───────────────────────────────────────────────────────────────────────── */
.md-typeset code {
  font-family: var(--mono);
  font-size: 0.85em;
  font-weight: 400;
  background: var(--surface-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-xs);
  padding: 1px 6px;
  color: var(--ink);
}

.md-typeset pre {
  background: var(--surface-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
}

.md-typeset pre > code {
  background: transparent;
  border: none;
  padding: 0;
  font-size: 0.8125rem;       /* 13px */
  line-height: 1.65;
}

.highlight {
  border-radius: var(--r-md);
}

/* ─────────────────────────────────────────────────────────────────────────
   Tables — paper, not steel
   ───────────────────────────────────────────────────────────────────────── */
.md-typeset table:not([class]) {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  font-family: var(--sans);
  font-size: 0.875rem;        /* 14px */
  overflow: hidden;
}

.md-typeset table:not([class]) th {
  background: var(--surface-2);
  font-weight: 500;
  letter-spacing: 0;
  color: var(--ink);
  text-align: left;
  padding: 12px 16px;
  border-bottom: 1px solid var(--rule);
}

.md-typeset table:not([class]) td {
  padding: 12px 16px;
  border-top: 1px solid var(--rule-2);
  vertical-align: top;
  color: var(--ink-2);
}

.md-typeset table:not([class]) td:first-child {
  color: var(--ink);
  font-weight: 500;
}

/* ─────────────────────────────────────────────────────────────────────────
   Blockquotes — accent stripe, restrained
   ───────────────────────────────────────────────────────────────────────── */
.md-typeset blockquote {
  border-left: 2px solid var(--accent);
  color: var(--ink-2);
  padding-left: var(--space-6);
  margin: 1.5rem 0;
  font-style: normal;
}

/* ─────────────────────────────────────────────────────────────────────────
   Header — quiet, hairline border
   ───────────────────────────────────────────────────────────────────────── */
.md-header {
  background: var(--bg);
  color: var(--ink);
  border-bottom: 1px solid var(--rule);
  box-shadow: none;
  transition: none;
}

.md-header[data-md-state="shadow"] {
  box-shadow: 0 1px 0 var(--rule);
}

.md-header__title {
  font-weight: 500;
  font-size: 0.9375rem;
  letter-spacing: -0.012em;
  color: var(--ink);
}

.md-header__topic:first-child {
  font-weight: 500;
}

.md-header__button.md-logo {
  margin: 0.4rem;
  padding: 0.4rem;
  color: var(--ink);
}

.md-header__button.md-logo img,
.md-header__button.md-logo svg {
  height: 1.4rem;
  width: 1.4rem;
}

/* ─────────────────────────────────────────────────────────────────────────
   Search — quiet, surface-2 background
   ───────────────────────────────────────────────────────────────────────── */
.md-search__form {
  background: var(--surface-2);
  border-radius: var(--r-sm);
  border: 1px solid var(--rule);
}

.md-search__input {
  font-family: var(--sans);
  font-weight: 400;
  font-size: 0.875rem;
}

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

[data-md-toggle="search"]:checked ~ .md-header .md-search__form {
  background: var(--surface);
  box-shadow: var(--shadow-popover);
}

/* Search results */
.md-search-result__meta {
  font-family: var(--mono);
  font-size: 0.6875rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.md-search-result__article {
  background: var(--surface);
}

/* ─────────────────────────────────────────────────────────────────────────
   Sidebar nav — editorial weight, restrained tracking
   ───────────────────────────────────────────────────────────────────────── */
.md-nav {
  font-family: var(--sans);
  font-size: 0.8125rem;       /* 13px */
  font-weight: 400;
}

.md-nav__title {
  font-family: var(--mono);
  font-weight: 500;
  font-size: 0.6875rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.md-nav__item .md-nav__link {
  color: var(--ink-2);
  padding: 0.32rem 0;
  transition: color var(--t-quick) var(--ease-out);
}

.md-nav__item .md-nav__link:hover,
.md-nav__item .md-nav__link:focus {
  color: var(--accent);
}

.md-nav__item .md-nav__link--active,
.md-nav__item .md-nav__link--active:hover {
  color: var(--ink);
  font-weight: 500;
}

/* Section labels (top-level groups) */
.md-nav__item--section > .md-nav__link {
  color: var(--ink);
  font-weight: 500;
  letter-spacing: 0;
}

/* Right-side TOC — slightly smaller, gentle */
.md-sidebar--secondary .md-nav__title {
  color: var(--ink-3);
}

.md-sidebar--secondary .md-nav__link {
  font-size: 0.75rem;         /* 12px */
  padding: 0.22rem 0;
  color: var(--ink-3);
}

.md-sidebar--secondary .md-nav__link:hover {
  color: var(--accent);
}

/* ─────────────────────────────────────────────────────────────────────────
   Tabs — quiet, no Material-loud underlines
   ───────────────────────────────────────────────────────────────────────── */
.md-tabs {
  background: var(--bg);
  color: var(--ink);
  border-bottom: 1px solid var(--rule);
  box-shadow: none;
}

.md-tabs__link {
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0;
  opacity: 0.6;
  margin-top: 0.7rem;
  padding-bottom: 0.7rem;
  color: var(--ink);
  transition: opacity var(--t-quick) var(--ease-out);
}

.md-tabs__link:hover,
.md-tabs__link--active {
  opacity: 1;
  color: var(--ink);
}

/* ─────────────────────────────────────────────────────────────────────────
   Admonitions — hairlines, accent-tinted left border
   ───────────────────────────────────────────────────────────────────────── */
.md-typeset .admonition,
.md-typeset details {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-left: 2px solid var(--accent);
  border-radius: var(--r-sm);
  font-size: 0.875rem;
  box-shadow: none;
  color: var(--ink);
}

.md-typeset .admonition-title,
.md-typeset summary {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 0.875rem;
  letter-spacing: 0;
  background: var(--surface-2);
  color: var(--ink);
  border-bottom: 1px solid var(--rule-2);
  padding-left: 2.4rem;
}

.md-typeset .admonition-title::before,
.md-typeset summary::before {
  background-color: var(--accent);
}

/* Variant accents — semantic */
.md-typeset .admonition.warning,
.md-typeset .admonition.danger,
.md-typeset details.warning,
.md-typeset details.danger {
  border-left-color: var(--critical);
}
.md-typeset .admonition.warning .admonition-title::before,
.md-typeset .admonition.danger .admonition-title::before,
.md-typeset details.warning summary::before,
.md-typeset details.danger summary::before {
  background-color: var(--critical);
}

.md-typeset .admonition.tip,
.md-typeset .admonition.success,
.md-typeset details.tip,
.md-typeset details.success {
  border-left-color: var(--success);
}
.md-typeset .admonition.tip .admonition-title::before,
.md-typeset .admonition.success .admonition-title::before,
.md-typeset details.tip summary::before,
.md-typeset details.success summary::before {
  background-color: var(--success);
}

/* ─────────────────────────────────────────────────────────────────────────
   Footer
   ───────────────────────────────────────────────────────────────────────── */
.md-footer {
  background: var(--bg);
  color: var(--ink-2);
  border-top: 1px solid var(--rule);
}

.md-footer-meta {
  background: var(--surface-2);
  font-family: var(--mono);
  font-size: 0.6875rem;
  letter-spacing: 0.04em;
  color: var(--ink-3);
}

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

/* ─────────────────────────────────────────────────────────────────────────
   Mermaid diagrams — brand surface
   ───────────────────────────────────────────────────────────────────────── */
.md-typeset .mermaid {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  padding: var(--space-6);
  margin: 1.5rem 0;
  text-align: center;
}

/* ─────────────────────────────────────────────────────────────────────────
   Grid cards — extends Material's grid cards with brand polish
   ───────────────────────────────────────────────────────────────────────── */
.md-typeset .grid.cards > :is(ul, ol) > li,
.md-typeset .grid > .card {
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  padding: var(--space-6);
  transition: border-color var(--t-quick) var(--ease-out),
              transform var(--t-quick) var(--ease-out);
}

.md-typeset .grid.cards > :is(ul, ol) > li:hover,
.md-typeset .grid > .card:hover {
  border-color: var(--accent);
  transform: translateY(-1px);
}

/* Card title (first paragraph) */
.md-typeset .grid.cards > :is(ul, ol) > li > p:first-child {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 1rem;
  letter-spacing: -0.012em;
  margin-bottom: 0.5rem;
  color: var(--ink);
}

.md-typeset .grid.cards > :is(ul, ol) > li > p:not(:first-child) {
  color: var(--ink-2);
  font-size: 0.875rem;
  line-height: 1.55;
  margin: 0.4rem 0 0;
}

.md-typeset .grid.cards > :is(ul, ol) > li > hr {
  border: 0;
  border-top: 1px solid var(--rule-2);
  margin: 0.8rem 0;
}

/* ─────────────────────────────────────────────────────────────────────────
   Status pills — for the project-status table on the landing page
   .pill class + status modifiers
   ───────────────────────────────────────────────────────────────────────── */
.md-typeset .pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 2px 10px;
  font-family: var(--mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: var(--r-sm);
  border: 1px solid var(--rule);
  background: var(--surface);
  color: var(--ink-2);
}

.md-typeset .pill--complete {
  border-color: var(--cellar-100);
  background: var(--cellar-50);
  color: var(--success);
}

.md-typeset .pill--progress {
  border-color: var(--eclipse-100);
  background: var(--eclipse-50);
  color: var(--accent);
}

.md-typeset .pill--planned {
  border-color: var(--rule);
  background: var(--surface-2);
  color: var(--ink-3);
}

/* ─────────────────────────────────────────────────────────────────────────
   Scrollbars
   ───────────────────────────────────────────────────────────────────────── */
.md-sidebar__scrollwrap::-webkit-scrollbar {
  width: 4px;
}

.md-sidebar__scrollwrap::-webkit-scrollbar-thumb {
  background: var(--rule);
  border-radius: 2px;
}

.md-sidebar__scrollwrap::-webkit-scrollbar-thumb:hover {
  background: var(--ink-4);
}

/* ─────────────────────────────────────────────────────────────────────────
   Print
   ───────────────────────────────────────────────────────────────────────── */
@media print {
  .md-header,
  .md-tabs,
  .md-sidebar,
  .md-footer { display: none; }
  .md-content { margin: 0; }
}
