/* extra.css — "Friendly App Docs" für Material for MkDocs */

@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined');

/* ------------------------------
   1) Grund-Design-Variablen
   ------------------------------ */

/* Light Theme */
:root,
[data-md-color-scheme="default"] {
  --app-radius: 14px;
  --app-radius-sm: 10px;
  --app-shadow: 0 8px 24px rgba(2, 24, 43, 0.08);
  --app-shadow-sm: 0 4px 14px rgba(2, 24, 43, 0.06);
  --app-focus: 0 0 0 3px rgba(56, 120, 255, 0.25);

  /* Sanfte, freundliche Farben mit guter Lesbarkeit */
  --md-primary-fg-color: #3a7afe;             /* Primär (Links, Buttons) */
  --md-primary-fg-color--light: #6ea1ff;
  --md-primary-fg-color--dark: #2757c7;

  --md-accent-fg-color: #ff6b6b;              /* Akzent (Badge, Hover) */
  --md-default-fg-color: #1b2430;             /* Text */
  --md-default-fg-color--light: #3b485a;
  --md-default-bg-color: #ffffff;             /* Fläche */
  --md-code-bg-color: #f6f8fc;                /* Code-Boxen weicher */
  --md-code-fg-color: #1f2d3d;

  --card-bg: #ffffff;
  --card-border: #eef1f7;
  --card-hero: linear-gradient(180deg, #f7faff 0%, #ffffff 100%);
  --chip-bg: #eef3ff;
  --chip-fg: #234;
}

/* Dark Theme */
[data-md-color-scheme="slate"] {
  --app-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
  --app-shadow-sm: 0 4px 14px rgba(0, 0, 0, 0.35);

  --md-primary-fg-color: #7ba6ff;
  --md-primary-fg-color--light: #a6c2ff;
  --md-primary-fg-color--dark: #4e79ff;

  --md-default-fg-color: #e7ecf5;
  --md-default-fg-color--light: #b8c3d9;
  --md-default-bg-color: #0f1420;
  --md-code-bg-color: #141b2b;
  --md-code-fg-color: #e8edf7;

  --card-bg: #141b2b;
  --card-border: #202a40;
  --card-hero: linear-gradient(180deg, #17223a 0%, #101727 100%);
  --chip-bg: #1a2440;
  --chip-fg: #d8e3ff;
}

/* Etwas großzügigere Typografie */
:root {
  --md-text-font-size: 0.98rem;  /* Basis leicht hoch */
}
.md-typeset {
  font-size: var(--md-text-font-size);
  line-height: 1.7;
}

/* ------------------------------
   2) Seitenrahmen & Layout
   ------------------------------ */

/* Hauptinhalt als "Card" wirken lassen */
.md-main__inner {
  padding-top: 1.0rem;
}
.md-content {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--app-radius);
  box-shadow: var(--app-shadow);
  padding: 1.2rem 1.4rem;
}

/* Sticky Inhaltsverzeichnis leicht abheben */
.md-nav--secondary {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--app-radius);
  box-shadow: var(--app-shadow-sm);
  padding: .6rem .6rem;
}

/* Header-Brand größer & freundlicher */
.md-header__brand .md-logo {
  border-radius: 10px;
  overflow: hidden;
  box-shadow: var(--app-shadow-sm);
}

/* Tabs moderner */
.md-tabs {
  border-bottom: 1px solid var(--card-border);
}
.md-tabs__link {
  border-radius: 999px;
  padding: .35rem .9rem;
}
.md-tabs__link--active,
.md-tabs__link:focus-visible {
  background: var(--chip-bg);
  color: var(--md-primary-fg-color);
}

/* ------------------------------
   3) Überschriften & Absätze
   ------------------------------ */

.md-typeset h1,
.md-typeset h2,
.md-typeset h3 {
  letter-spacing: .2px;
}
.md-typeset h1 {
  font-size: 2rem;
  background: var(--card-hero);
  padding: 1.0rem 1.1rem;
  border-radius: var(--app-radius);
  border: 1px solid var(--card-border);
  box-shadow: var(--app-shadow-sm);
}
.md-typeset h2 {
  margin-top: 2.0rem;
  padding-top: .2rem;
  border-bottom: 0;
}
.md-typeset p {
  margin: .85rem 0 1.05rem;
}

/* ------------------------------
   4) Links, Buttons, Badges
   ------------------------------ */

/* Links klarer & mit weichem Hover */
.md-typeset a {
  color: var(--md-primary-fg-color);
  text-decoration: none;
  border-bottom: 1px dashed rgba(58,122,254,.35);
  transition: all .15s ease;
}
.md-typeset a:hover {
  color: var(--md-primary-fg-color--dark);
  border-bottom-color: transparent;
}

/* Primäre Aktionsbuttons */
.md-typeset .md-button {
  border-radius: 999px;
  padding: .55rem 1rem;
  box-shadow: var(--app-shadow-sm);
  border: 1px solid var(--card-border);
}
.md-typeset .md-button--primary {
  background: var(--md-primary-fg-color);
  color: #fff;
  border: none;
}
.md-typeset .md-button--primary:hover {
  filter: brightness(1.05);
  transform: translateY(-1px);
}

/* „Chips“ für kleine Hinweise */
.chip {
  display: inline-block;
  padding: .25rem .6rem;
  border-radius: 999px;
  background: var(--chip-bg);
  color: var(--chip-fg);
  font-weight: 600;
  font-size: .78rem;
  margin: 0 .35rem .35rem 0;
}

/* ------------------------------
   5) Karten, Bilder, Tabellen
   ------------------------------ */

/* Generische Card */
.card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: var(--app-radius);
  box-shadow: var(--app-shadow);
  padding: 1rem 1.1rem;
  margin: 1rem 0;
}

/* Bilder mit sanfter Rundung & Schatten */
.md-typeset img,
.md-typeset .mdx-figure > img {
  border-radius: var(--app-radius-sm);
  box-shadow: var(--app-shadow-sm);
}

/* Tabellen freundlicher */
.md-typeset table:not([class]) {
  border-radius: var(--app-radius);
  overflow: hidden;
  border: 1px solid var(--card-border);
  box-shadow: var(--app-shadow-sm);
}
.md-typeset table:not([class]) thead th {
  background: var(--chip-bg);
  color: var(--md-primary-fg-color--dark);
  font-weight: 700;
}

/* ------------------------------
   6) Code-Blöcke (weniger „techy“)
   ------------------------------ */

.md-typeset code {
  background: rgba(58,122,254,0.08);
  border-radius: 8px;
  padding: .08rem .35rem;
  border: 1px solid rgba(58,122,254,0.15);
}

/* Block */
.md-typeset pre > code {
  background: var(--md-code-bg-color);
  color: var(--md-code-fg-color);
  border-radius: var(--app-radius);
  box-shadow: var(--app-shadow-sm);
  border: 1px solid var(--card-border);
  padding: 1rem 1rem;
}

/* Copy-Button auffälliger */
.highlight .md-clipboard {
  border-radius: 8px;
  box-shadow: var(--app-shadow-sm);
}

/* ------------------------------
   7) Admonitions (Hinweise)
   ------------------------------ */

.md-typeset .admonition,
.md-typeset details {
  border-radius: var(--app-radius);
  border: 1px solid var(--card-border);
  box-shadow: var(--app-shadow-sm);
}
.md-typeset .admonition-title {
  font-weight: 700;
}
.md-typeset .admonition.note   { border-left: 6px solid #3a7afe; }
.md-typeset .admonition.tip    { border-left: 6px solid #00c48c; }
.md-typeset .admonition.info   { border-left: 6px solid #7ba6ff; }
.md-typeset .admonition.warning{ border-left: 6px solid #ffb020; }
.md-typeset .admonition.danger { border-left: 6px solid #ff6b6b; }

/* ------------------------------
   8) Suche & Inputs
   ------------------------------ */

.md-search__form {
  border-radius: 999px;
  box-shadow: var(--app-shadow-sm);
  border: 1px solid var(--card-border);
}
.md-search__input {
  border-radius: 999px;
  padding: .55rem .9rem;
}
.md-search__input:focus {
  outline: none;
  box-shadow: var(--app-focus);
}

/* Autocomplete-Einträge */
.md-search-result__list {
  border-radius: var(--app-radius);
  overflow: hidden;
}

/* ------------------------------
   9) Navigation und Sidebar
   ------------------------------ */

.md-nav__title,
.md-nav__link {
  border-radius: 8px;
}
.md-nav__link--active,
.md-nav__link:hover {
  background: var(--chip-bg);
  color: var(--md-primary-fg-color--dark);
}

/* Footer kompakter & dezenter */
.md-footer-meta,
.md-footer {
  border-top: 1px solid var(--card-border);
  opacity: .95;
}

/* ------------------------------
   10) Kleinzeug & A11y
   ------------------------------ */

:focus-visible {
  outline: none;
  box-shadow: var(--app-focus) !important;
  border-radius: 8px;
}

/* Abstand zwischen Elementen harmonisieren */
.md-typeset ul > li { margin: .35rem 0; }
.md-typeset .tabbed-set { border-radius: var(--app-radius); box-shadow: var(--app-shadow-sm); }

/* Optional: zarter Glow für aktive Links im Text */
.md-typeset a:focus-visible,
.md-typeset a:active {
  text-shadow: 0 0 0 rgba(0,0,0,0); /* reset */
  box-shadow: 0 0 0 3px rgba(58,122,254,.18);
  border-radius: 6px;
}

.material-symbols-outlined {
  font-family: 'Material Symbols Outlined';
  font-weight: normal;
  font-style: normal;
  font-size: 24px;  /* beliebig */
  display: inline-block;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  direction: ltr;
}