/* Paleta de colores personalizada basada en el logo */
body {
    font-family: 'Inter', sans-serif;
}
.bg-near-black { background-color: #010101; }
.text-gold { color: #f0b859; }
.bg-gold { background-color: #f0b859; }
.border-gold { border-color: #f0b859; }
.ring-gold { --tw-ring-color: #f0b859; }

/* Efecto hover para botones dorados */
.hover\:bg-gold-dark:hover {
    background-color: #d4a24a; /* Un tono de dorado más oscuro */
}

/* Estilo para el menú fijo */
header {
    transition: background-color 0.3s ease;
}

/* Estilo para el enlace activo en la navegación */
.nav-link.active {
    color: #f0b859;
    font-weight: 700;
}

/* Estado activo del filtro del portafolio */
.portfolio-filter.active {
    background-color: #f0b859;
    color: #010101;
}

/* --- ESTILOS PARA ARTÍCULOS (PROSE) - VERSIÓN COMPLETA Y CORREGIDA --- */
.prose {
    color: #374151; /* gray-700 */
    line-height: 1.75;
}

/* Espaciado y estilo para títulos */
.prose h1, .prose h2, .prose h3, .prose h4 {
    color: #111827; /* gray-900 */
    font-weight: 800;
    margin-top: 1.5em; /* Espacio arriba del título */
    margin-bottom: 0.8em; /* Espacio abajo del título */
}

/* Espaciado para párrafos */
.prose p {
    margin-bottom: 1.25em; /* Espacio debajo de cada párrafo */
}

/* Párrafo principal o "lead" */
.prose .lead {
    font-size: 1.25rem; /* text-xl */
    line-height: 1.75;
    color: #4B5563; /* gray-600 */
    margin-bottom: 1.5em;
}

/* Estilos para listas */
.prose ul, .prose ol {
    margin-top: 1.25em;
    margin-bottom: 1.25em;
    padding-left: 1.75em;
    list-style-type: disc; /* Añade los puntos a las listas */
}

.prose li {
    margin-top: 0.5em;
}

/* Estilos para enlaces dentro de artículos */
.prose a {
    color: #f0b859;
    text-decoration: none;
    font-weight: 600;
}
.prose a:hover {
    text-decoration: underline;
}

/* ===== NAV: Magic line ===== */
.nav-container { position: relative; }
#nav-underline {
  position: absolute; left: 0; bottom: -6px; height: 2px;
  background: var(--gold, #CBA135);
  width: 0;
  transform: translateX(0);
  transition: transform 200ms ease, width 200ms ease, opacity 200ms ease;
  opacity: 0;
}

/* Oculta completamente en reduced motion */
@media (prefers-reduced-motion: reduce) {
  #nav-underline { transition: none; }
}

/* ===== Header: efectos al hacer scroll ===== */
#main-header {
  transition: transform 250ms ease, background-color 200ms ease, box-shadow 200ms ease;
}
#main-header.scrolled {
  background-color: rgba(17,17,17,0.92);
  box-shadow: 0 8px 24px rgba(0,0,0,0.18);
}
#main-header.nav-hide {
  transform: translateY(-100%);
}

/* ===== Mobile menu (apertura suave) ===== */
#mobile-menu {
  transform-origin: top;
  transform: scale(0.98) translateY(-4px);
  opacity: 0;
  pointer-events: none;
  transition: transform 180ms ease, opacity 180ms ease;
}
#mobile-menu[data-open="true"] {
  transform: scale(1) translateY(0);
  opacity: 1;
  pointer-events: auto;
}

@media (prefers-reduced-motion: reduce) {
  #main-header, #mobile-menu { transition: none; }
}

/* ===== Page fade-in ===== */
.page-fade {
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 200ms ease, transform 200ms ease;
}
.page-fade.ready {
  opacity: 1; transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .page-fade { transition: none; opacity: 1; transform: none; }
}
