/*
 * BARGS Theme - Colors extracted from logo.png
 * Features: bloodshot-eyed lowercase "b" vomiting CLI arguments
 */

/*
 * Define colors based on logo palette
 */

:root {
  /* BARGS Brand Colors - Extracted from logo.png */
  --bargs-lime: #9bbf30; /* Main hexagon background */
  --bargs-lime-light: #b8d454; /* Lighter lime variant */
  --bargs-lime-dark: #7a9926; /* Darker lime for contrast */
  --bargs-lime-muted: #8aad2b; /* Muted lime */

  --bargs-black: #1a1a1a; /* Logo border */
  --bargs-black-pure: #000000;
  --bargs-white: #ffffff; /* Text and "b" character */
  --bargs-white-off: #f4f4f4;

  --bargs-red: #e02020; /* Bloodshot eyes, tongue */
  --bargs-red-light: #ff4444;
  --bargs-red-dark: #b01818;

  --bargs-green-accent: #2e8b4c; /* Spiral eye pupils */
  --bargs-green-accent-light: #3da85e;

  /* Letter spray colors */
  --bargs-cyan: #5bcbf0;
  --bargs-cyan-dark: #3db5dc;
  --bargs-purple: #9b59b6;
  --bargs-purple-light: #b67dd0;
  --bargs-yellow: #f1c40f;
  --bargs-yellow-light: #f5d442;

  /* Grays derived from logo */
  --bargs-gray-dark: #333333;
  --bargs-gray-medium: #666666;
  --bargs-gray-light: #999999;
  --bargs-gray-lighter: #cccccc;
  --bargs-gray-lightest: #e8e8e8;

  /* Light theme - BARGS lime-forward */
  --light-color-background: var(--bargs-white);
  --light-color-background-secondary: #f0f5e6; /* Lime-tinted white */
  --light-color-background-navbar: #f8faf4;
  --light-color-background-overlay: rgba(154, 191, 48, 0.3);

  --light-color-accent: var(--bargs-lime-muted);

  --light-color-text: var(--bargs-black);
  --light-color-text-aside: var(--bargs-gray-dark);

  --light-color-link: var(--bargs-green-accent);

  --light-color-warning-border: #fff0cc;
  --light-color-background-warning: #fffbe6;

  --light-color-alert-note: var(--bargs-cyan-dark);
  --light-color-alert-tip: var(--bargs-green-accent);
  --light-color-alert-important: var(--bargs-purple);
  --light-color-alert-warning: var(--bargs-yellow);
  --light-color-alert-caution: var(--bargs-red);

  /* Dark theme - Letter-spray chaos energy */
  --dark-color-background: #0d0d0d;
  --dark-color-background-secondary: #1a1a1a;
  --dark-color-background-navbar: var(--bargs-black-pure);
  --dark-color-background-overlay: rgba(91, 203, 240, 0.2);

  --dark-color-accent: var(--bargs-lime-dark);

  --dark-color-text: var(--bargs-white-off);
  --dark-color-text-aside: var(--bargs-gray-light);

  --dark-color-link: var(--bargs-cyan);

  --dark-color-warning-border: #4a3a00;
  --dark-color-background-warning: #2a2200;

  --dark-color-alert-note: var(--bargs-cyan);
  --dark-color-alert-tip: var(--bargs-lime-light);
  --dark-color-alert-important: var(--bargs-purple-light);
  --dark-color-alert-warning: var(--bargs-yellow);
  --dark-color-alert-caution: var(--bargs-red-light);

  /* Shared */
  --color-warning-text: var(--color-text);
  --color-contrast-text: var(--color-text);
  --color-icon-background: var(--color-background);
  --color-focus-outline: var(--bargs-lime);

  --light-icon-npm: url('media/mark-npm-24.svg');
  --dark-icon-npm: url('media/mark-npm-inverse-24.svg');
  --light-icon-github: url('media/mark-github-24.svg');
  --dark-icon-github: url('media/mark-github-inverse-24.svg');
}

@media (prefers-color-scheme: light) {
  :root {
    --color-background-navbar: var(--light-color-background-navbar);
    --color-background-overlay: var(--light-color-background-overlay);
    --color-warning-border: var(--light-color-warning-border);
    --icon-github: var(--light-icon-github);
    --icon-npm: var(--light-icon-npm);
  }
}

@media (prefers-color-scheme: dark) {
  :root {
    --color-background-navbar: var(--dark-color-background-navbar);
    --color-background-overlay: var(--dark-color-background-overlay);
    --color-warning-border: var(--dark-color-warning-border);
    --icon-github: var(--dark-icon-github);
    --icon-npm: var(--dark-icon-npm);
  }
}

:root[data-theme='light'] {
  --color-background-navbar: var(--light-color-background-navbar);
  --color-background-overlay: var(--light-color-background-overlay);
  --color-warning-border: var(--light-color-warning-border);
  --icon-github: var(--light-icon-github);
  --icon-npm: var(--light-icon-npm);
}

:root[data-theme='dark'] {
  --color-background-navbar: var(--dark-color-background-navbar);
  --color-background-overlay: var(--dark-color-background-overlay);
  --color-warning-border: var(--dark-color-warning-border);
  --icon-github: var(--dark-icon-github);
  --icon-npm: var(--dark-icon-npm);
}

/*
 * Define fonts - using system fonts only
 */

:root {
  --font-family-text:
    -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Noto Sans', Helvetica,
    Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji';
  --font-family-code:
    ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, Liberation Mono,
    monospace;
}

body {
  font-family: var(--font-family-text);
}

/*
 * Links
 */

.tsd-accordion-details a,
.tsd-accordion a,
.tsd-page-toolbar a.title {
  color: var(--color-text);
  text-decoration: none;
}

.tsd-accordion-details a:hover,
.tsd-page-toolbar a.title:hover,
.tsd-accordion a:hover,
.tsd-anchor-icon {
  color: var(--bargs-lime);
}

.tsd-kind-class {
  color: var(--color-link);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.tsd-index-link,
.tsd-page-navigation a:hover {
  text-decoration: none;
}

.tsd-index-link:hover {
  text-decoration: underline;
  text-underline-offset: 3px;
  color: var(--bargs-lime);
}

a code,
.tsd-sources a,
.tsd-page-navigation a:hover {
  color: var(--color-link);
}

a.external[target='_blank'] {
  background-image: none;
  padding-right: 0px;
}

/*
 * Tables
 */

table {
  margin: 1em 0;
}

.tsd-typography th,
.tsd-typography td {
  padding: 8px;
  text-align: left;
}

.tsd-typography th {
  background-color: var(--color-background);
  color: var(--color-text);
}

.tsd-typography tr:nth-child(2n) {
  background-color: var(--color-background-code);
}

/*
 * Horizontal line
 */

.tsd-typography hr {
  color: var(--color-accent);
}

/*
 * Buttons
 */

button {
  background-color: var(--color-background-navbar);
  color: var(--color-text);
  border: 1px solid var(--color-accent);
  border-radius: 6px;
  padding: 8px 16px;
  cursor: pointer;
  transition: all 0.2s ease-in-out;
}

button:hover {
  background-color: var(--bargs-lime);
  color: var(--bargs-black);
  border-color: var(--bargs-lime);
}

pre > button {
  background-color: transparent;
  transition: all 0.2s ease-in-out;
  border: none;
  opacity: 1;
  top: 8px;
  padding: 4px 8px;
}

pre > button:hover {
  background-color: var(--bargs-lime);
  color: var(--bargs-black);
}

/*
 * Checkbox
 */

.tsd-filter-input input[type='checkbox'],
.tsd-filter-input svg {
  width: 1em;
  height: 1em;
}

.tsd-filter-input svg {
  border-radius: 2px;
}

.tsd-checkbox-background {
  fill: var(--color-background);
  stroke: var(--color-accent);
  stroke-width: 6px;
}

input[type='checkbox']:checked ~ svg .tsd-checkbox-background {
  fill: var(--bargs-lime);
}

.tsd-checkbox-checkmark {
  color: var(--bargs-black);
}

/*
 * Select
 */

select {
  background-color: var(--color-background);
  border: 1px solid var(--color-accent);
  border-radius: 6px;
  padding: 8px;
  font-family: inherit;
}

/*
 * Code blocks
 */

code,
pre {
  border: none;
  border-radius: 6px;
  margin: 1em 0;
  background-color: var(--color-background-secondary);
  color: var(--color-text);
  font-family: var(--font-family-code);
}

code.tsd-tag {
  background-color: var(--color-accent);
  border: unset;
  margin: 0 0.25em;
  font-weight: 500;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/*
 * Warnings
 */

.warning {
  border-style: solid;
  border-width: 1px;
  border-color: var(--color-warning-border);
  border-radius: 6px;
}

/*
 * Topbar
 */

.tsd-page-toolbar {
  background-color: var(--color-background-navbar);
  border-bottom-color: var(--color-accent);
}

.tsd-toolbar-contents a.title:hover {
  color: var(--color-text);
}

/*
 * Search
 */

#tsd-search-trigger {
  width: unset;
  border: unset;
  background-color: unset;
  transition: opacity 0.15s ease-in-out;
}

#tsd-search-trigger:hover {
  opacity: 1;
}

#tsd-search-input,
#tsd-search-input:focus-visible {
  background-color: transparent;
  border: 1px solid var(--color-focus-outline);
}

#tsd-search-status:not(:empty) {
  min-height: unset;
  padding-top: 1.5rem;
  padding-bottom: 0.5rem;
}

#tsd-search-results > li:is(:hover, [aria-selected='true']) {
  background-color: color-mix(in srgb, var(--color-text-aside), #0000 88%);
}

#tsd-search-results > li > a:hover {
  text-decoration: unset;
}

#tsd-overlay {
  background-color: var(--color-background-overlay);
}

/*
 * Baseboard
 */

footer {
  border-top-color: var(--color-accent);
}

/*
 * Side navigations
 */

.site-menu {
  padding: 1rem 0;
}

.tsd-navigation a {
  color: var(--color-text);
  border-radius: 6px;
  padding: 6px;
}

.tsd-navigation a,
.tsd-navigation a:hover {
  text-decoration: none;
}

.tsd-navigation a:hover:not(.current) {
  background-color: color-mix(in srgb, var(--color-text-aside), #0000 88%);
}

.tsd-navigation a.current {
  background-color: color-mix(in srgb, var(--color-text-aside), #0000 92%);
}

/*
 * Type definition groups
 */

.tsd-index-panel,
.tsd-member-group {
  background-color: var(--color-background);
  padding: 16px;
  border: 1px var(--color-accent) solid;
  border-radius: 6px;
}

.tsd-panel > h1,
.tsd-panel > h2,
.tsd-panel > h3 {
  margin-top: 0px;
}

/*
 * Header typography
 */
h1,
h2,
h3,
h4,
h5,
h6,
.tsd-panel > h1,
.tsd-panel > h2,
.tsd-panel > h3,
.tsd-accordion-summary > h3 {
  font-weight: 600;
}

.tsd-typography h4 {
  font-size: 1.1em;
}

.tsd-panel-group.tsd-index-group details {
  margin: 0px;
}

.tsd-member-group .tsd-member:last-child {
  margin-bottom: 0px;
}

.tsd-signature {
  border: 1px solid var(--color-accent);
  border-radius: 6px;
}

.tsd-signatures .tsd-signature {
  border-color: var(--color-accent);
  border-radius: 0px;
}

.tsd-description .tsd-signatures .tsd-signature {
  border-radius: 6px;
}

.tsd-full-hierarchy:not(:last-child) {
  border-bottom: var(--color-accent);
}

/*
 * Footer
 */

footer p {
  font-size: 1rem;
  text-align: center;
  color: var(--color-text-aside);
}

/*
 * Fix collapsed margin
 */

.tsd-accordion-summary > h3 {
  margin-top: 0px;
  margin-bottom: 0px;
}

.tsd-page-navigation:not([open]) > .tsd-accordion-summary {
  margin-bottom: 0px;
}

/*
 * Fix collapse arrows position
 */

.tsd-accordion-summary svg {
  transition: transform 0.1s ease-in-out;
  margin-top: auto;
  margin-bottom: auto;
}

/*
 * BARGS brand styling
 */

span.bargs {
  /* text-transform: uppercase; */
  letter-spacing: 0.04em;
  font-weight: bold;
  font-size: 1.1em;
}

h2 span.bargs {
  font-weight: bold;
  font-size: 1.1em;
}

p span.bargs {
  font-weight: bold;
}

/*
 * Main title typography
 */

body > header > div > a.title {
  font-weight: 900;
  /* text-transform: uppercase; */
  letter-spacing: 0.04em;
  font-size: 1.875rem;
}

/*
 * Hide main page title when content is "bargs"
 */

body
  > div.container.container-main
  > div.col-content
  > div.tsd-page-title
  > h1:only-child {
  display: none;
}

/*
 * Monospace font for code-related sidebar items
 */

a:has(svg[aria-label='Module']) span,
a:has(svg[aria-label='Reference']) span,
a:has(svg[aria-label='Function']) span,
a:has(svg[aria-label='Type Alias']) span,
a:has(svg[aria-label='Interface']) span,
a:has(svg[aria-label='Namespace']) span,
a:has(svg[aria-label='Class']) span,
a:has(svg[aria-label='Variable']) span {
  font-family: var(--font-family-code);
}

nav:nth-child(2) > a {
  font-weight: 900;
  /* text-transform: uppercase; */
  letter-spacing: 0.04em;
  font-size: 1.2em;
}

.tsd-kind-class,
.tsd-kind-function,
.tsd-kind-interface,
.tsd-kind-namespace,
.tsd-kind-parameter,
.tsd-kind-property,
.tsd-kind-type-alias,
.tsd-kind-type-parameter,
.tsd-kind-variable,
.tsd-member-summary-name,
.tsd-signature-keyword,
.tsd-signature-symbol,
.tsd-signature-type,
.tsd-type-kind-parameter,
span:has(.tsd-kind-parameter) {
  font-family: var(--font-family-code) !important;
}

:is(p, li)
  > a:is(
    .tsd-parameters,
    .tsd-kind-class,
    .tsd-kind-function,
    .tsd-kind-interface,
    .tsd-kind-namespace,
    .tsd-kind-parameter,
    .tsd-kind-property,
    .tsd-kind-type-alias,
    .tsd-kind-type-parameter,
    .tsd-kind-variable,
    .tsd-signature-keyword,
    .tsd-signature-symbol,
    .tsd-signature-type,
    .tsd-type-kind-parameter
  ) {
  font-size: 0.9em;
}

code.tsd-tag {
  border: 1px solid var(--bargs-lime);
  border-radius: 6px;
}

/* Light mode - tsd-tag styling */
@media (prefers-color-scheme: light) {
  code.tsd-tag {
    background-color: var(--bargs-white);
    color: var(--bargs-black);
  }
}

/* Dark mode - tsd-tag styling */
@media (prefers-color-scheme: dark) {
  code.tsd-tag {
    background-color: var(--bargs-black);
    color: var(--bargs-white);
  }
}

/* Explicit theme overrides for tsd-tag */
:root[data-theme='light'] code.tsd-tag {
  background-color: var(--bargs-white);
  color: var(--bargs-black);
}

:root[data-theme='dark'] code.tsd-tag {
  background-color: var(--bargs-black);
  color: var(--bargs-white);
}

/*
 * Lime border utility classes
 */

.bargs-lime-border {
  border: 1px solid var(--bargs-lime);
  border-radius: 6px;
}

/* Light mode - white background */
@media (prefers-color-scheme: light) {
  .bargs-lime-border {
    background-color: var(--bargs-white);
    color: var(--bargs-black);
  }
}

/* Dark mode - black background */
@media (prefers-color-scheme: dark) {
  .bargs-lime-border {
    background-color: var(--bargs-black);
    color: var(--bargs-white);
  }
}

/* Explicit theme overrides */
:root[data-theme='light'] .bargs-lime-border {
  background-color: var(--bargs-white);
  color: var(--bargs-black);
}

:root[data-theme='dark'] .bargs-lime-border {
  background-color: var(--bargs-black);
  color: var(--bargs-white);
}

/*
 * Theme-aware icons
 */

.icon-github {
  display: inline-block;
  width: 24px;
  height: 24px;
  background-image: var(--icon-github);
  background-size: contain;
  background-repeat: no-repeat;
}

.icon-npm {
  display: inline-block;
  width: 24px;
  height: 24px;
  background-image: var(--icon-npm);
  background-size: contain;
  background-repeat: no-repeat;
}

.tsd-typography
  code:not(.typescript):not(.ts):not(.sh):not(.js):not(.javascript):not(.shell),
:is(h1, h2, h3, h4, h5, h6) .code {
  padding: 0;
  font-size: 0.9em;
}

.tsd-typography > h2 {
  margin-top: 3rem;
}
.tsd-typography > h2:first-child {
  margin-top: 0;
}
.tsd-typography > h3 {
  margin-top: 2rem;
}

.tsd-typography ul {
  list-style: none;
  padding-left: 0;
}

.tsd-typography ul > li {
  position: relative;
  padding: 0 0 0 1.25em;
}

.tsd-typography ul > li::before {
  content: '⬢';
  position: absolute;
  left: 0;
  top: -0.1em;
  font-size: 0.9em;
}

@media (prefers-color-scheme: light) {
  .tsd-typography ul > li::before {
    color: var(--bargs-lime-dark);
  }
}
@media (prefers-color-scheme: dark) {
  .tsd-typography ul > li::before {
    color: var(--bargs-lime);
  }
}

:root[data-theme='dark'] .tsd-typography ul > li::before {
  color: var(--bargs-lime);
}

:root[data-theme='light'] .tsd-typography ul > li::before {
  color: var(--bargs-lime-dark);
}

.tsd-typography blockquote {
  margin: 1.5em;
  padding: 0.5em 1.5em 0.5em 1.5em;
  border-left: 4px solid var(--bargs-lime-muted);
  background-color: #f0f5e6;
}

@media (prefers-color-scheme: light) {
  .tsd-typography blockquote {
    border-left: 4px solid var(--bargs-lime-muted);
    background-color: #f0f5e6;
  }
}

@media (prefers-color-scheme: dark) {
  .tsd-typography blockquote {
    border-left: 4px solid var(--bargs-lime-dark);
    background-color: #1a1f14;
  }
}

:root[data-theme='light'] .tsd-typography blockquote {
  border-left: 4px solid var(--bargs-lime-muted);
  background-color: #f0f5e6;
}

:root[data-theme='dark'] .tsd-typography blockquote {
  border-left: 4px solid var(--bargs-lime-dark);
  background-color: #1a1f14;
}

small {
  font-size: 0.9em;
}

.tsd-typography {
  line-height: 1.5em;
}

.tsd-typography li > ul {
  margin: 0.25em 0 0.25em 0;
}
