/**
 * Dango Documentation - Custom Styles
 * Matching getdango.dev design system exactly
 *
 * Colors: Teal #14B8A6, Indigo #6366F1, Dark Teal #0D9488
 * Typography: Inter font with Tailwind-inspired scale
 * Note: Fonts are loaded via mkdocs.yml theme.font configuration
 */

:root {
  /* Brand colors from getdango.dev */
  --md-primary-fg-color: #14B8A6;
  --md-primary-fg-color--light: #5EEAD4;
  --md-primary-fg-color--dark: #0D9488;
  --md-accent-fg-color: #6366F1;

  /* Neutral grays */
  --md-default-fg-color: #495057;
  --md-default-fg-color--light: #6c757d;
  --md-default-fg-color--lighter: #adb5bd;
  --md-default-fg-color--lightest: #E9ECEF;
  --md-default-bg-color: #ffffff;
  --md-code-bg-color: #F8F9FA;

  /* Typography scale matching website (Tailwind values) */
  --md-text-font-family: 'Inter', system-ui, -apple-system, sans-serif;
  --md-code-font-family: 'JetBrains Mono', 'Courier New', monospace;

  /* Font sizes - documentation-optimized (smaller than marketing site) */
  --text-xs: 0.75rem;      /* 12px */
  --text-sm: 0.875rem;     /* 14px */
  --text-base: 0.9375rem;  /* 15px - slightly smaller for readability */
  --text-lg: 1.0625rem;    /* 17px */
  --text-xl: 1.125rem;     /* 18px */
  --text-2xl: 1.25rem;     /* 20px */
  --text-3xl: 1.5rem;      /* 24px */
  --text-4xl: 1.875rem;    /* 30px */
  --text-5xl: 2.25rem;     /* 36px */

  /* Line heights */
  --leading-tight: 1.25;
  --leading-normal: 1.5;
  --leading-relaxed: 1.625;

  /* Font weights */
  --font-normal: 400;
  --font-medium: 500;
  --font-semibold: 600;
  --font-bold: 700;

  /* Spacing (0.25rem base like website) */
  --spacing-unit: 0.25rem;
}

/* Ensure consistent font application */
body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-weight: 400;
}

/* All headings use semibold by default */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

/* Override MkDocs Material default colors */
[data-md-color-scheme="default"] {
  --md-primary-fg-color: #14B8A6;
  --md-accent-fg-color: #6366F1;
  --md-default-fg-color: #495057;
  --md-default-bg-color: #FFFFFF;
  --md-code-bg-color: #F8F9FA;
  --md-typeset-a-color: #14B8A6;
}

[data-md-color-scheme="slate"] {
  --md-primary-fg-color: #14B8A6;
  --md-accent-fg-color: #6366F1;
}

/* Typography - documentation-optimized (smaller than marketing site) */
.md-typeset {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--md-default-fg-color);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

.md-typeset h1 {
  font-size: var(--text-3xl);     /* 24px - smaller than marketing site */
  font-weight: var(--font-bold);
  line-height: var(--leading-tight);
  color: var(--md-default-fg-color);
  margin-top: 0;
  margin-bottom: calc(var(--spacing-unit) * 5);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

.md-typeset h2 {
  font-size: var(--text-2xl);     /* 20px - more appropriate for docs */
  font-weight: var(--font-semibold);
  line-height: var(--leading-tight);
  color: var(--md-default-fg-color);
  margin-top: calc(var(--spacing-unit) * 10);
  margin-bottom: calc(var(--spacing-unit) * 3);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

.md-typeset h3 {
  font-size: var(--text-xl);      /* 18px - cleaner for sections */
  font-weight: var(--font-semibold);
  line-height: var(--leading-normal);
  color: var(--md-primary-fg-color);
  margin-top: calc(var(--spacing-unit) * 8);
  margin-bottom: calc(var(--spacing-unit) * 2);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

.md-typeset h4 {
  font-size: var(--text-base);    /* 15px - subtle hierarchy */
  font-weight: var(--font-semibold);
  line-height: var(--leading-normal);
  color: var(--md-default-fg-color);
  margin-top: calc(var(--spacing-unit) * 6);
  margin-bottom: calc(var(--spacing-unit) * 2);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

.md-typeset p {
  font-size: var(--text-base);    /* 15px base text */
  line-height: var(--leading-relaxed);
  margin-bottom: calc(var(--spacing-unit) * 4);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

.md-typeset li {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

/* Buttons - rounded like website */
.md-button {
  border-radius: 0.5rem;
  font-weight: var(--font-medium);
  padding: calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 6);
}

.md-button--primary {
  background-color: var(--md-primary-fg-color);
  border-color: var(--md-primary-fg-color);
  color: white;
}

.md-button--primary:hover {
  background-color: var(--md-primary-fg-color--dark);
  border-color: var(--md-primary-fg-color--dark);
}

/* Code blocks - light gray background like website */
.md-typeset code {
  background-color: var(--md-code-bg-color);
  color: var(--md-default-fg-color);
  border-radius: 0.25rem;
  padding: 0.125rem 0.375rem;
  font-size: var(--text-sm);
  font-family: var(--md-code-font-family);
}

.md-typeset pre {
  background-color: var(--md-code-bg-color);
  border-radius: 0.5rem;
  border: 1px solid var(--md-default-fg-color--lightest);
}

.md-typeset pre code {
  background-color: transparent;
  font-size: var(--text-sm);
}

/* Admonitions - rounded corners */
.md-typeset .admonition,
.md-typeset details {
  border-radius: 0.5rem;
  border-left: 0.25rem solid var(--md-primary-fg-color);
}

/* Links */
.md-typeset a {
  color: var(--md-primary-fg-color);
  text-decoration: none;
  font-weight: var(--font-medium);
}

.md-typeset a:hover {
  color: var(--md-primary-fg-color--dark);
  text-decoration: underline;
}

/* Tables - clean styling */
.md-typeset table:not([class]) {
  border-radius: 0.5rem;
  overflow: hidden;
  font-size: var(--text-sm);
}

.md-typeset table:not([class]) th {
  background-color: var(--md-code-bg-color);
  font-weight: var(--font-semibold);
  color: var(--md-default-fg-color);
}

/* Navigation - teal active states */
.md-nav__link--active {
  color: var(--md-primary-fg-color);
  font-weight: var(--font-medium);
}

.md-nav__link:hover {
  color: var(--md-primary-fg-color--dark);
}

/* Lists - better spacing */
.md-typeset ul, .md-typeset ol {
  margin-bottom: calc(var(--spacing-unit) * 4);
}

.md-typeset li {
  margin-bottom: calc(var(--spacing-unit) * 2);
}

/* Tabbed content */
.md-typeset .tabbed-set {
  border-radius: 0.5rem;
  border: 1px solid var(--md-default-fg-color--lightest);
}

/* Content max-width for readability */
.md-content__inner {
  max-width: 48rem;
}

/* Header logo - ensure emoji renders properly */
.md-header__button.md-logo img,
.md-header__button.md-logo svg {
  height: 2rem;
  width: auto;
}

/* Responsive typography adjustments */
@media screen and (max-width: 76.1875em) {
  .md-typeset h1 {
    font-size: var(--text-2xl);  /* Even smaller on mobile */
  }

  .md-typeset h2 {
    font-size: var(--text-xl);
  }

  .md-typeset h3 {
    font-size: var(--text-base);
  }
}

/* Clean horizontal rules */
.md-typeset hr {
  border-top: 1px solid var(--md-default-fg-color--lightest);
  margin: calc(var(--spacing-unit) * 8) 0;
}
