:root {
  --bg: #0f0f10;
  --bg-card: #1a1b1e;
  --text: #e5e7eb;
  --border: #2a2a2d;
  --accent: #00b7ff;
  --accent-hover: #00d0ff;
  --code-bg: #1e1e1e;
  --code-text: #e5e7eb;
}

:root[data-theme='light'] {
  --bg: #f3f4f6;
  --bg-card: #ffffff;
  --text: #1f2937;
  --border: #d1d5db;
  --accent: #0094cc;
  --accent-hover: #0077a8;

  /* Slightly darker neutral for readability */
  --code-bg: #dfe3e8;
  --code-text: #111827;
}

/* Base */
body {
  background-color: var(--bg);
  color: var(--text);
  font-family: 'Inter', 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  transition: background-color 0.3s ease, color 0.3s ease;
}

/* Cards */
.card {
  background-color: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  padding: 1.25rem;
  transition: background-color 0.3s ease, border-color 0.3s ease;
}

/* Header / Footer */
header,
footer {
  background-color: var(--bg-card);
  border-color: var(--border);
  transition: background-color 0.3s ease, border-color 0.3s ease;
}

/* Links */
a {
  color: var(--accent);
  text-decoration: none;
  transition: color 0.2s ease;
}
a:hover {
  color: var(--accent-hover);
}

/* Buttons */
button {
  transition: all 0.2s ease;
}

/* Code and Pre */
code {
  font-family: 'JetBrains Mono', 'Courier New', monospace;
  word-break: break-all;
  color: var(--code-text);
}

pre {
  white-space: pre-wrap;
  word-wrap: break-word;
  background-color: var(--code-bg);
  color: var(--code-text);
  border-radius: 0.5rem;
  padding: 0.75rem;
  overflow-x: auto;
}

/* Scrollbar */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 6px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--accent);
}

/* Animations */
.fade {
  transition: all 0.3s ease;
}

/* Forms */
select,
input {
  background-color: var(--bg);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  padding: 0.5rem 0.75rem;
  transition: background-color 0.3s ease, border-color 0.3s ease;
}

select:focus,
input:focus {
  outline: none;
  border-color: var(--accent);
}

/* Code Box */
.code-box {
  background-color: var(--code-bg);
  color: var(--code-text);
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.875rem;
  padding: 0.75rem 1rem;
  position: relative;
  overflow-x: auto;
  transition: background-color 0.3s ease, color 0.3s ease;
}

.code-box button.copy-btn {
  position: absolute;
  top: 0.5rem;
  right: 0.75rem;
  background: none;
  border: none;
  color: var(--accent);
  cursor: pointer;
  transition: color 0.2s ease;
}

.code-box button.copy-btn:hover {
  color: var(--accent-hover);
}

/* Titles / Headings */
h1,
h2,
h3,
h4 {
  color: var(--text);
  transition: color 0.3s ease;
}

/* Footer */
footer {
  color: var(--text);
  text-align: center;
  padding: 1rem;
  font-size: 0.875rem;
}

/* Responsive */
@media (max-width: 768px) {
  .code-box {
    font-size: 0.8rem;
  }
}

/* ---------- LIGHT THEME PRISM FIX ---------- */
:root[data-theme='light'] {
  --bg: #f3f4f6;
  --bg-card: #ffffff;
  --text: #1f2937;
  --border: #d1d5db;
  --accent: #0094cc;
  --accent-hover: #0077a8;

  /* Balanced neutral for code and manifest sections */
  --code-bg: #dfe3e8;
  --code-text: #111827;
}

/* ---------- LIGHT THEME PRISM FIX ---------- */
:root[data-theme='light'] pre[class*="language-"],
:root[data-theme='light'] code[class*="language-"] {
  color: var(--code-text);
  background: var(--code-bg);
}

/* Keys, punctuation, strings, etc. */
:root[data-theme='light'] .token.property,
:root[data-theme='light'] .token.tag,
:root[data-theme='light'] .token.constant,
:root[data-theme='light'] .token.symbol,
:root[data-theme='light'] .token.deleted {
  color: #374151; /* neutral gray-blue for keys */
}

:root[data-theme='light'] .token.string {
  color: #065f46; /* readable deep green */
}

:root[data-theme='light'] .token.number {
  color: #7c2d12; /* darker orange-brown */
}

:root[data-theme='light'] .token.keyword {
  color: #1e3a8a; /* navy blue for clarity */
}

:root[data-theme='light'] .token.function {
  color: #7c3aed; /* bold purple accent */
}

:root[data-theme='light'] .token.boolean {
  color: #9a3412; /* warm brown tone */
}

:root[data-theme='light'] .token.operator,
:root[data-theme='light'] .token.entity,
:root[data-theme='light'] .token.url {
  color: var(--code-text);
}

/* ---------- STRUCTURE FIX: make braces/brackets visible ---------- */
:root[data-theme='light'] .token.punctuation,
:root[data-theme='light'] .token.brace,
:root[data-theme='light'] .token.bracket,
:root[data-theme='light'] .token.delimiter {
  color: var(--code-text) !important;
}

/* Ensure nested highlights (within <pre><code>) stay strong */
:root[data-theme='light'] pre[class*="language-"] {
  border: 1px solid #cdd1d6;
  box-shadow: inset 0 0 4px rgba(0,0,0,0.05);
  border-radius: 0.5rem;
}
