/* =========================================================================
   SpeedPy brand theme for MkDocs Material.
   Ports the Docusaurus palette (src/css/custom.css) — indigo accent,
   dark-first surfaces — onto Material's CSS variables.
   ========================================================================= */

/* ---- Light scheme (indigo on white, Docusaurus-like) ---- */
[data-md-color-scheme="default"] {
  --md-primary-fg-color: #6366F1;
  --md-primary-fg-color--light: #818CF8;
  --md-primary-fg-color--dark: #4F46E5;
  --md-accent-fg-color: #4F46E5;
  --md-typeset-a-color: #4F46E5;
}

/* Keep a light header in light mode (logo reads on white). */
[data-md-color-scheme="default"] .md-header {
  background-color: #ffffff;
  color: #1c2536;
  border-bottom: 1px solid #e2e8f0;
}
[data-md-color-scheme="default"] .md-header .speedpy-header-nav__link {
  color: #1c2536;
}

/* ---- Dark scheme (the brand default) ---- */
[data-md-color-scheme="slate"] {
  --md-default-bg-color: #0e1320;
  --md-default-fg-color: #edf2f7;
  --md-default-fg-color--light: #a0aec0;
  --md-default-fg-color--lighter: #6b7689;
  --md-default-fg-color--lightest: #2a3346;

  /* header background = surface, not indigo */
  --md-primary-fg-color: #111927;
  --md-primary-bg-color: #edf2f7;

  --md-accent-fg-color: #a5b4fc;
  --md-typeset-a-color: #818cf8;

  --md-code-bg-color: #1c2536;
  --md-code-fg-color: #edf2f7;

  --md-footer-bg-color: #111927;
  --md-footer-bg-color--dark: #111927;
}

/* Sidebar surface tint (Docusaurus used #111927 for the menu). */
[data-md-color-scheme="slate"] .md-nav--primary .md-nav__title {
  background-color: #111927;
}
[data-md-color-scheme="slate"] .md-nav__link--active,
[data-md-color-scheme="slate"] .md-nav__item--active > .md-nav__link {
  color: #edf2f7;
}

/* Code blocks: subtle border like the Docusaurus dark theme. */
[data-md-color-scheme="slate"] .md-typeset pre > code,
[data-md-color-scheme="slate"] .md-typeset .highlight {
  border: 1px solid #253047;
  border-radius: 6px;
}

/* Tables */
[data-md-color-scheme="slate"] .md-typeset table:not([class]) th {
  background-color: #1c2536;
}
[data-md-color-scheme="slate"] .md-typeset table:not([class]) td,
[data-md-color-scheme="slate"] .md-typeset table:not([class]) th {
  border-color: #253047;
}

/* =========================================================================
   Header: right-aligned nav links (SpeedPy.com / Discord / GitHub)
   ========================================================================= */
.speedpy-header-nav {
  display: flex;
  align-items: center;
  gap: 1.1rem;
  margin-right: 0.4rem;
}
.speedpy-header-nav__link {
  color: var(--md-primary-bg-color);
  font-size: 0.72rem;
  font-weight: 500;
  text-decoration: none;
  opacity: 0.85;
  white-space: nowrap;
  transition: opacity 0.2s;
}
.speedpy-header-nav__link:hover {
  opacity: 1;
}
/* "Start Free" CTA button (gradient, ported from the Docusaurus navbar). */
.speedpy-header-nav__cta {
  background: linear-gradient(135deg, #7c3aed 0%, #4f46e5 100%);
  color: #ffffff;
  opacity: 1;
  padding: 0.34rem 0.85rem;
  border-radius: 6px;
  font-weight: 600;
}
.speedpy-header-nav__cta:hover {
  filter: brightness(1.08);
}
@media screen and (max-width: 76.1875em) {
  .speedpy-header-nav {
    display: none;
  }
}

/* =========================================================================
   Card grid (replaces the Docusaurus <CardGrid> component on the home page).
   Uses Material's native `.grid.cards`, restyled to match.
   ========================================================================= */
.md-typeset .grid.cards > ul > li,
.md-typeset .grid.cards > .card {
  border: 1px solid var(--md-default-fg-color--lightest);
  border-radius: 8px;
  padding: 0.9rem 1.1rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.md-typeset .grid.cards > ul > li:hover {
  border-color: var(--md-typeset-a-color);
  box-shadow: 0 0 0 1px var(--md-typeset-a-color);
}
.md-typeset .grid.cards > ul > li > p {
  margin: 0;
}
/* Card text reads like Docusaurus: white/bold title, muted description —
   not the indigo link colour Material applies to link text by default. */
.md-typeset .grid.cards a,
.md-typeset .grid.cards a:hover {
  color: var(--md-default-fg-color--light);
}
.md-typeset .grid.cards a strong {
  color: var(--md-default-fg-color);
  font-weight: 600;
}
.md-typeset .grid.cards a .twemoji,
.md-typeset .grid.cards a .twemoji svg,
.md-typeset .grid.cards a .md-icon {
  color: var(--md-default-fg-color);
}

/* =========================================================================
   Headings: bold like Docusaurus (Material defaults h1 to a thin weight).
   ========================================================================= */
.md-typeset h1 {
  font-weight: 700;
  color: var(--md-default-fg-color);
}

/* =========================================================================
   Footer: 3-column link section (Docusaurus-style) above the meta row.
   ========================================================================= */
.speedpy-footer-links {
  background-color: #111927;
}
.speedpy-footer-links__inner {
  display: flex;
  flex-wrap: wrap;
  gap: 3rem;
  padding: 2.2rem 0.8rem 1.4rem;
}
.speedpy-footer-col__title {
  color: #edf2f7;
  font-weight: 700;
  font-size: 0.8rem;
  margin-bottom: 0.7rem;
}
.speedpy-footer-col a {
  display: block;
  color: #a0aec0;
  font-size: 0.72rem;
  line-height: 1.95;
  text-decoration: none;
}
.speedpy-footer-col a:hover {
  color: #edf2f7;
}

/* =========================================================================
   Right-sidebar CTA card (below the TOC) — "Start with Appliku".
   ========================================================================= */
/* toc.html is also included in the mobile nav drawer; only show the card in
   the right-hand secondary sidebar. */
.appliku-cta {
  display: none;
}
.md-sidebar--secondary .appliku-cta {
  display: block;
  margin-top: 1.6rem;
  padding: 1rem 1rem 1.1rem;
  border-radius: 10px;
  border: 1px solid rgba(99, 102, 241, 0.35);
  background: linear-gradient(180deg, rgba(99, 102, 241, 0.16), rgba(99, 102, 241, 0.08));
}
.appliku-cta__eyebrow {
  margin: 0 0 0.3rem;
  font-size: 0.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--md-typeset-a-color);
}
.appliku-cta__title {
  margin: 0 0 0.4rem;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--md-default-fg-color);
}
.appliku-cta__copy {
  margin: 0 0 0.8rem;
  font-size: 0.68rem;
  line-height: 1.4;
  color: var(--md-default-fg-color--light);
}
.appliku-cta__button {
  display: block;
  text-align: center;
  padding: 0.45rem 0.8rem;
  border-radius: 6px;
  font-size: 0.72rem;
  font-weight: 600;
  text-decoration: none;
  color: #ffffff;
  background: linear-gradient(135deg, #7c3aed 0%, #4f46e5 100%);
}
.appliku-cta__button:hover {
  filter: brightness(1.08);
}
.appliku-cta__secondary {
  display: block;
  text-align: center;
  margin-top: 0.5rem;
  font-size: 0.7rem;
  text-decoration: none;
  color: var(--md-default-fg-color);
}
.appliku-cta__secondary:hover {
  color: var(--md-typeset-a-color);
}

/* =========================================================================
   Admonitions: Docusaurus renders `note` in neutral gray (Material defaults
   it to blue). Re-tint note to match; other types already align closely.
   ========================================================================= */
.md-typeset .admonition.note,
.md-typeset details.note {
  border-color: #6b7689;
}
.md-typeset .note > .admonition-title,
.md-typeset .note > summary {
  background-color: rgba(160, 174, 192, 0.12);
}
.md-typeset .note > .admonition-title::before,
.md-typeset .note > summary::before {
  background-color: #a0aec0;
}
