/* ============================================================================
   Post detail page — Oscar I. Morales
   Lee la paleta y la tipografía desde colors_and_type.css
   ============================================================================ */

/* Site override: el post tiene fondo crema cálido más limpio */
.site--post {
  background: var(--crema-50);
}

/* --------------------------------------------------------------------------
   NAV — barra de progreso de lectura
   -------------------------------------------------------------------------- */
.nav__progress {
  height: 2px;
  background: rgba(13, 27, 42, 0.06);
  position: relative;
  overflow: hidden;
}
.nav__progress-fill {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--terracota-500), var(--dorado-500));
  transform-origin: left center;
  transform: scaleX(0);
  transition: transform 80ms linear;
}

/* --------------------------------------------------------------------------
   ARTICLE COVER — portada con título sobre la imagen
   -------------------------------------------------------------------------- */
.acover {
  position: relative;
  min-height: clamp(560px, 86vh, 820px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--noche-900);
  color: var(--crema-50);
  isolation: isolate;
}
.acover__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.acover__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  display: block;
  filter: saturate(0.92) contrast(1.05) brightness(0.9);
}
.acover__scrim {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg,
      rgba(13, 27, 42, 0.55) 0%,
      rgba(13, 27, 42, 0.20) 28%,
      rgba(13, 27, 42, 0.10) 50%,
      rgba(13, 27, 42, 0.65) 80%,
      rgba(13, 27, 42, 0.92) 100%);
  pointer-events: none;
}
/* Fallback sin imagen — gradiente noche con numeral grande */
.acover__bg--fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  background: radial-gradient(ellipse at 50% 50%, var(--noche-700), var(--noche-900) 80%);
}
.acover__fallback-num {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(160px, 22vw, 360px);
  line-height: 0.85;
  color: rgba(212, 158, 124, 0.35);
  letter-spacing: -0.02em;
}
.acover__fallback-num sup {
  font-size: 0.32em;
  vertical-align: top;
  margin-right: 8px;
  color: rgba(245, 240, 232, 0.25);
}

/* Top bar — crumbs + numeral */
.acover__top {
  position: relative;
  z-index: 2;
  padding-top: 36px;
  padding-bottom: 36px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.acover__crumbs {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-descriptor);
  font-weight: 800;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: rgba(245, 240, 232, 0.7);
}
.acover__crumbs a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color var(--transition-fast), color var(--transition-fast);
}
.acover__crumbs a:hover { color: var(--crema-50); border-bottom-color: currentColor; }
.acover__crumbs-sep { color: rgba(245, 240, 232, 0.35); }
.acover__crumbs-current { color: var(--terracota-300); }

.acover__num {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 22px;
  color: var(--dorado-300);
  letter-spacing: -0.01em;
}
.acover__num sup { font-size: 0.5em; margin-right: 1px; }

/* Bottom block — título + meta */
.acover__bottom {
  position: relative;
  z-index: 2;
  margin-top: auto;
  padding-bottom: clamp(48px, 6vw, 80px);
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 2vw, 28px);
  max-width: 1100px;
}
.acover__cats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.acover__cat {
  font-family: var(--font-descriptor);
  font-weight: 800;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  padding: 6px 11px;
  border-radius: 2px;
  background: rgba(245, 240, 232, 0.14);
  color: var(--crema-50);
  text-decoration: none;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  transition: background var(--transition-fast);
}
.acover__cat:hover { background: var(--terracota-500); }

.acover__title {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: clamp(40px, 6.4vw, 92px);
  line-height: 1.02;
  letter-spacing: -0.028em;
  color: var(--crema-50);
  margin: 0;
  text-wrap: balance;
  text-shadow: 0 2px 30px rgba(13, 27, 42, 0.45);
  max-width: 18ch;
}

.acover__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  font-family: var(--font-descriptor);
  font-weight: 800;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: rgba(245, 240, 232, 0.85);
}
.acover__byline {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
}
.acover__byline-lbl { color: rgba(245, 240, 232, 0.55); }
.acover__byline-name {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 15px;
  text-transform: none;
  letter-spacing: -0.005em;
  color: var(--crema-50);
}
.acover__dot {
  width: 4px; height: 4px;
  border-radius: 50%;
  background: rgba(245, 240, 232, 0.4);
}
.acover__date { color: rgba(245, 240, 232, 0.85); }
.acover__read { color: var(--terracota-300); }

/* --------------------------------------------------------------------------
   PROSE — cuerpo del artículo
   -------------------------------------------------------------------------- */
.prose {
  padding: 80px 0 96px;
}
.prose .wrap--narrow {
  max-width: 720px;
}

/* Lead — primer párrafo con drop cap */
.prose__lead {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(22px, 1.9vw, 26px);
  line-height: 1.55;
  color: var(--noche-800);
  margin: 0 0 32px;
  letter-spacing: -0.003em;
  /* Drop cap */
  &::first-letter {
    font-style: normal;
    font-weight: 700;
    font-size: 6.2em;
    line-height: 0.88;
    color: var(--terracota-500);
    float: left;
    margin: 6px 14px 0 0;
    font-family: var(--font-serif);
  }
}

/* Párrafo */
.prose__p {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 19px;
  line-height: 1.72;
  color: var(--noche-800);
  margin: 0 0 24px;
  letter-spacing: -0.003em;
  text-wrap: pretty;
}

/* H2 — sección del artículo */
.prose__h2 {
  display: flex;
  align-items: center;
  gap: 16px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: clamp(24px, 2.4vw, 32px);
  line-height: 1.1;
  letter-spacing: -0.018em;
  color: var(--noche-800);
  margin: 56px 0 28px;
  text-wrap: balance;
}
.prose__h2-rule {
  width: 36px;
  height: 2px;
  background: var(--terracota-500);
  flex-shrink: 0;
  margin-top: 4px;
}

/* Pull quote — acento terracota */
.prose__quote {
  margin: 48px 0;
  padding: 0;
  border-left: 0;
  position: relative;
  text-align: left;
}
.prose__quote::before {
  content: "\201C";
  display: block;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 96px;
  line-height: 0.6;
  color: var(--terracota-400);
  margin-bottom: 14px;
  user-select: none;
}
.prose__quote p {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(22px, 2.2vw, 28px);
  line-height: 1.42;
  letter-spacing: -0.005em;
  color: var(--noche-800);
  margin: 0;
  text-wrap: balance;
  max-width: 30ch;
}

/* Scripture — pasaje bíblico citado */
.prose__scripture {
  margin: 36px 0;
  padding: 28px 32px;
  background: rgba(212, 158, 124, 0.08);
  border-left: 2px solid var(--dorado-500);
  position: relative;
}
.prose__scripture-text {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 17px;
  line-height: 1.62;
  color: var(--noche-800);
  margin: 0 0 12px;
  letter-spacing: -0.003em;
}
.prose__scripture-ref {
  display: block;
  font-family: var(--font-descriptor);
  font-weight: 800;
  font-style: normal;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--dorado-700);
}

/* --------------------------------------------------------------------------
   ARTICLE FOOTER — compartir + tags + firma + navegación
   -------------------------------------------------------------------------- */
.afoot {
  padding: 0 0 96px;
  border-top: 1px solid var(--rule);
  padding-top: 56px;
}
.afoot__share,
.afoot__tags {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 24px;
  align-items: center;
  margin-bottom: 32px;
}
.afoot__share-lbl,
.afoot__tags-lbl {
  font-family: var(--font-descriptor);
  font-weight: 800;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--niebla-600);
}
.afoot__share-row,
.afoot__tags-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.afoot__share-btn {
  font-family: var(--font-descriptor);
  font-weight: 800;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--noche-800);
  padding: 10px 14px;
  border: 1px solid var(--rule-strong);
  border-radius: 2px;
  text-decoration: none;
  background: transparent;
  cursor: pointer;
  line-height: 1;
  transition: background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
}
.afoot__share-btn:hover {
  background: var(--noche-800);
  color: var(--crema-50);
  border-color: var(--noche-800);
}
.afoot__share-btn--copy {
  color: var(--terracota-600);
  border-color: var(--terracota-400);
}
.afoot__share-btn--copy:hover {
  background: var(--terracota-500);
  color: var(--crema-50);
  border-color: var(--terracota-500);
}
.afoot__share-link-wrap {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 16px;
}
.afoot__share-link {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--noche-800);
  background: var(--crema-50);
  border: 1px solid var(--rule-strong);
  border-radius: 2px;
  padding: 12px 14px;
  width: 100%;
  box-sizing: border-box;
}
.afoot__share-link:focus {
  outline: none;
  border-color: var(--terracota-500);
  box-shadow: 0 0 0 3px var(--focus-ring);
}
.afoot__share-hint {
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--fg-subtle);
}
.afoot__tag {
  font-family: var(--font-descriptor);
  font-weight: 800;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  padding: 6px 11px;
  border-radius: 2px;
  background: var(--niebla-200);
  color: var(--niebla-700);
  text-decoration: none;
  transition: background var(--transition-fast);
}
.afoot__tag:hover { background: var(--niebla-300); }

/* Firma — separador editorial con logo */
.afoot__signature {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  margin: 64px 0;
  padding: 36px 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.afoot__signature-logo {
  width: 110px;
  height: 110px;
  margin-bottom: 6px;
}
.afoot__signature-name {
  font-family: var(--font-descriptor);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--noche-800);
}
.afoot__signature-tag {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 12.5px;
  color: var(--terracota-600);
  letter-spacing: 0.01em;
}

/* Navegación anterior/siguiente */
.afoot__nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
.afoot__nav-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 28px 24px;
  background: var(--crema-50);
  text-decoration: none;
  color: inherit;
  transition: background var(--transition-fast);
  position: relative;
}
.afoot__nav-card:hover { background: var(--crema-100); }
.afoot__nav-card--next { text-align: right; align-items: flex-end; }
.afoot__nav-card--empty {
  background: var(--niebla-200);
}
.afoot__nav-card--empty .afoot__nav-lbl { color: var(--niebla-700); }
.afoot__nav-card--empty .afoot__nav-title { color: var(--noche-700); }
.afoot__nav-card--empty .afoot__nav-num {
  font-style: normal;
  font-family: var(--font-descriptor);
  font-weight: 800;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--niebla-600);
}
.afoot__nav-card--empty:hover { background: var(--niebla-300); }
.afoot__nav-lbl {
  font-family: var(--font-descriptor);
  font-weight: 800;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--terracota-600);
}
.afoot__nav-title {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 17px;
  line-height: 1.25;
  letter-spacing: -0.012em;
  color: var(--noche-800);
  max-width: 24ch;
}
.afoot__nav-num {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 14px;
  color: var(--niebla-500);
}
.afoot__nav-num sup { font-size: 0.6em; margin-right: 1px; }

/* --------------------------------------------------------------------------
   RELATED — 3 posts relacionados al final
   -------------------------------------------------------------------------- */
.related {
  background: var(--noche-800);
  color: var(--crema-100);
  padding: 96px 0 110px;
}
.related__head {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 56px;
  padding-bottom: 24px;
  border-bottom: 1px solid rgba(245, 240, 232, 0.14);
}
.related__eb {
  font-family: var(--font-descriptor);
  font-weight: 800;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--terracota-400);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.related__eb::before {
  content: "";
  width: 28px;
  height: 1px;
  background: currentColor;
}
.related__title {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 38px;
  line-height: 1.04;
  letter-spacing: -0.022em;
  color: var(--crema-100);
  margin: 0;
  text-wrap: balance;
}
.related__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px 28px;
}

.rel-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: transform var(--transition-base);
}
.rel-card:hover { transform: translateY(-3px); }
.rel-card__media {
  position: relative;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  background: var(--noche-700);
  margin-bottom: 18px;
}
.rel-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 500ms cubic-bezier(.2,.6,.2,1);
}
.rel-card:hover .rel-card__media img { transform: scale(1.04); }
.rel-card--no-image .rel-card__media {
  background: radial-gradient(ellipse at 65% 50%, var(--noche-600), var(--noche-800) 75%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.rel-card__num {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(64px, 8vw, 100px);
  line-height: 0.85;
  color: rgba(212, 158, 124, 0.45);
}
.rel-card__num sup {
  font-size: 0.32em;
  margin-right: 5px;
  vertical-align: top;
  color: rgba(245, 240, 232, 0.3);
}
.rel-card__title {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 18px;
  line-height: 1.25;
  letter-spacing: -0.012em;
  color: var(--crema-100);
  margin: 0 0 10px;
  text-wrap: balance;
  transition: color var(--transition-fast);
}
.rel-card:hover .rel-card__title { color: var(--terracota-300); }
.rel-card__meta {
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--niebla-400);
  display: flex;
  flex-wrap: wrap;
  gap: 0 8px;
}
.rel-card__meta-sep { color: rgba(245, 240, 232, 0.25); }

/* --------------------------------------------------------------------------
   Responsivo
   -------------------------------------------------------------------------- */
@media (max-width: 900px) {
  .acover { min-height: clamp(480px, 80vh, 640px); }
  .acover__top { padding-top: 24px; padding-bottom: 24px; }
  .acover__title { font-size: clamp(36px, 9vw, 56px); }
  .acover__meta { gap: 10px; font-size: 10px; }
  .prose { padding: 56px 0 56px; }
  .prose .wrap--narrow { padding: 0 24px; }
  .afoot__share, .afoot__tags { grid-template-columns: 1fr; gap: 12px; }
  .afoot__nav { grid-template-columns: 1fr; }
  .afoot__nav-card--next { text-align: left; align-items: flex-start; }
  .related__grid { grid-template-columns: 1fr; gap: 32px; }
}
