/* Global styles for all pages */

/* Light mode color theme variables */
:root {
  /* Language Journey brand palette — light theme */
  --color-bg: #f5eedc;
  --color-bg-secondary: #ffffff;
  --color-header-bg: #f5eedc;
  --color-text: #292929;
  --color-text-secondary: #4a4a4a;
  --color-accent: #0a3d2f;
  --color-accent-hover: #0c5140;
  --color-accent-secondary: #d97706;
  --color-accent-secondary-hover: #b65e05;
  --color-border: #e2d7c2;
  --color-code-bg: #f9f3e5;
  --color-code: #8c4a0a;
  --color-blockquote-bg: #fff8eb;
  --color-blockquote-border: #d9c9ad;
}

/* Dark theme overrides: apply when .dark class is present on the root element */
.dark {
  --color-bg: #1e2325;
  --color-bg-secondary: #273034;
  --color-header-bg: #1e2325;
  --color-text: #e9e4d4;
  --color-text-secondary: #cfc7b6;
  --color-accent: #1c6b61;
  --color-accent-hover: #228074;
  --color-accent-secondary: #ffc107;
  --color-accent-secondary-hover: #e0a800;
  --color-border: #2f3637;
  --color-code-bg: #262f31;
  --color-code: #ffd27f;
  --color-blockquote-bg: #242c2e;
  --color-blockquote-border: #35524c;
}

/* Header area styling */
.header {
  background-color: var(--color-header-bg);
  border-bottom: 1px solid var(--color-border);
}

/* Font smoothing for better readability */
body {
  font-family:
    "Inter",
    ui-sans-serif,
    system-ui,
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Roboto,
    sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  background-color: var(--color-bg);
  color: var(--color-text);
}

/* Reading content font */
.font-reading,
.prose,
.markdown-content,
.chapter-content {
  font-family: "Source Serif Pro", ui-serif, Georgia, Cambria, "Times New Roman",
    Times, serif;
  line-height: 1.7;
}

/* Mobile reading optimizations */
@media (max-width: 640px) {
  .font-reading,
  .prose,
  .markdown-content,
  .chapter-content {
    line-height: 1.8;
    font-size: 1.1rem;
  }

  /* Better text spacing for mobile reading */
  .prose p,
  .markdown-content p,
  .chapter-content p {
    margin-bottom: 1.2em;
    text-align: left;
    word-spacing: 0.1em;
  }

  /* Improved link spacing for touch targets */
  .prose a,
  .markdown-content a,
  .chapter-content a {
    padding: 0.1em 0.05em;
    margin: -0.1em -0.05em;
  }
}

/* Monospace font improvements */
code,
pre,
.font-mono {
  font-family: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco,
    Consolas, "Liberation Mono", "Courier New", monospace;
  font-feature-settings:
    "liga" 1,
    "calt" 1;
}

/* --- Dark theme adjustments for Language Journey palette --- */
.dark body,
.dark .bg-white,
.dark .bg-gray-800,
.dark .bg-gray-900 {
  background-color: var(--color-bg) !important;
  color: var(--color-text) !important;
}

.dark .bg-gray-50,
.dark .bg-gray-100,
.dark .bg-gray-200,
.dark .bg-gray-700 {
  background-color: var(--color-bg-secondary) !important;
  color: var(--color-text) !important;
}

.dark .prose h1,
.dark .markdown-content h1,
.dark .comment-text h1,
.dark .user-content h1,
.dark .prose h2,
.dark .markdown-content h2,
.dark .comment-text h2,
.dark .user-content h2 {
  color: var(--color-text) !important;
}

.dark .prose h3,
.dark .markdown-content h3,
.dark .comment-text h3,
.dark .user-content h3,
.dark .prose h4,
.dark .markdown-content h4,
.dark .comment-text h4,
.dark .user-content h4,
.dark .prose h5,
.dark .markdown-content h5,
.dark .comment-text h5,
.dark .user-content h5,
.dark .prose h6,
.dark .markdown-content h6,
.dark .comment-text h6,
.dark .user-content h6 {
  color: var(--color-text-secondary) !important;
}

.dark .prose strong,
.dark .markdown-content strong,
.dark .comment-text strong,
.dark .user-content strong {
  color: var(--color-text) !important;
}

.dark .prose em,
.dark .markdown-content em,
.dark .comment-text em,
.dark .user-content em {
  color: var(--color-text-secondary) !important;
  font-style: italic;
}

.dark .prose blockquote,
.dark .markdown-content blockquote,
.dark .comment-text blockquote,
.dark .user-content blockquote {
  border-left: 4px solid var(--color-accent) !important;
  background-color: rgba(28, 107, 97, 0.18) !important;
  color: var(--color-text) !important;
  font-style: italic;
}

.dark .prose code,
.dark .markdown-content code,
.dark .comment-text code,
.dark .user-content code {
  background-color: var(--color-code-bg) !important;
  color: var(--color-code) !important;
  border-radius: 4px;
  padding: 2px 6px;
}

.dark .prose pre,
.dark .markdown-content pre,
.dark .comment-text pre,
.dark .user-content pre {
  background-color: var(--color-bg-secondary) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 6px;
}

.dark .prose a,
.dark .markdown-content a,
.dark .comment-text a,
.dark .user-content a {
  color: var(--color-accent-secondary) !important;
  text-decoration: underline;
}

.dark .prose a:hover,
.dark .markdown-content a:hover,
.dark .comment-text a:hover,
.dark .user-content a:hover {
  color: var(--color-accent-secondary-hover) !important;
}

.dark ::selection {
  background-color: rgba(28, 107, 97, 0.35) !important;
  color: var(--color-text) !important;
}

.dark .highlighted {
  background-color: rgba(28, 107, 97, 0.22) !important;
}

.dark .bg-blue-600,
.dark .bg-green-600,
.dark .bg-yellow-500,
.dark .bg-purple-600,
.dark .bg-red-600 {
  color: var(--color-bg) !important;
  font-weight: 600;
}

.dark ::-webkit-scrollbar {
  width: 8px;
  background: var(--color-bg);
}

.dark ::-webkit-scrollbar-thumb {
  background: rgba(28, 107, 97, 0.35);
  border-radius: 4px;
}

.dark ::-webkit-scrollbar-thumb:hover {
  background: rgba(28, 107, 97, 0.55);
}

.dark .bg-white {
  background-color: var(--color-bg);
}

.dark .bg-gray-50,
.dark .bg-gray-100,
.dark .bg-gray-200,
.dark .bg-gray-700,
.dark .bg-gray-800 {
  background-color: var(--color-bg-secondary);
}

.dark .text-gray-900,
.dark .text-gray-100,
.dark .text-gray-300,
.dark .text-gray-600,
.dark .text-gray-500,
.dark .text-gray-400,
.dark .text-gray-700 {
  color: var(--color-text) !important;
}

.dark .text-blue-600,
.dark .text-blue-400 {
  color: var(--color-accent-secondary) !important;
}

.dark .text-green-400,
.dark .text-green-600 {
  color: var(--color-accent) !important;
}

.dark .text-yellow-500,
.dark .text-orange-400 {
  color: var(--color-accent-secondary) !important;
}

.dark .text-purple-400 {
  color: #c8a8ff;
}

.dark .text-red-400 {
  color: #ff9b9b;
}

.dark .bg-blue-600 {
  background-color: var(--color-accent);
  color: var(--color-bg);
}

.dark .bg-green-600 {
  background-color: var(--color-accent);
  color: var(--color-bg);
}

.dark .bg-yellow-500 {
  background-color: var(--color-accent-secondary);
  color: var(--color-bg);
}

.dark .bg-purple-600 {
  background-color: #8560d7;
  color: var(--color-bg);
}

.dark .bg-red-600 {
  background-color: #d66f6f;
  color: var(--color-bg);
}

.dark .hover\:bg-blue-700:hover,
.dark .hover\:bg-blue-500:hover {
  background-color: var(--color-accent-hover);
}

.dark .hover\:bg-green-700:hover {
  background-color: var(--color-accent-hover);
}

.dark .hover\:bg-yellow-600:hover {
  background-color: var(--color-accent-secondary-hover);
}

.dark .hover\:bg-purple-700:hover {
  background-color: #7452c4;
}

.dark .hover\:bg-gray-50:hover,
.dark .hover\:bg-gray-700:hover {
  background-color: var(--color-bg-secondary);
}

.dark .hover\:text-blue-600:hover,
.dark .hover\:text-blue-400:hover {
  color: var(--color-accent-secondary-hover);
}

.dark .bg-blue-100,
.dark .bg-green-100,
.dark .bg-purple-100,
.dark .bg-yellow-100,
.dark .bg-red-100,
.dark .bg-gray-100 {
  background-color: rgba(28, 107, 97, 0.12);
}

.dark input[type="text"],
.dark input[type="email"],
.dark input[type="password"],
.dark select,
.dark textarea {
  background-color: var(--color-bg-secondary);
  border-color: var(--color-border);
  color: var(--color-text);
}

.dark input[type="text"]:focus,
.dark input[type="email"]:focus,
.dark input[type="password"]:focus,
.dark select:focus,
.dark textarea:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 2px rgba(28, 107, 97, 0.25);
  outline: none;
}

.dark input::placeholder,
.dark textarea::placeholder {
  color: rgba(233, 228, 212, 0.55);
}

.dark .border-gray-200,
.dark .border-gray-300,
.dark .border-gray-600,
.dark .border-gray-700 {
  border-color: var(--color-border);
}

.dark .border-blue-500,
.dark .border-blue-400 {
  border-color: var(--color-accent);
}

.dark .divide-gray-200 > :not([hidden]) ~ :not([hidden]),
.dark .divide-gray-700 > :not([hidden]) ~ :not([hidden]) {
  border-color: var(--color-border);
}

.dark .shadow {
  box-shadow:
    0 1px 3px 0 rgba(0, 0, 0, 0.45),
    0 1px 2px 0 rgba(0, 0, 0, 0.35);
}

.dark .shadow-lg {
  box-shadow:
    0 10px 15px -3px rgba(0, 0, 0, 0.5),
    0 4px 6px -2px rgba(0, 0, 0, 0.4);
}

.dark .shadow-xl {
  box-shadow:
    0 20px 25px -5px rgba(0, 0, 0, 0.5),
    0 10px 10px -5px rgba(0, 0, 0, 0.4);
}

.dark .highlighted:hover {
  background-color: rgba(28, 107, 97, 0.32);
}

/* Language Journey brand utilities */
.lj-app-header {
  background-color: var(--color-header-bg);
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text);
  backdrop-filter: blur(8px);
}

.dark .lj-app-header {
  background-color: var(--color-header-bg);
  color: var(--color-text);
}

.lj-brand-title {
  color: var(--color-text);
  font-weight: 700;
  letter-spacing: 0.02em;
}

.lj-brand-subtitle {
  color: var(--color-text-secondary);
}

.lj-logo-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 1rem;
  background-color: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(10, 61, 47, 0.18);
  box-shadow: 0 12px 28px -18px rgba(10, 61, 47, 0.45);
}

.lj-logo-mark {
  width: 32px;
  height: 32px;
  display: block;
}

.dark .lj-logo-badge {
  background-color: rgba(30, 35, 37, 0.94);
  border-color: rgba(233, 228, 212, 0.2);
  box-shadow: 0 20px 40px -24px rgba(0, 0, 0, 0.62);
}

.dark .lj-logo-mark {
  filter: brightness(1.1);
}

.lj-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  border-radius: 0.75rem;
  background-color: var(--color-accent);
  color: #f5eedc;
  font-weight: 600;
  transition: background-color 0.2s ease, transform 0.2s ease;
}

.lj-btn-primary:hover {
  background-color: var(--color-accent-hover);
  transform: translateY(-1px);
}

.dark .lj-btn-primary {
  color: var(--color-text);
}

.dark .lj-btn-primary:hover {
  background-color: var(--color-accent-hover);
}

.lj-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  border-radius: 0.75rem;
  background-color: var(--color-accent-secondary);
  color: #fffaf0;
  font-weight: 600;
  transition: background-color 0.2s ease, transform 0.2s ease;
}

.lj-btn-secondary:hover {
  background-color: var(--color-accent-secondary-hover);
  transform: translateY(-1px);
}

.dark .lj-btn-secondary {
  color: var(--color-bg);
}

.dark .lj-btn-secondary:hover {
  background-color: var(--color-accent-secondary-hover);
}

.lj-store-badge {
  display: inline-block;
  border-radius: 0.9rem;
  overflow: hidden;
  background-color: #000;
  box-shadow: 0 12px 30px -18px rgba(10, 61, 47, 0.6);
}

.lj-store-badge img {
  display: block;
  width: 220px;
  max-width: 100%;
  height: auto;
}

.dark .lj-store-badge {
  box-shadow: 0 16px 34px -20px rgba(0, 0, 0, 0.7);
}

.lj-section-card {
  background-color: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: 1rem;
  box-shadow: 0 18px 36px -24px rgba(10, 61, 47, 0.35);
}

.dark .lj-section-card {
  background-color: #273034;
  border-color: var(--color-border);
  box-shadow: 0 26px 50px -28px rgba(0, 0, 0, 0.65);
}

.lj-accent-text {
  color: var(--color-accent);
}

.dark .lj-accent-text {
  color: var(--color-accent-secondary);
}

.lj-section-subtitle {
  color: var(--color-text-secondary);
}

.lj-badge-soft {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.45rem 0.85rem;
  border-radius: 9999px;
  background-color: rgba(10, 61, 47, 0.1);
  color: var(--color-accent);
  font-weight: 600;
}

.dark .lj-badge-soft {
  background-color: rgba(255, 193, 7, 0.1);
  color: var(--color-accent-secondary);
}
.lj-icon-button {
  color: var(--color-accent);
  background-color: transparent;
  transition: background-color 0.2s ease, color 0.2s ease;
  border-radius: 0.75rem;
}

.lj-icon-button:hover {
  background-color: rgba(10, 61, 47, 0.12);
  color: var(--color-accent-hover);
}

.dark .lj-icon-button {
  color: var(--color-text);
}

.dark .lj-icon-button:hover {
  background-color: rgba(28, 107, 97, 0.22);
  color: var(--color-accent-secondary);
}

/* Map legacy utility classes to brand colors */
.bg-blue-600,
.bg-blue-500 {
  background-color: var(--color-accent) !important;
  color: #f5eedc;
}

.hover\:bg-blue-700:hover,
.hover\:bg-blue-500:hover {
  background-color: var(--color-accent-hover) !important;
}

.text-blue-600,
.text-blue-500 {
  color: var(--color-accent) !important;
}

.text-blue-400 {
  color: var(--color-accent-secondary) !important;
}

.bg-blue-100 {
  background-color: rgba(10, 61, 47, 0.12) !important;
  color: var(--color-accent);
}

.border-blue-500,
.border-blue-400 {
  border-color: var(--color-accent) !important;
}

.focus\:ring-blue-500:focus {
  box-shadow: 0 0 0 2px rgba(10, 61, 47, 0.22);
  outline: none;
}

.lj-hero {
  position: relative;
  background: linear-gradient(135deg, rgba(10, 61, 47, 0.1) 0%, rgba(245, 238, 220, 0.85) 100%);
  border-bottom: 1px solid var(--color-border);
}

.dark .lj-hero {
  background: linear-gradient(135deg, rgba(28, 107, 97, 0.25) 0%, rgba(30, 35, 37, 0.9) 100%);
  border-bottom: 1px solid rgba(233, 228, 212, 0.12);
}

.lj-hero-illustration {
  background: radial-gradient(circle at 30% 20%, rgba(217, 119, 6, 0.12), transparent 55%),
              radial-gradient(circle at 70% 80%, rgba(10, 61, 47, 0.18), transparent 60%),
              var(--color-bg-secondary);
  border: 1px solid rgba(10, 61, 47, 0.12);
  border-radius: 1.5rem;
}

.lj-hero-disc {
  background-color: rgba(255, 255, 255, 0.85);
  color: var(--color-accent);
}

.dark .lj-hero-disc {
  background-color: rgba(255, 255, 255, 0.08);
  color: var(--color-accent-secondary);
}


.dark .lj-hero-illustration {
  background: radial-gradient(circle at 30% 20%, rgba(255, 193, 7, 0.14), transparent 55%),
              radial-gradient(circle at 70% 80%, rgba(28, 107, 97, 0.35), transparent 60%),
              #1e2325;
  border: 1px solid rgba(233, 228, 212, 0.12);
}

.lj-feature-icon {
  background-color: rgba(10, 61, 47, 0.12);
  color: var(--color-accent);
  border-radius: 0.9rem;
}

.dark .lj-feature-icon {
  background-color: rgba(255, 193, 7, 0.12);
  color: var(--color-accent-secondary);
}


.lj-grid-divider {
  border-top: 1px solid var(--color-border);
}

.dark .lj-grid-divider {
  border-color: rgba(233, 228, 212, 0.12);
}

/* Common utility class overrides */
.p-8 {
  padding: 1rem;
}

/* Transition utilities */
.transition-colors {
  transition-property: color, background-color, border-color,
    text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-shadow {
  transition-property: box-shadow;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-all {
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

/* Dark mode specific shadow improvements */
.dark .shadow-xl {
  box-shadow:
    0 20px 25px -5px rgba(0, 0, 0, 0.4),
    0 10px 10px -5px rgba(0, 0, 0, 0.2);
}

.dark .hover\:shadow-md:hover {
  box-shadow:
    0 4px 6px -1px rgba(0, 0, 0, 0.3),
    0 2px 4px -1px rgba(0, 0, 0, 0.2);
}

.dark .hover\:shadow-xl:hover {
  box-shadow:
    0 20px 25px -5px rgba(0, 0, 0, 0.4),
    0 10px 10px -5px rgba(0, 0, 0, 0.2);
}

/* Global markdown styling for notes, comments, and other content */
.prose,
.markdown-content,
.comment-text,
.user-content {
  line-height: 1.6;
}

.prose h1,
.markdown-content h1,
.comment-text h1,
.user-content h1 {
  font-size: 1.5em;
  font-weight: 700;
  /* margin-top: 1.5em;1.5em */
  margin-bottom: 0.75em;
  color: var(--color-text);
}

.prose h2,
.markdown-content h2,
.comment-text h2,
.user-content h2 {
  font-size: 1.3em;
  font-weight: 600;
  margin-top: 1.25em;
  margin-bottom: 0.625em;
  color: var(--color-text);
}

.prose h3,
.markdown-content h3,
.comment-text h3,
.user-content h3 {
  font-size: 1.15em;
  font-weight: 600;
  margin-top: 1em;
  margin-bottom: 0.5em;
  color: var(--color-text-secondary);
}

.prose h4,
.markdown-content h4,
.comment-text h4,
.user-content h4,
.prose h5,
.markdown-content h5,
.comment-text h5,
.user-content h5,
.prose h6,
.markdown-content h6,
.comment-text h6,
.user-content h6 {
  font-weight: 600;
  margin-top: 0.75em;
  margin-bottom: 0.375em;
  color: var(--color-text-secondary);
}

.prose p,
.markdown-content p,
.comment-text p,
.user-content p {
  margin-bottom: 1em;
}

.prose p:last-child,
.markdown-content p:last-child,
.comment-text p:last-child,
.user-content p:last-child {
  margin-bottom: 0;
}

.prose strong,
.markdown-content strong,
.comment-text strong,
.user-content strong {
  font-weight: 600;
  color: var(--color-text);
}

.prose em,
.markdown-content em,
.comment-text em,
.user-content em {
  font-style: italic;
  /* color: var(--color-text-secondary); */
  color: #6a6c6f; /*  #f3f4f6; */
}

.prose code,
.markdown-content code,
.comment-text code,
.user-content code {
  background-color: var(--color-code-bg);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.9em;
  font-family: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco,
    Consolas, monospace;
  color: var(--color-code);
}

.prose pre,
.markdown-content pre,
.comment-text pre,
.user-content pre {
  background-color: var(--color-blockquote-bg);
  padding: 1em;
  border-radius: 6px;
  overflow-x: auto;
  font-size: 0.9em;
  font-family: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco,
    Consolas, monospace;
  margin: 1em 0;
  border: 1px solid var(--color-border);
}

.prose pre code,
.markdown-content pre code,
.comment-text pre code,
.user-content pre code {
  background: none;
  padding: 0;
  color: inherit;
}

.prose blockquote,
.markdown-content blockquote,
.comment-text blockquote,
.user-content blockquote {
  border-left: 4px solid var(--color-blockquote-border);
  padding-left: 1em;
  margin: 1em 0;
  color: #6b7280;
  font-style: italic;
  background-color: var(--color-blockquote-bg);
  padding: 0.75em 1em;
  border-radius: 0 4px 4px 0;
}

/* Dark mode code and content styling - One Dark Pro */
.dark .prose code,
.dark .markdown-content code,
.dark .comment-text code,
.dark .user-content code {
  background-color: #3e4451;
  color: #e06c75;
  padding: 2px 6px;
  border-radius: 4px;
}

.dark .prose pre,
.dark .markdown-content pre,
.dark .comment-text pre,
.dark .user-content pre {
  background-color: #21252b;
  border: 1px solid #3e4451;
  color: #abb2bf;
}

.dark .prose blockquote,
.dark .markdown-content blockquote,
.dark .comment-text blockquote,
.dark .user-content blockquote {
  border-left-color: #61afef;
  background-color: rgba(97, 175, 239, 0.1);
  color: #5c6370;
}

.prose ul,
.markdown-content ul,
.comment-text ul,
.user-content ul,
.prose ol,
.markdown-content ol,
.comment-text ol,
.user-content ol {
  margin: 1em 0;
  padding-left: 1.5em;
}

.prose ul,
.markdown-content ul,
.comment-text ul,
.user-content ul {
  list-style-type: disc;
}

.prose ol,
.markdown-content ol,
.comment-text ol,
.user-content ol {
  list-style-type: decimal;
}

.prose li,
.markdown-content li,
.comment-text li,
.user-content li {
  margin-bottom: 0.5em;
}

.prose a,
.markdown-content a,
.comment-text a,
.user-content a {
  color: var(--color-accent);
  text-decoration: underline;
  transition: color 0.2s ease;
}

.prose a:hover,
.markdown-content a:hover,
.comment-text a:hover,
.user-content a:hover {
  color: var(--color-accent-hover);
}

.prose hr,
.markdown-content hr,
.comment-text hr,
.user-content hr {
  border: none;
  border-top: 2px solid var(--color-border);
  margin: 2em 0;
}

/* Dark mode markdown styles */
.dark .prose h1,
.dark .markdown-content h1,
.dark .comment-text h1,
.dark .user-content h1,
.dark .prose h2,
.dark .markdown-content h2,
.dark .comment-text h2,
.dark .user-content h2 {
  color: #f3f4f6;
}

.dark .prose h3,
.dark .markdown-content h3,
.dark .comment-text h3,
.dark .user-content h3,
.dark .prose h4,
.dark .markdown-content h4,
.dark .comment-text h4,
.dark .user-content h4,
.dark .prose h5,
.dark .markdown-content h5,
.dark .comment-text h5,
.dark .user-content h5,
.dark .prose h6,
.dark .markdown-content h6,
.dark .comment-text h6,
.dark .user-content h6 {
  color: #e5e7eb;
}

.dark .prose strong,
.dark .markdown-content strong,
.dark .comment-text strong,
.dark .user-content strong {
  color: #f9fafb;
}

.dark .prose em,
.dark .markdown-content em,
.dark .comment-text em,
.dark .user-content em {
  color: #d1d5db;
}

.dark .prose code,
.dark .markdown-content code,
.dark .comment-text code,
.dark .user-content code {
  background-color: #374151;
  color: #fbbf24;
}

.dark .prose pre,
.dark .markdown-content pre,
.dark .comment-text pre,
.dark .user-content pre {
  background-color: #1f2937;
  border-color: #374151;
  color: #e5e7eb;
}

.dark .prose blockquote,
.dark .markdown-content blockquote,
.dark .comment-text blockquote,
.dark .user-content blockquote {
  border-left-color: #4b5563;
  background-color: #1f2937;
  color: #9ca3af;
}

.dark .prose a,
.dark .markdown-content a,
.dark .comment-text a,
.dark .user-content a {
  color: #60a5fa;
}

.dark .prose a:hover,
.dark .markdown-content a:hover,
.dark .comment-text a:hover,
.dark .user-content a:hover {
  color: #93c5fd;
}

.dark .prose hr,
.dark .markdown-content hr,
.dark .comment-text hr,
.dark .user-content hr {
  border-top-color: #4b5563;
}

/* Prose invert class for better dark mode support */
.prose-invert {
  color: #e5e7eb;
}

.prose-invert h1,
.prose-invert h2,
.prose-invert h3,
.prose-invert h4,
.prose-invert h5,
.prose-invert h6 {
  color: #f3f4f6;
}

.prose-invert strong {
  color: #f9fafb;
}

.prose-invert em {
  color: #d1d5db;
}

.prose-invert code {
  background-color: #374151;
  color: #fbbf24;
}

.prose-invert pre {
  background-color: #1f2937;
  border-color: #374151;
  color: #e5e7eb;
}

.prose-invert blockquote {
  border-left-color: #4b5563;
  background-color: #1f2937;
  color: #9ca3af;
}

.prose-invert a {
  color: #61afef;
}

.prose-invert a:hover {
  color: #6bb6ff;
}

.prose-invert hr {
  border-top-color: #3e4451;
}

/* One Dark Pro specific enhancements */
.dark .bg-blue-50 {
  background-color: rgba(97, 175, 239, 0.1);
}

.dark .bg-green-50 {
  background-color: rgba(152, 195, 121, 0.1);
}

.dark .bg-red-50 {
  background-color: rgba(224, 108, 117, 0.1);
}

.dark .bg-yellow-50 {
  background-color: rgba(229, 192, 123, 0.1);
}

/* Better text contrast for readability */
.dark .text-gray-800 {
  color: #abb2bf;
}

/* Improved selection styling */
.dark ::selection {
  background-color: #3e4451;
  color: #abb2bf;
}

/* Scrollbar styling for dark mode */
.dark ::-webkit-scrollbar {
  width: 8px;
}

.dark ::-webkit-scrollbar-track {
  background: #21252b;
}

.dark ::-webkit-scrollbar-thumb {
  background: #3e4451;
  border-radius: 4px;
}

.dark ::-webkit-scrollbar-thumb:hover {
  background: #5c6370;
}
