/* =============================================================================
   EasyQuant Docs — Professional dark theme
   Default: dark mode with clean typography and polished search UI
   ============================================================================= */

/* ----- Global palette (dark = default) ----- */
:root {
  --eq-bg:        #0a0a0c;
  --eq-surface:   #141418;
  --eq-surface-2: #1c1c22;
  --eq-border:    #2a2a32;
  --eq-border-hover: #3a3a44;
  --eq-text:      #e8e8ed;
  --eq-text-2:    #909098;
  --eq-text-3:    #606068;
  --eq-accent:    #5b8def;
  --eq-accent-soft: rgba(91, 141, 239, 0.12);
  --eq-code-bg:   #111116;
  --eq-shadow:    0 8px 32px rgba(0, 0, 0, 0.45);
  --eq-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.3);
  --eq-radius:    0.625rem;
  --eq-radius-lg: 0.875rem;

  /* MkDocs variables */
  --md-default-bg-color: var(--eq-bg);
  --md-default-fg-color: var(--eq-text);
  --md-default-fg-color--light: var(--eq-text-2);
  --md-default-fg-color--lighter: var(--eq-text-3);
  --md-default-fg-color--lightest: var(--eq-surface-2);
  --md-primary-fg-color: var(--eq-bg);
  --md-primary-fg-color--light: var(--eq-surface);
  --md-primary-fg-color--dark: #000;
  --md-accent-fg-color: var(--eq-accent);
  --md-typeset-a-color: var(--eq-accent);
  --md-code-bg-color: var(--eq-code-bg);
  --md-code-fg-color: var(--eq-text);
  --md-footer-bg-color: var(--eq-bg);
  --md-footer-bg-color--dark: #050507;
}

/* Light mode overrides */
[data-md-color-scheme="default"] {
  --eq-bg:          #ffffff;
  --eq-surface:     #f5f5f7;
  --eq-surface-2:   #e8e8ed;
  --eq-border:      #e0e0e5;
  --eq-border-hover:#c8c8d0;
  --eq-text:        #1d1d23;
  --eq-text-2:      #6e6e76;
  --eq-text-3:      #909098;
  --eq-accent:      #3366cc;
  --eq-accent-soft: rgba(51, 102, 204, 0.08);
  --eq-code-bg:     #f0f0f4;
  --eq-shadow:      0 8px 32px rgba(0, 0, 0, 0.12);
  --eq-shadow-sm:   0 2px 8px rgba(0, 0, 0, 0.08);

  --md-default-bg-color: var(--eq-bg);
  --md-default-fg-color: var(--eq-text);
  --md-default-fg-color--light: var(--eq-text-2);
  --md-default-fg-color--lighter: var(--eq-text-3);
  --md-default-fg-color--lightest: var(--eq-surface-2);
  --md-primary-fg-color: var(--eq-bg);
  --md-primary-fg-color--light: var(--eq-surface);
  --md-primary-fg-color--dark: var(--eq-text);
  --md-accent-fg-color: var(--eq-accent);
  --md-typeset-a-color: var(--eq-accent);
  --md-code-bg-color: var(--eq-code-bg);
  --md-code-fg-color: var(--eq-text);
}

/* ============================================================================
   LAYOUT & BODY
   ============================================================================ */

body, .md-container, .md-main {
  background: var(--eq-bg) !important;
}

.md-grid {
  max-width: 72rem;
}

/* ============================================================================
   HEADER
   ============================================================================ */

.md-header {
  background: color-mix(in srgb, var(--eq-bg) 85%, transparent) !important;
  backdrop-filter: blur(12px) saturate(180%);
  -webkit-backdrop-filter: blur(12px) saturate(180%);
  border-bottom: 1px solid var(--eq-border);
  transition: background 0.2s;
}

.md-header__inner {
  background: transparent !important;
}

.md-header__title,
.md-header__topic {
  font-weight: 600;
  letter-spacing: -0.02em;
}

.md-header__button {
  opacity: 0.7;
  transition: opacity 0.15s;
}

.md-header__button:hover {
  opacity: 1;
}

/* ============================================================================
   TABS
   ============================================================================ */

.md-tabs {
  background: var(--eq-bg) !important;
  border-bottom: 1px solid var(--eq-border);
}

.md-tabs__link {
  font-weight: 500;
  font-size: 0.813rem;
  opacity: 0.65;
  transition: opacity 0.15s;
}

.md-tabs__link:hover {
  opacity: 1;
}

.md-tabs__item--active .md-tabs__link {
  opacity: 1;
  font-weight: 600;
}

/* ============================================================================
   SIDEBAR — LEFT (navigation)
   ============================================================================ */

.md-sidebar--primary .md-sidebar__scrollwrap {
  background: var(--eq-bg);
}

.md-nav__link {
  font-size: 0.813rem;
  color: var(--eq-text-2) !important;
  transition: color 0.15s;
}

.md-nav__link:hover {
  color: var(--eq-text) !important;
}

.md-nav__link--active {
  color: var(--eq-text) !important;
  font-weight: 600;
}

.md-nav__title {
  font-weight: 600;
  color: var(--eq-text) !important;
}

.md-nav__item--nested > .md-nav__link {
  font-weight: 400;
}

/* ============================================================================
   SIDEBAR — RIGHT (TOC)
   ============================================================================ */

.md-nav--secondary .md-nav__link {
  font-size: 0.75rem;
  color: var(--eq-text-3) !important;
}

.md-nav--secondary .md-nav__link:hover,
.md-nav--secondary .md-nav__link--active {
  color: var(--eq-text) !important;
}

/* ============================================================================
   TYPOGRAPHY
   ============================================================================ */

.md-typeset {
  font-size: 0.938rem;
  line-height: 1.75;
}

.md-typeset h1 {
  font-size: 2.25rem;
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.15;
  margin-bottom: 0.75rem;
}

.md-typeset h2 {
  font-size: 1.375rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  margin-top: 2.5rem;
  margin-bottom: 0.75rem;
  padding-bottom: 0;
  border-bottom: none;
}

.md-typeset h3 {
  font-size: 1.063rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin-top: 2rem;
  margin-bottom: 0.5rem;
}

.md-typeset a {
  color: var(--eq-accent);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s;
}

.md-typeset a:hover {
  border-bottom-color: var(--eq-accent);
}

/* ============================================================================
   CONTENT AREA
   ============================================================================ */

.md-content__inner {
  padding: 2.5rem 2.8rem 3.5rem;
}

@media (min-width: 60em) {
  .md-content__inner {
    padding: 2.5rem 3.2rem 3.5rem;
  }
}

/* ============================================================================
   CODE
   ============================================================================ */

.md-typeset code:not(pre > code) {
  background: var(--eq-code-bg);
  border: 1px solid var(--eq-border);
  border-radius: 0.25rem;
  padding: 0.08em 0.35em;
  font-size: 0.85em;
}

.md-typeset pre > code {
  border-radius: var(--eq-radius);
  border: 1px solid var(--eq-border);
  font-size: 0.813rem;
  line-height: 1.65;
  background: var(--eq-code-bg) !important;
}

/* ============================================================================
   TABLES
   ============================================================================ */

.md-typeset table:not([class]) {
  font-size: 0.875rem;
  border: 1px solid var(--eq-border);
  border-radius: var(--eq-radius);
  overflow: hidden;
}

.md-typeset table:not([class]) tr {
  border-bottom: 1px solid var(--eq-border);
}

.md-typeset table:not([class]) tr:last-child {
  border-bottom: none;
}

.md-typeset table:not([class]) td,
.md-typeset table:not([class]) th {
  padding: 0.75rem 1rem;
}

/* ============================================================================
   ADMONITIONS
   ============================================================================ */

.md-typeset .admonition,
.md-typeset details {
  border-radius: var(--eq-radius);
  border: 1px solid var(--eq-border) !important;
  background: var(--eq-surface) !important;
  box-shadow: none !important;
}

.md-typeset .admonition-title,
.md-typeset summary {
  font-weight: 600;
  background: transparent !important;
  border-bottom: 1px solid var(--eq-border);
}

/* ============================================================================
   HERO CARDS
   ============================================================================ */

.hero-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1px;
  margin: 2rem 0 2.5rem;
  background: var(--eq-border);
  border: 1px solid var(--eq-border);
  border-radius: var(--eq-radius-lg);
  overflow: hidden;
}

.hero-card {
  background: var(--eq-bg);
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  text-decoration: none;
  transition: background 0.2s;
  cursor: pointer;
}

.hero-card:hover {
  background: var(--eq-surface);
}

.hero-card h3 {
  font-size: 1.063rem;
  font-weight: 600;
  margin: 0;
  padding: 0;
  border: none;
  letter-spacing: -0.01em;
}

.hero-card p {
  font-size: 0.875rem;
  color: var(--eq-text-2);
  margin: 0;
  line-height: 1.6;
}

.hero-card code {
  background: var(--eq-code-bg);
  border: 1px solid var(--eq-border);
  border-radius: 0.2rem;
  padding: 0.05em 0.3em;
  font-size: 0.85em;
}

.hero-card > span.card-link {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--eq-accent);
  margin-top: auto;
  padding-top: 0.5rem;
}

/* ============================================================================
   SEARCH — FULL OVERHAUL
   ============================================================================ */

/* Search overlay (background dim) */
.md-search__overlay {
  background: rgba(0, 0, 0, 0.65);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

/* Search container (the white/light box) */
.md-search {
  position: relative;
}

/* Search input in header */
.md-search__form {
  background: var(--eq-surface) !important;
  border: 1px solid var(--eq-border);
  border-radius: var(--eq-radius);
  transition: border-color 0.2s, box-shadow 0.2s;
}

.md-search__form:hover {
  border-color: var(--eq-border-hover);
}

.md-search__form .md-search__icon {
  color: var(--eq-text-3);
}

.md-search__input {
  color: var(--eq-text) !important;
  font-size: 0.875rem;
}

.md-search__input::placeholder {
  color: var(--eq-text-3) !important;
}

/* Search output (the dropdown panel) */
.md-search__output {
  background: var(--eq-surface);
  border: 1px solid var(--eq-border);
  border-radius: var(--eq-radius);
  box-shadow: var(--eq-shadow);
  overflow: hidden;
}

/* Search result items */
.md-search-result__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.md-search-result__item {
  border-bottom: 1px solid var(--eq-border);
  transition: background 0.15s;
}

.md-search-result__item:last-child {
  border-bottom: none;
}

.md-search-result__item:hover,
.md-search-result__item:focus-within {
  background: var(--eq-accent-soft);
}

/* Search result link */
.md-search-result__link {
  padding: 0.875rem 1.25rem;
  display: block;
  text-decoration: none;
}

/* Search result title */
.md-search-result__title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--eq-text);
  line-height: 1.4;
  margin-bottom: 0.25rem;
}

/* Search result text (snippet) */
.md-search-result__teaser {
  font-size: 0.813rem;
  color: var(--eq-text-2);
  line-height: 1.5;
  max-height: 3.6em;
  overflow: hidden;
}

/* Highlighted match text */
.md-search-result__teaser mark {
  background: var(--eq-accent-soft);
  color: var(--eq-accent);
  border-radius: 2px;
  padding: 0.05em 0.2em;
  font-weight: 600;
}

.md-search-result__title mark {
  background: var(--eq-accent-soft);
  color: var(--eq-accent);
  border-radius: 2px;
  padding: 0.05em 0.2em;
}

/* "X results" header */
.md-search-result__meta {
  font-size: 0.75rem;
  color: var(--eq-text-3);
  padding: 0.75rem 1.25rem;
  background: var(--eq-surface-2);
  border-bottom: 1px solid var(--eq-border);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* "Show all" link */
.md-search-result__more {
  font-size: 0.813rem;
  color: var(--eq-accent);
}

/* Share / close buttons */
.md-search__share,
.md-search__close {
  color: var(--eq-text-2);
  opacity: 0.7;
  transition: opacity 0.15s;
}

.md-search__share:hover,
.md-search__close:hover {
  opacity: 1;
}

/* ============================================================================
   SCROLLBAR
   ============================================================================ */

::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: var(--eq-text-3);
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--eq-text-2);
}

/* ============================================================================
   MISC
   ============================================================================ */

.md-typeset hr {
  margin: 2.5rem 0;
  border-color: var(--eq-border);
}

.md-typeset blockquote {
  border-left: 3px solid var(--eq-text-3);
  background: var(--eq-surface);
  padding: 0.5rem 0 0.5rem 1rem;
  margin: 1.5rem 0;
  color: var(--eq-text-2);
  border-radius: 0 var(--eq-radius) var(--eq-radius) 0;
}

.md-typeset .md-button {
  border-radius: var(--eq-radius);
  font-size: 0.875rem;
  font-weight: 500;
  padding: 0.5rem 1.25rem;
}

.md-typeset .md-button--primary {
  background: var(--eq-accent);
  color: #fff;
  border: none;
}

::selection {
  background: rgba(91, 141, 239, 0.3);
}

.md-typeset .headerlink {
  opacity: 0;
  transition: opacity 0.15s;
  margin-left: 0.25em;
  color: var(--eq-text-3);
}

.md-typeset h1:hover .headerlink,
.md-typeset h2:hover .headerlink,
.md-typeset h3:hover .headerlink {
  opacity: 1;
}

.md-footer {
  background: var(--eq-bg) !important;
  border-top: 1px solid var(--eq-border);
  color: var(--eq-text-3);
}

.md-footer a {
  color: var(--eq-text-2);
}

/* Hide nav.path on home page */
.md-path__link {
  font-size: 0.75rem;
  color: var(--eq-text-3);
}
