/* EMPN brand overrides for MkDocs Material.
 *
 * Goal: light, airy, low-density. Cream background, navy primary,
 * orange accent for emphasis. Freight Display Pro Book for headings,
 * Söhne for body. Matches the visual identity of empn.eu.
 *
 * Brand tokens mirror plugins/empn-core/shared/empn/visuals/design-tokens.yaml.
 * Update both in the same commit when the brand palette changes.
 */

/* ---- Web fonts: load from empn.eu (same canonical source as in-skill
 * embeds). If empn.eu is unreachable, fall back to Georgia / Arial. */

@font-face {
  font-family: "Freight Display Pro Book";
  src: url("https://empn.eu/wp-content/themes/empn/dist/BVj-n37x.woff2") format("woff2"),
       url("https://empn.eu/wp-content/themes/empn/dist/B9g9AJpx.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Söhne";
  src: url("https://empn.eu/wp-content/themes/empn/dist/BbOgjKDo.woff2") format("woff2"),
       url("https://empn.eu/wp-content/themes/empn/dist/FePQAFPJ.woff") format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Söhne";
  src: url("https://empn.eu/wp-content/themes/empn/dist/Hhs_d3ts.woff2") format("woff2"),
       url("https://empn.eu/wp-content/themes/empn/dist/Ddw76IwM.woff") format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ---- Brand tokens ---- */
:root {
  --empn-navy:   #091436;
  --empn-blue:   #016EA1;
  --empn-orange: #FFA500;
  --empn-cream:  #FFFDF8;
  --empn-text:   #272727;
  --empn-muted:  #595959;
  --empn-rule:   #E6E6E5;

  /* Material theme colour overrides */
  --md-primary-fg-color:        var(--empn-navy);
  --md-primary-fg-color--light: var(--empn-blue);
  --md-primary-fg-color--dark:  var(--empn-navy);
  --md-primary-bg-color:        var(--empn-cream);
  --md-primary-bg-color--light: var(--empn-cream);
  --md-accent-fg-color:         var(--empn-orange);
  --md-accent-fg-color--transparent: rgba(255, 165, 0, 0.1);
  --md-accent-bg-color:         var(--empn-cream);

  --md-default-bg-color:        var(--empn-cream);
  --md-default-fg-color:        var(--empn-text);
  --md-default-fg-color--light: var(--empn-muted);
  --md-typeset-a-color:         var(--empn-blue);

  --md-code-bg-color:           #F4F2EC;
  --md-code-fg-color:           #2B2B2B;
}

/* ---- Typography ---- */
body, .md-typeset {
  font-family: "Söhne", "Soehne", Arial, Helvetica, sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 1.65;
  letter-spacing: 0.005em;
  color: var(--empn-text);
}

.md-typeset h1, .md-typeset h2, .md-typeset h3, .md-typeset h4,
.md-header__title, .md-nav__title {
  font-family: "Freight Display Pro Book", "FreightDisplay", Georgia, serif;
  font-weight: 400;
  font-synthesis: none;
  letter-spacing: -0.005em;
  color: var(--empn-navy);
}

.md-typeset h1 { font-size: 2.4rem; line-height: 1.15; margin-bottom: 1rem; }
.md-typeset h2 { font-size: 1.7rem; line-height: 1.25; margin-top: 2.4rem; }
.md-typeset h3 { font-size: 1.25rem; line-height: 1.3;  margin-top: 1.8rem; }
.md-typeset h4 { font-size: 1.05rem; line-height: 1.4;  font-weight: 700; font-family: "Söhne", sans-serif; }

.md-typeset strong { font-weight: 700; }
.md-typeset em     { font-style: italic; }

/* ---- Header (top nav bar) ---- */
.md-header {
  background-color: var(--empn-cream);
  color: var(--empn-navy);
  box-shadow: none;
  border-bottom: 1px solid var(--empn-rule);
}
.md-header__title {
  color: var(--empn-navy);
  font-size: 1.05rem;
}
.md-search__input {
  background-color: rgba(9, 20, 54, 0.06);
  color: var(--empn-navy);
}
.md-search__input::placeholder {
  color: var(--empn-muted);
}

/* ---- Primary tabs (page nav) ---- */
.md-tabs {
  background-color: var(--empn-cream);
  color: var(--empn-navy);
  border-bottom: 1px solid var(--empn-rule);
}
.md-tabs__link {
  color: var(--empn-muted);
  opacity: 1;
  font-size: 0.85rem;
  letter-spacing: 0.01em;
}
.md-tabs__link--active,
.md-tabs__link:hover {
  color: var(--empn-navy);
  border-bottom: 2px solid var(--empn-orange);
}

/* ---- Sidebar nav ---- */
.md-nav__title { color: var(--empn-navy); }
.md-nav__link  { color: var(--empn-text); }
.md-nav__link:hover,
.md-nav__link--active { color: var(--empn-blue); }

/* ---- Links ---- */
.md-typeset a {
  color: var(--empn-blue);
  text-decoration: none;
  border-bottom: 1px solid rgba(1, 110, 161, 0.25);
}
.md-typeset a:hover {
  color: var(--empn-navy);
  border-bottom-color: var(--empn-orange);
}

/* ---- Code blocks: subtle, not loud ---- */
.md-typeset code,
.md-typeset pre {
  font-family: "SF Mono", "Menlo", "Consolas", monospace;
  font-size: 0.85em;
}
.md-typeset pre > code {
  background-color: var(--md-code-bg-color);
  border-radius: 4px;
}
.md-typeset :not(pre) > code {
  background-color: var(--md-code-bg-color);
  padding: 0.1em 0.35em;
  border-radius: 3px;
}

/* ---- Admonitions: less garish than Material's defaults ---- */
.md-typeset .admonition,
.md-typeset details {
  border-radius: 4px;
  border-left-width: 3px;
  font-size: 0.92em;
  box-shadow: none;
}
.md-typeset .admonition.note,
.md-typeset details.note { border-left-color: var(--empn-blue); }
.md-typeset .admonition.warning,
.md-typeset details.warning { border-left-color: var(--empn-orange); }

/* ---- Tables: rules only, no zebra ---- */
.md-typeset table:not([class]) {
  border: none;
  font-size: 0.9em;
}
.md-typeset table:not([class]) th {
  background-color: transparent;
  color: var(--empn-navy);
  font-weight: 700;
  border-bottom: 2px solid var(--empn-navy);
}
.md-typeset table:not([class]) td {
  border-top: 1px solid var(--empn-rule);
}
.md-typeset table:not([class]) tr:hover {
  background-color: rgba(1, 110, 161, 0.04);
}

/* ---- Footer ---- */
.md-footer {
  background-color: var(--empn-navy);
}
.md-footer-meta {
  background-color: var(--empn-navy);
}

/* ---- Content max-width: keep reading lines short ---- */
.md-grid { max-width: 64rem; }

/* ---- Home-page hero block (default = cream) ---- */
.empn-hero {
  text-align: center;
  padding: 3rem 1.5rem 2.5rem;
  margin: -1rem -1rem 2.5rem;
  border-bottom: 1px solid var(--empn-rule);
}
.empn-hero .empn-hero-logo {
  display: block;
  margin: 0 auto 1.5rem;
  max-width: 260px;
  width: 60%;
  height: auto;
}
.empn-hero h1 {
  font-size: 2.4rem;
  line-height: 1.15;
  margin: 0 0 1rem;
  font-weight: 400;
  color: var(--empn-navy);
  font-family: "Freight Display Pro Book", "FreightDisplay", Georgia, serif;
  letter-spacing: -0.01em;
}
.empn-hero p {
  max-width: 42rem;
  margin: 0 auto 1rem;
  color: var(--empn-muted);
  font-size: 1.05rem;
  line-height: 1.55;
}

/* ---- Navy hero variant for the home page ---- */
.empn-hero.empn-hero--navy {
  background-color: var(--empn-navy);
  padding: 4.5rem 2rem 3.5rem;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-top: -1.5rem;
  margin-bottom: 3rem;
  width: 100vw;
  border-bottom: none;
  color: var(--empn-cream);
}
.empn-hero.empn-hero--navy h1 {
  color: var(--empn-cream);
  font-size: 3rem;
}
.empn-hero.empn-hero--navy p {
  color: rgba(255, 253, 248, 0.85);
  font-size: 1.15rem;
  max-width: 44rem;
}
.empn-hero.empn-hero--navy .empn-hero-logo {
  max-width: 200px;
}
.empn-hero .empn-hero-link {
  display: inline-block;
  margin-top: 0.5rem;
  color: var(--empn-orange);
  border-bottom: 1px solid rgba(255, 165, 0, 0.4);
  font-size: 0.95rem;
  letter-spacing: 0.02em;
}
.empn-hero .empn-hero-link:hover {
  border-bottom-color: var(--empn-orange);
}

/* ---- Doorway cards on the home page ---- */
.empn-doorways {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  margin: 0 0 3rem;
}
.empn-doorway {
  background-color: rgba(1, 110, 161, 0.04);
  border: 1px solid var(--empn-rule);
  border-radius: 6px;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
}
.empn-doorway h3 {
  margin: 0 0 0.5rem;
  font-size: 1.15rem;
  color: var(--empn-navy);
}
.empn-doorway p {
  flex-grow: 1;
  color: var(--empn-text);
  font-size: 0.95rem;
  margin-bottom: 1rem;
}
.empn-doorway .empn-doorway-cta {
  align-self: flex-start;
  font-weight: 700;
  color: var(--empn-blue);
  border-bottom: 1px solid rgba(1, 110, 161, 0.3);
}
.empn-doorway .empn-doorway-cta:hover {
  color: var(--empn-navy);
  border-bottom-color: var(--empn-orange);
}
@media (max-width: 800px) {
  .empn-doorways { grid-template-columns: 1fr; }
  .empn-hero.empn-hero--navy { margin: -1.5rem -1rem 2rem; }
}

/* Header lockup: small icon-only logo beside the site title */
.md-header__button.md-logo img,
.md-header__button.md-logo svg {
  height: 1.6rem;
  width: auto;
}

/* ---- Mermaid diagram colouring ---- */
.mermaid .node rect,
.mermaid .node circle,
.mermaid .node polygon {
  fill: var(--empn-cream) !important;
  stroke: var(--empn-navy) !important;
  stroke-width: 1.5px !important;
}
.mermaid .edgePath path {
  stroke: var(--empn-blue) !important;
  stroke-width: 1.5px !important;
}
.mermaid .node text {
  fill: var(--empn-navy) !important;
  font-family: "Söhne", Arial, sans-serif !important;
}
