/* ===== NEWS ARTICLE DETAIL STYLES ===== */
/* Estilos específicos para páginas de artículos individuales */
/* Integrado con design-system.css */

/* ===== IMPORTAR DESIGN SYSTEM ===== */
@import url("../design-system.css");

/* ===== LAYOUT PRINCIPAL RESPONSIVE ===== */
.main-article {
  max-width: none;
  width: 100%;
}

.article-container {
  max-width: var(--container-lg, 960px);
  margin-inline: auto;
  padding-inline: var(--space-4, 1rem);
}

@media (min-width: 1200px) {
  .article-container {
    max-width: var(--container-xl, 1140px);
  }
}

/* ===== HEADER SECTION ===== */
.article-header {
  margin-bottom: var(--space-12, 3rem);
  padding: var(--space-8, 2rem) 0;
  border-bottom: 1px solid var(--color-outline-variant, #dee2e6);
}

.article-page-title {
  font-family: var(--font-family-heading, var(--font-family-base));
  font-weight: var(--font-weight-black, 900);
  line-height: var(--line-height-tight, 1.25);
  letter-spacing: -0.025em;
  color: var(--color-on-surface, #212529);
  font-size: clamp(var(--font-size-2xl, 1.5rem), 4vw, var(--font-size-4xl, 2.25rem));
  margin-bottom: var(--space-6, 1.5rem);
}

.article-summary {
  font-size: clamp(var(--font-size-lg, 1.125rem), 2.5vw, var(--font-size-xl, 1.25rem));
  line-height: var(--line-height-relaxed, 1.625);
  color: var(--color-on-surface-variant, #6c757d);
  font-weight: var(--font-weight-normal, 400);
  max-width: 65ch;
  margin-bottom: var(--space-6, 1.5rem);
}

/* ===== META INFORMATION ===== */
.article-detail-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4, 1rem);
  padding: var(--space-4, 1rem) 0;
  border-bottom: 1px solid var(--color-outline-variant, #dee2e6);
  margin-bottom: var(--space-8, 2rem);
  font-size: var(--font-size-sm, 0.875rem);
  color: var(--color-on-surface-variant, #6c757d);
}

@media (max-width: 640px) {
  .article-detail-meta {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-2, 0.5rem);
  }
}

.author-info {
  display: flex;
  align-items: center;
  gap: var(--space-3, 0.75rem);
}

.author-avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full, 9999px);
  background: linear-gradient(135deg, var(--color-primary-500, #0056b3), var(--color-primary-700, #003875));
  color: var(--color-on-primary, #ffffff);
  font-weight: var(--font-weight-bold, 700);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-lg, 1.125rem);
}

.author-name {
  font-weight: var(--font-weight-semibold, 600);
  color: var(--color-on-surface, #212529);
}

.article-date {
  display: flex;
  align-items: center;
  gap: var(--space-1, 0.25rem);
}

.article-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2, 0.5rem);
  margin-top: var(--space-2, 0.5rem);
}

.article-tags .tag {
  background: var(--color-surface-container, #f5f5f5);
  color: var(--color-on-surface-variant, #6c757d);
  padding: var(--space-1, 0.25rem) var(--space-3, 0.75rem);
  border-radius: var(--radius-full, 9999px);
  font-size: var(--font-size-xs, 0.75rem);
  font-weight: var(--font-weight-medium, 500);
  transition: all var(--duration-fast, 150ms) var(--easing-standard, cubic-bezier(0.4, 0, 0.2, 1));
  text-decoration: none;
  border: 1px solid var(--color-outline-variant, #dee2e6);
}

.article-tags .tag:hover {
  background: var(--color-primary-50, #e3f2fd);
  color: var(--color-primary-700, #003875);
  border-color: var(--color-primary-300, #64b5f6);
  transform: translateY(-1px);
}

/* ===== FEATURED IMAGE RESPONSIVE ===== */
.featured-image {
  margin: var(--space-8, 2rem) 0;
  border-radius: var(--radius-xl, 0.75rem);
  overflow: hidden;
  box-shadow: var(--shadow-4, 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -2px rgb(0 0 0 / 0.05));
}

.featured-image img {
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: var(--radius-xl, 0.75rem);
  transition: transform var(--duration-normal, 250ms) var(--easing-standard, cubic-bezier(0.4, 0, 0.2, 1));
}

.featured-image:hover img {
  transform: scale(1.02);
}

/* ===== TYPOGRAPHY DE CLASE MUNDIAL ===== */
/* Inspirado en Medium, NYT, Apple News, y mejores prácticas de UX */

.article-content.prose {
  /* Optimización para lectura profesional */
  max-width: 680px; /* Ancho óptimo para lectura: 65-75 caracteres por línea */
  margin: 0 auto;

  /* Tipografía premium */
  font-family: -apple-system, BlinkMacSystemFont, 'Charter', 'Droid Serif', 'Times New Roman', Georgia, serif;
  font-size: clamp(1.125rem, 1rem + 0.5vw, 1.25rem); /* Responsive 18px-20px */
  line-height: 1.75; /* Espaciado generoso para legibilidad */
  font-weight: 400;
  color: #1a1a1a;

  /* Espaciado óptimo */
  padding: 2rem 1rem;

  /* Mejora de renderizado de fuentes */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: "kern" 1, "liga" 1, "onum" 1;
}

.article-content.prose > * {
  margin-left: 0;
  margin-right: 0;
}

/* ===== HEADINGS PREMIUM ===== */
.article-content.prose h1,
.article-content.prose h2,
.article-content.prose h3,
.article-content.prose h4,
.article-content.prose h5,
.article-content.prose h6 {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Arial', sans-serif;
  font-weight: 700;
  color: #1a1a1a;
  line-height: 1.3;
  letter-spacing: -0.02em; /* Tracking negativo para headings grandes */
  margin-top: 2.5rem;
  margin-bottom: 1rem;
  text-wrap: balance; /* Evita líneas huérfanas */
}

.article-content.prose h1 {
  font-size: clamp(2rem, 2rem + 1vw, 2.75rem);
  margin-top: 0;
  margin-bottom: 1.5rem;
  letter-spacing: -0.03em;
}

.article-content.prose h2 {
  font-size: clamp(1.5rem, 1.5rem + 0.5vw, 2rem);
  padding-bottom: 0.75rem;
  border-bottom: 2px solid #e5e5e5;
  margin-top: 3rem;
  position: relative;
}

.article-content.prose h2::before {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 3rem;
  height: 2px;
  background: linear-gradient(90deg, #0056b3, #4285f4);
}

.article-content.prose h3 {
  font-size: clamp(1.25rem, 1.25rem + 0.3vw, 1.5rem);
  margin-top: 2rem;
}

/* ===== PARAGRAPHS & TEXT ===== */
.article-content.prose p {
  margin-bottom: 1.5rem;
  color: #2e2e2e;
  text-align: justify;
  hyphens: auto;
  hanging-punctuation: first last;
}

.article-content.prose p:first-of-type {
  font-size: 1.2em;
  line-height: 1.6;
  margin-bottom: 2rem;
  color: #1a1a1a;
}

/* Drop cap para el primer párrafo (estilo NYT) */
.article-content.prose p:first-of-type::first-letter {
  float: left;
  font-family: Georgia, serif;
  font-size: 4.2em;
  line-height: 0.8;
  margin: 0.1em 0.1em 0 0;
  color: #0056b3;
  font-weight: 700;
}

/* ===== BLOCKQUOTES PREMIUM ===== */
.article-content.prose blockquote {
  position: relative;
  border: none;
  background: transparent;
  padding: 1.5rem 2rem 1.5rem 3rem;
  margin: 2.5rem auto;
  font-size: 1.1em;
  font-style: italic;
  color: #4a4a4a;
  max-width: 90%;
  text-align: center;
  quotes: """ """ "'" "'";
}

.article-content.prose blockquote::before {
  content: open-quote;
  position: absolute;
  top: 0;
  left: 0;
  font-size: 4rem;
  color: #0056b3;
  font-family: Georgia, serif;
  line-height: 1;
  opacity: 0.3;
}

.article-content.prose blockquote p {
  margin: 0;
  text-align: inherit;
  font-size: inherit;
}

/* ===== CODE & PRE ===== */
.article-content.prose code {
  background: #f5f6f7;
  color: #e83e8c;
  padding: 0.125rem 0.375rem;
  border-radius: 0.25rem;
  font-size: 0.875em;
  font-family: 'SFMono-Regular', 'Monaco', 'Cascadia Code', 'Roboto Mono', 'Courier New', monospace;
  font-weight: 500;
}

.article-content.prose pre {
  background: #f8f9fa;
  border: 1px solid #e9ecef;
  padding: 1.5rem;
  border-radius: 0.5rem;
  overflow-x: auto;
  margin: 2rem 0;
  font-family: 'SFMono-Regular', 'Monaco', 'Cascadia Code', 'Roboto Mono', 'Courier New', monospace;
  font-size: 0.875rem;
  line-height: 1.5;
}

/* ===== LISTS PREMIUM ===== */
.article-content.prose ul,
.article-content.prose ol {
  padding-left: 2rem;
  margin-bottom: 1.5rem;
  line-height: 1.7;
}

.article-content.prose ul {
  list-style: none;
  position: relative;
}

.article-content.prose ul li {
  position: relative;
  margin-bottom: 0.75rem;
  padding-left: 1rem;
}

.article-content.prose ul li::before {
  content: '•';
  color: #0056b3;
  font-size: 1.2em;
  position: absolute;
  left: -0.75rem;
  top: 0;
}

.article-content.prose ol li {
  margin-bottom: 0.75rem;
  padding-left: 0.5rem;
}

.article-content.prose ol li::marker {
  color: #0056b3;
  font-weight: 700;
}

/* ===== LINKS PREMIUM ===== */
.article-content.prose a {
  color: #0056b3;
  text-decoration: none;
  background-image: linear-gradient(120deg, #84fab0 0%, #8fd3f4 100%);
  background-repeat: no-repeat;
  background-size: 100% 0.2em;
  background-position: 0 88%;
  transition: all 0.25s ease-in;
}

.article-content.prose a:hover {
  background-size: 100% 88%;
  color: #003d82;
}

/* ===== IMAGES PREMIUM ===== */
.article-content.prose img {
  border-radius: 0.75rem;
  max-width: 100%;
  height: auto;
  margin: 2rem auto;
  display: block;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.article-content.prose img:hover {
  transform: scale(1.02);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}

/* ===== FOCUS & ACCESSIBILITY ===== */
.article-content.prose *:focus-visible {
  outline: 2px solid #0056b3;
  outline-offset: 2px;
  border-radius: 0.25rem;
}

/* ===== RESPONSIVE ADJUSTMENTS ===== */
@media (max-width: 768px) {
  .article-content.prose {
    font-size: 1.125rem;
    line-height: 1.65;
    padding: 1rem 0.75rem;
  }

  .article-content.prose h1 {
    font-size: 2rem;
  }

  .article-content.prose h2 {
    font-size: 1.5rem;
    margin-top: 2rem;
  }

  /* Desactiva drop cap en móvil */
  .article-content.prose p:first-of-type::first-letter {
    float: none;
    font-size: inherit;
    line-height: inherit;
    margin: 0;
    color: inherit;
    font-weight: inherit;
  }

  .article-content.prose blockquote {
    margin: 1.5rem 0;
    padding: 1rem 1.5rem;
  }
}

/* ===== AUTHOR BIO ENHANCED ===== */
.author-bio {
  background: linear-gradient(135deg, var(--color-surface-variant, #f8f9fa), var(--color-surface-container, #f5f5f5));
  border-left: 4px solid var(--color-primary-500, #0056b3);
  border-radius: 0 var(--radius-lg, 0.5rem) var(--radius-lg, 0.5rem) 0;
  padding: var(--space-6, 1.5rem);
  margin: var(--space-8, 2rem) 0;
  box-shadow: var(--shadow-1, 0 1px 2px 0 rgb(0 0 0 / 0.05));
}

.author-bio .author-details {
  display: flex;
  align-items: center;
  gap: var(--space-4, 1rem);
  margin-bottom: var(--space-4, 1rem);
}

.author-bio .author-avatar-large {
  width: 64px;
  height: 64px;
  border-radius: var(--radius-full, 9999px);
  background: linear-gradient(135deg, var(--color-primary-500, #0056b3), var(--color-secondary-500, #944700));
  color: var(--color-on-primary, #ffffff);
  font-weight: var(--font-weight-bold, 700);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xl, 1.25rem);
  flex-shrink: 0;
}

.author-bio .author-info-text {
  flex-grow: 1;
}

.author-bio .author-name-large {
  font-size: var(--font-size-lg, 1.125rem);
  font-weight: var(--font-weight-bold, 700);
  color: var(--color-on-surface, #212529);
  margin-bottom: var(--space-1, 0.25rem);
}

.author-bio .author-title {
  font-size: var(--font-size-sm, 0.875rem);
  color: var(--color-on-surface-variant, #6c757d);
  font-weight: var(--font-weight-medium, 500);
}

.author-bio .author-description {
  color: var(--color-on-surface-variant, #6c757d);
  line-height: var(--line-height-relaxed, 1.625);
  font-size: var(--font-size-sm, 0.875rem);
}

/* ===== SHARE FOOTER ===== */
.share-footer {
  background: linear-gradient(135deg, var(--color-surface-variant, #f8f9fa), var(--color-surface-container, #f5f5f5));
  border: 1px solid var(--color-outline-variant, #dee2e6);
  border-radius: var(--radius-xl, 0.75rem);
  padding: var(--space-6, 1.5rem);
  margin: var(--space-8, 2rem) 0;
  text-align: center;
}

.share-footer .share-title {
  font-size: var(--font-size-lg, 1.125rem);
  font-weight: var(--font-weight-bold, 700);
  color: var(--color-on-surface, #212529);
  margin-bottom: var(--space-4, 1rem);
}

.share-footer .share-buttons {
  display: flex;
  justify-content: center;
  gap: var(--space-3, 0.75rem);
  flex-wrap: wrap;
}

/* ===== SIDEBAR RESPONSIVE ===== */
.sidebar {
  position: sticky;
  top: calc(70px + var(--space-4, 1rem));
  height: fit-content;
}

@media (max-width: 991px) {
  .sidebar {
    position: static;
    margin-top: var(--space-8, 2rem);
  }
}

.sidebar > * {
  margin-bottom: var(--space-6, 1.5rem);
}

.sidebar > *:last-child {
  margin-bottom: 0;
}

/* ===== NEWSLETTER WIDGET ===== */
.sidebar .news-newsletter {
  background: var(--color-surface, #ffffff);
  border: 1px solid var(--color-outline-variant, #dee2e6);
  border-radius: var(--radius-lg, 0.5rem);
  padding: var(--space-6, 1.5rem);
  box-shadow: var(--shadow-1, 0 1px 2px 0 rgb(0 0 0 / 0.05));
}

.sidebar .newsletter-title {
  font-size: var(--font-size-lg, 1.125rem);
  font-weight: var(--font-weight-bold, 700);
  color: var(--color-on-surface, #212529);
  margin-bottom: var(--space-3, 0.75rem);
  text-align: center;
}

.sidebar .newsletter-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-3, 0.75rem);
}

.sidebar .newsletter-input {
  padding: var(--space-3, 0.75rem) var(--space-4, 1rem);
  border: 1px solid var(--color-outline-variant, #dee2e6);
  border-radius: var(--radius-md, 0.375rem);
  font-size: var(--font-size-sm, 0.875rem);
  transition: all var(--duration-fast, 150ms) var(--easing-standard, cubic-bezier(0.4, 0, 0.2, 1));
}

.sidebar .newsletter-input:focus {
  border-color: var(--color-primary-500, #0056b3);
  box-shadow: 0 0 0 3px var(--color-primary-100, #bbdefb);
  outline: none;
}

.sidebar .newsletter-btn {
  background: var(--color-primary-500, #0056b3);
  color: var(--color-on-primary, #ffffff);
  border: none;
  padding: var(--space-3, 0.75rem) var(--space-4, 1rem);
  border-radius: var(--radius-md, 0.375rem);
  font-weight: var(--font-weight-semibold, 600);
  font-size: var(--font-size-sm, 0.875rem);
  cursor: pointer;
  transition: all var(--duration-fast, 150ms) var(--easing-standard, cubic-bezier(0.4, 0, 0.2, 1));
}

.sidebar .newsletter-btn:hover {
  background: var(--color-primary-600, #004494);
  transform: translateY(-1px);
  box-shadow: var(--shadow-2, 0 1px 3px 0 rgb(0 0 0 / 0.1));
}

/* ===== RELATED ARTICLES ===== */
.related-articles {
  background: var(--color-surface, #ffffff);
  border: 1px solid var(--color-outline-variant, #dee2e6);
  border-radius: var(--radius-lg, 0.5rem);
  padding: var(--space-6, 1.5rem);
  box-shadow: var(--shadow-1, 0 1px 2px 0 rgb(0 0 0 / 0.05));
}

.related-articles .related-title {
  font-size: var(--font-size-lg, 1.125rem);
  font-weight: var(--font-weight-bold, 700);
  color: var(--color-on-surface, #212529);
  margin-bottom: var(--space-4, 1rem);
  padding-bottom: var(--space-2, 0.5rem);
  border-bottom: 2px solid var(--color-primary-500, #0056b3);
}

.related-article-item {
  display: flex;
  gap: var(--space-3, 0.75rem);
  padding: var(--space-3, 0.75rem) 0;
  border-bottom: 1px solid var(--color-outline-variant, #dee2e6);
  transition: all var(--duration-fast, 150ms) var(--easing-standard, cubic-bezier(0.4, 0, 0.2, 1));
}

.related-article-item:last-child {
  border-bottom: none;
}

.related-article-item:hover {
  background: var(--color-surface-variant, #f8f9fa);
  border-radius: var(--radius-md, 0.375rem);
  margin-inline: calc(-1 * var(--space-3, 0.75rem));
  padding-inline: var(--space-3, 0.75rem);
}

.related-article-image {
  width: 60px;
  height: 60px;
  border-radius: var(--radius-md, 0.375rem);
  background-size: cover;
  background-position: center;
  flex-shrink: 0;
}

.related-article-content {
  flex-grow: 1;
}

.related-article-title {
  font-size: var(--font-size-sm, 0.875rem);
  font-weight: var(--font-weight-semibold, 600);
  color: var(--color-on-surface, #212529);
  line-height: var(--line-height-tight, 1.25);
  margin-bottom: var(--space-1, 0.25rem);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.related-article-meta {
  font-size: var(--font-size-xs, 0.75rem);
  color: var(--color-on-surface-variant, #6c757d);
}

/* ===== MOBILE OPTIMIZATIONS ===== */
@media (max-width: 768px) {
  .article-container {
    padding-inline: var(--space-3, 0.75rem);
  }

  .article-header {
    padding: var(--space-4, 1rem) 0;
  }

  .author-bio .author-details {
    flex-direction: column;
    text-align: center;
    gap: var(--space-3, 0.75rem);
  }

  .share-footer .share-buttons {
    gap: var(--space-2, 0.5rem);
  }

  .related-article-item {
    gap: var(--space-2, 0.5rem);
  }

  .related-article-image {
    width: 50px;
    height: 50px;
  }
}

.popular-articles-widget a {
  padding: 0.75rem;
  border-radius: 6px;
  transition: all 0.2s ease;
  display: block;
  margin: -0.75rem;
  margin-bottom: 0.5rem;
}

.popular-articles-widget a:hover {
  background-color: #f3f4f6;
  transform: translateX(4px);
}

/* Breadcrumb styling */
.breadcrumb a {
  text-decoration: none;
  font-weight: 500;
}

.breadcrumb a:hover {
  text-decoration: underline;
}

/* Enhanced responsiveness for article detail */
@media (max-width: 1024px) {
  .sidebar {
    position: static;
    margin-top: 3rem;
  }
}

@media (max-width: 768px) {
  .article-header .badges {
    margin-bottom: 1rem;
  }

  .breaking-badge,
  .category-badge {
    display: block;
    margin-bottom: 0.5rem;
    width: fit-content;
  }

  .article-page-title {
    font-size: 1.875rem !important;
    line-height: 1.2;
    margin-bottom: 1rem;
  }

  .article-summary {
    font-size: 1.125rem !important;
    line-height: 1.5;
    margin-bottom: 1.5rem;
  }

  .article-detail-meta {
    flex-direction: column;
    align-items: flex-start !important;
    gap: 1rem;
  }

  .author-info {
    width: 100%;
  }

  .featured-image {
    margin: 1.5rem -1rem;
  }

  .featured-image img {
    border-radius: 0;
    height: 250px;
  }

  .article-content.prose {
    font-size: 1rem;
    line-height: 1.7;
  }

  .author-bio {
    margin: 1.5rem -1rem;
    border-radius: 0;
    padding: 1.5rem 1rem;
  }

  .share-footer {
    margin: 1.5rem -1rem;
    border-radius: 0;
    padding: 1.5rem 1rem;
  }
}

/* ===== DARK MODE SUPPORT - CONSOLIDADO ===== */
[data-bs-theme="dark"] {
  /* Variables unificadas con news.css */
  --article-surface: var(--news-surface, #1e1e1e);
  --article-surface-container: var(--news-surface-container, #2a2a2a);
  --article-border: var(--news-border, #49454f);
  --article-text: var(--news-text, #e3e3e3);
  --article-text-muted: var(--news-text-muted, #938f99);
  --article-primary: var(--news-primary, var(--color-primary-300));
  --article-primary-hover: var(--news-primary-hover, var(--color-primary-200));
}

/* Header y título */
[data-bs-theme="dark"] .article-header {
  border-color: var(--article-border);
}

[data-bs-theme="dark"] .article-page-title {
  color: var(--article-text);
}

[data-bs-theme="dark"] .article-summary {
  color: var(--article-text-muted);
}

[data-bs-theme="dark"] .article-detail-meta {
  color: var(--article-text-muted);
}

[data-bs-theme="dark"] .article-detail-meta .meta-item strong {
  color: var(--article-text);
}

[data-bs-theme="dark"] .article-detail-meta .category-link {
  color: var(--article-primary);
}

[data-bs-theme="dark"] .article-detail-meta .category-link:hover {
  color: var(--article-primary-hover);
}

[data-bs-theme="dark"] .article-featured-image .image-caption {
  background: rgba(0, 0, 0, 0.8);
  color: var(--article-text);
}

/* ===== DARK MODE - TYPOGRAPHY PREMIUM ===== */

/* Content principal */
[data-bs-theme="dark"] .article-content.prose {
  color: #e8e8e8;
}

/* Headings premium en modo oscuro */
[data-bs-theme="dark"] .article-content.prose h1,
[data-bs-theme="dark"] .article-content.prose h2,
[data-bs-theme="dark"] .article-content.prose h3,
[data-bs-theme="dark"] .article-content.prose h4,
[data-bs-theme="dark"] .article-content.prose h5,
[data-bs-theme="dark"] .article-content.prose h6 {
  color: #ffffff;
}

[data-bs-theme="dark"] .article-content.prose h2 {
  border-bottom: 2px solid #404040;
}

[data-bs-theme="dark"] .article-content.prose h2::before {
  background: linear-gradient(90deg, #4285f4, #34a853);
}

/* Párrafos en modo oscuro */
[data-bs-theme="dark"] .article-content.prose p {
  color: #d0d0d0;
}

[data-bs-theme="dark"] .article-content.prose p:first-of-type {
  color: #e8e8e8;
}

[data-bs-theme="dark"] .article-content.prose p:first-of-type::first-letter {
  color: #4285f4;
}

/* Blockquotes elegantes en modo oscuro */
[data-bs-theme="dark"] .article-content.prose blockquote {
  color: #b8b8b8;
}

[data-bs-theme="dark"] .article-content.prose blockquote::before {
  color: #4285f4;
}

/* Code y Pre en modo oscuro */
[data-bs-theme="dark"] .article-content.prose code {
  background: #2d2d2d;
  color: #f97316;
}

[data-bs-theme="dark"] .article-content.prose pre {
  background: #1e1e1e;
  border: 1px solid #404040;
  color: #e8e8e8;
}

/* Links premium en modo oscuro */
[data-bs-theme="dark"] .article-content.prose a {
  color: #4285f4;
  background-image: linear-gradient(120deg, #4285f4 0%, #34a853 100%);
}

[data-bs-theme="dark"] .article-content.prose a:hover {
  color: #5a9bf8;
}

/* Listas en modo oscuro */
[data-bs-theme="dark"] .article-content.prose ul li::before {
  color: #4285f4;
}

[data-bs-theme="dark"] .article-content.prose ol li::marker {
  color: #4285f4;
}

[data-bs-theme="dark"] .article-content.prose table {
  background: var(--article-surface);
  color: var(--article-text);
}

[data-bs-theme="dark"] .article-content.prose th {
  background: var(--article-surface-container);
  color: var(--article-text);
  border-color: var(--article-border);
}

[data-bs-theme="dark"] .article-content.prose td {
  border-color: var(--article-border);
  color: var(--article-text);
}

/* Sidebar styles */
[data-bs-theme="dark"] .sidebar {
  background: var(--article-surface);
}

[data-bs-theme="dark"] .sidebar-widget {
  background: var(--article-surface-container);
  border-color: var(--article-border);
}

[data-bs-theme="dark"] .sidebar-widget .widget-title {
  color: var(--article-text);
  border-color: var(--article-primary);
}

[data-bs-theme="dark"] .sidebar-widget .list-group-item {
  background: transparent;
  border-color: var(--article-border);
  color: var(--article-text);
}

[data-bs-theme="dark"] .sidebar-widget .list-group-item:hover {
  background: var(--article-surface);
  color: var(--article-primary);
}

[data-bs-theme="dark"] .sidebar-widget .list-group-item a {
  color: var(--article-text);
}

[data-bs-theme="dark"] .sidebar-widget .list-group-item a:hover {
  color: var(--article-primary);
}

/* Author bio y sharing */
[data-bs-theme="dark"] .author-bio {
  background: var(--article-surface-container);
  border-color: var(--article-border);
}

[data-bs-theme="dark"] .author-bio .author-name {
  color: var(--article-text);
}

[data-bs-theme="dark"] .author-bio .author-description {
  color: var(--article-text-muted);
}

[data-bs-theme="dark"] .share-section {
  background: var(--article-surface-container);
  border-color: var(--article-border);
}

[data-bs-theme="dark"] .share-section .section-title {
  color: var(--article-text);
}

[data-bs-theme="dark"] .share-footer {
  background: var(--article-surface-container);
  border-color: var(--article-border);
}

[data-bs-theme="dark"] .social-share-btn {
  background: var(--article-surface);
  color: var(--article-text-muted);
  border-color: var(--article-border);
}

[data-bs-theme="dark"] .social-share-btn:hover {
  background: var(--article-surface-container);
  border-color: var(--article-primary);
  color: var(--article-primary);
}

/* Related articles */
[data-bs-theme="dark"] .related-articles-widget .widget-title {
  color: var(--article-text);
  border-color: var(--article-primary);
}

[data-bs-theme="dark"] .related-article-item {
  border-color: var(--article-border);
}

[data-bs-theme="dark"] .related-article-item:hover {
  background: var(--article-surface-container);
}

[data-bs-theme="dark"] .related-article-item .article-title {
  color: var(--article-text);
}

[data-bs-theme="dark"] .related-article-item .article-title:hover {
  color: var(--article-primary);
}

[data-bs-theme="dark"] .related-article-item .article-excerpt {
  color: var(--article-text-muted);
}

[data-bs-theme="dark"] .related-article-item .article-meta {
  color: var(--article-text-muted);
}

/* Tags y newsletter */
[data-bs-theme="dark"] .tags-widget .tag {
  background: var(--article-surface-container);
  color: var(--article-text);
  border-color: var(--article-border);
}

[data-bs-theme="dark"] .tags-widget .tag:hover {
  background: var(--article-primary);
  color: var(--color-on-primary, #ffffff);
  border-color: var(--article-primary);
}

[data-bs-theme="dark"] .newsletter-widget {
  background: var(--article-surface-container);
  border-color: var(--article-border);
}

[data-bs-theme="dark"] .newsletter-widget .widget-title {
  color: var(--article-text);
}

[data-bs-theme="dark"] .newsletter-widget .widget-description {
  color: var(--article-text-muted);
}

[data-bs-theme="dark"] .newsletter-widget .form-control {
  background: var(--article-surface);
  color: var(--article-text);
  border-color: var(--article-border);
}

[data-bs-theme="dark"] .newsletter-widget .form-control:focus {
  border-color: var(--article-primary);
  box-shadow: 0 0 0 3px rgba(var(--color-primary-300-rgb, 100, 181, 246), 0.2);
}

/* Progress bar y breadcrumbs */
[data-bs-theme="dark"] .reading-progress {
  background: var(--article-border);
}

[data-bs-theme="dark"] .reading-progress-bar {
  background: var(--article-primary);
}

[data-bs-theme="dark"] .breadcrumb-item a {
  color: var(--article-primary);
}

[data-bs-theme="dark"] .breadcrumb-item.active {
  color: var(--article-text-muted);
}

/* Comments section */
[data-bs-theme="dark"] .comments-section {
  background: var(--article-surface-container);
  border-color: var(--article-border);
}

[data-bs-theme="dark"] .comments-section .section-title {
  color: var(--article-text);
}

[data-bs-theme="dark"] .comment-item {
  background: var(--article-surface);
  border-color: var(--article-border);
  color: var(--article-text);
}

[data-bs-theme="dark"] .comment-author {
  color: var(--article-text);
}

[data-bs-theme="dark"] .comment-date {
  color: var(--article-text-muted);
}

[data-bs-theme="dark"] .comment-content {
  color: var(--article-text);
}
