/* Reporte Iglesias — Tema editorial
   Paleta: Crema #F5F0E8 · Tinta #1A1814 · Rojo óxido #8B2500
   Tipografía: Playfair Display · Source Serif 4 · IBM Plex Mono */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Source+Serif+4:opsz,wght@8..60,300;8..60,400;8..60,600&family=IBM+Plex+Mono:wght@400;500&display=swap');

/* ─── Variables ─── */
:root {
  --papel: #F5F0E8;
  --tinta: #1A1814;
  --acento: #8B2500;
  --gris: #7A7060;
  --borde: #C8BEA8;
  --superficie: #EDE8DF;

  --font-display: 'Playfair Display', Georgia, serif;
  --font-body: 'Source Serif 4', Georgia, serif;
  --font-mono: 'IBM Plex Mono', monospace;

  --max-width: 720px;
  --max-width-wide: 1100px;
}

/* ─── Reset base ─── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 18px; -webkit-font-smoothing: antialiased; }

body {
  background: var(--papel);
  color: var(--tinta);
  font-family: var(--font-body);
  font-weight: 300;
  line-height: 1.8;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--acento); }

/* ─── Header ─── */
.site-header {
  border-top: 3px solid var(--tinta);
  border-bottom: 1px solid var(--borde);
  padding: 1.5rem 2rem;
  text-align: center;
  background: var(--papel);
}

.site-header-inner {
  max-width: var(--max-width-wide);
  margin: 0 auto;
}

.site-kicker {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gris);
  margin-bottom: 0.5rem;
}

.site-title {
  font-family: var(--font-display);
  font-size: 2.8rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--tinta);
  margin-bottom: 0.4rem;
}

.site-title a { color: inherit; }
.site-title a:hover { color: var(--tinta); }

.site-rule {
  width: 48px;
  height: 2px;
  background: var(--tinta);
  margin: 0.6rem auto;
}

.site-description {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  color: var(--gris);
  font-style: italic;
}

/* ─── Navegación ─── */
.site-nav {
  border-bottom: 1px solid var(--borde);
  padding: 0.6rem 2rem;
  background: var(--papel);
}

.site-nav-inner {
  max-width: var(--max-width-wide);
  margin: 0 auto;
  display: flex;
  justify-content: center;
  gap: 2rem;
  list-style: none;
}

.site-nav-item a {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gris);
  transition: color 0.15s;
}

.site-nav-item a:hover { color: var(--acento); }

/* ─── Layout principal ─── */
.site-main {
  max-width: var(--max-width-wide);
  margin: 0 auto;
  padding: 2.5rem 2rem;
}

/* ─── Feed de posts ─── */
.post-feed {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

/* Post destacado (primero) */
.post-card:first-child {
  border-bottom: 2px solid var(--tinta);
  padding-bottom: 2rem;
  margin-bottom: 2rem;
}

.post-card:first-child .post-card-title {
  font-size: 2rem;
}

/* Posts normales */
.post-card {
  display: grid;
  grid-template-columns: 1fr;
  border-bottom: 1px solid var(--borde);
  padding: 1.5rem 0;
}

.post-card-tag {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--acento);
  margin-bottom: 0.4rem;
  display: block;
}

.post-card-title {
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--tinta);
  margin-bottom: 0.5rem;
}

.post-card-title a { color: inherit; }
.post-card-title a:hover { color: var(--acento); }

.post-card-excerpt {
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 300;
  color: var(--gris);
  line-height: 1.6;
  margin-bottom: 0.75rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.post-card-meta {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  color: var(--gris);
}

/* ─── Artículo individual ─── */
.article-header {
  max-width: var(--max-width);
  margin: 0 auto 2rem;
  padding: 2rem 0 1.5rem;
  border-bottom: 1px solid var(--borde);
}

.article-tag {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--acento);
  display: block;
  margin-bottom: 0.75rem;
}

.article-title {
  font-family: var(--font-display);
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--tinta);
  margin-bottom: 1rem;
}

.article-meta {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  color: var(--gris);
}

.article-meta span { margin-right: 1rem; }

/* ─── Contenido del artículo ─── */
.article-content {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 2rem 0 3rem;
}

.article-content p {
  margin-bottom: 1.4rem;
  font-size: 1rem;
  line-height: 1.85;
}

.article-content h2 {
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--tinta);
  margin: 2.5rem 0 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--borde);
}

.article-content h3 {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--tinta);
  margin: 2rem 0 0.75rem;
}

.article-content blockquote {
  border-left: 3px solid var(--acento);
  margin: 2rem 0;
  padding: 0.5rem 0 0.5rem 1.5rem;
  font-style: italic;
  color: var(--gris);
}

.article-content a {
  color: var(--acento);
  border-bottom: 1px solid var(--borde);
}

.article-content a:hover {
  border-bottom-color: var(--acento);
}

.article-content strong {
  font-weight: 600;
  color: var(--tinta);
}

/* ─── Imagen de portada ─── */
.article-image {
  max-width: var(--max-width-wide);
  margin: 0 auto 2rem;
}

.article-image img {
  width: 100%;
  max-height: 480px;
  object-fit: cover;
}

.article-image figcaption {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.08em;
  color: var(--gris);
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--borde);
}

/* ─── Footer ─── */
.site-footer {
  border-top: 2px solid var(--tinta);
  padding: 2rem;
  text-align: center;
  margin-top: 3rem;
}

.site-footer-inner {
  max-width: var(--max-width-wide);
  margin: 0 auto;
}

.site-footer-name {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--tinta);
  margin-bottom: 0.4rem;
}

.site-footer-meta {
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  color: var(--gris);
}

/* ─── Paginación ─── */
.pagination {
  display: flex;
  justify-content: center;
  gap: 1rem;
  padding: 2rem 0;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.1em;
}

.pagination a {
  color: var(--gris);
  border-bottom: 1px solid var(--borde);
  padding-bottom: 2px;
}

.pagination a:hover { color: var(--acento); border-bottom-color: var(--acento); }

/* ─── Ghost Card clases requeridas ─── */
.kg-width-wide {
  margin-left: calc(50% - 50vw + 2rem);
  margin-right: calc(50% - 50vw + 2rem);
  max-width: 1000px;
}

.kg-width-full {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  max-width: 100vw;
}

.kg-image { max-width: 100%; }

.kg-image-card { margin: 1.5rem 0; }
.kg-image-card img { margin: 0 auto; }

.kg-gallery-container { display: flex; flex-direction: column; }
.kg-gallery-row { display: flex; flex-direction: row; justify-content: center; gap: 4px; margin: 0 0 4px; }
.kg-gallery-image { flex: 1 1 auto; overflow: hidden; }
.kg-gallery-image img { width: 100%; height: 100%; object-fit: cover; }

.kg-bookmark-card { border: 1px solid var(--borde); border-radius: 4px; overflow: hidden; margin: 1.5rem 0; }
.kg-bookmark-container { display: flex; }
.kg-bookmark-content { padding: 1rem; flex: 1; }
.kg-bookmark-title { font-family: var(--font-display); font-weight: 700; font-size: 0.95rem; margin-bottom: 0.25rem; }
.kg-bookmark-description { font-size: 0.8rem; color: var(--gris); }
.kg-bookmark-thumbnail { width: 160px; flex-shrink: 0; }
.kg-bookmark-thumbnail img { width: 100%; height: 100%; object-fit: cover; }

.kg-callout-card { display: flex; gap: 1rem; padding: 1.25rem; border-left: 3px solid var(--acento); background: var(--superficie); margin: 1.5rem 0; border-radius: 0 4px 4px 0; }
.kg-callout-emoji { font-size: 1.2rem; }
.kg-callout-text { font-size: 0.95rem; }

.kg-toggle-card { border: 1px solid var(--borde); border-radius: 4px; padding: 1rem; margin: 1.5rem 0; }
.kg-toggle-heading { font-family: var(--font-display); font-weight: 700; }
.kg-toggle-content { margin-top: 0.5rem; font-size: 0.9rem; color: var(--gris); }

.kg-video-card { margin: 1.5rem 0; }
.kg-video-card video { width: 100%; border-radius: 4px; }

.kg-audio-card { border: 1px solid var(--borde); border-radius: 4px; padding: 1rem; margin: 1.5rem 0; }

.kg-product-card { border: 1px solid var(--borde); border-radius: 4px; padding: 1.5rem; margin: 1.5rem 0; }
.kg-product-card-title { font-family: var(--font-display); font-weight: 700; font-size: 1.1rem; margin-bottom: 0.5rem; }

.kg-header-card { padding: 3rem 2rem; text-align: center; background: var(--tinta); color: var(--papel); margin: 1.5rem 0; }
.kg-header-card-heading { font-family: var(--font-display); font-size: 2rem; font-weight: 700; }
.kg-header-card-subheading { margin-top: 0.5rem; font-size: 0.9rem; opacity: 0.7; }

.kg-button-card { text-align: center; margin: 1.5rem 0; }
.kg-btn { display: inline-block; padding: 0.6rem 1.5rem; background: var(--tinta); color: var(--papel); font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; border-radius: 2px; }
.kg-btn:hover { background: var(--acento); color: var(--papel); }

.kg-divider-card { border: none; border-top: 1px solid var(--borde); margin: 2rem 0; }

.kg-code-card { margin: 1.5rem 0; }
.kg-code-card pre { background: var(--tinta); color: var(--papel); padding: 1.25rem; border-radius: 4px; overflow-x: auto; font-family: var(--font-mono); font-size: 0.8rem; line-height: 1.6; }

/* ─── Members / signup ─── */
.gh-subscribe { text-align: center; padding: 2rem; background: var(--superficie); border: 1px solid var(--borde); border-radius: 4px; margin: 2rem 0; }
.gh-subscribe-title { font-family: var(--font-display); font-size: 1.4rem; font-weight: 700; margin-bottom: 0.5rem; }
.gh-subscribe-description { font-size: 0.9rem; color: var(--gris); margin-bottom: 1rem; }
.gh-subscribe-input { display: flex; gap: 0.5rem; max-width: 400px; margin: 0 auto; }
.gh-subscribe-input input { flex: 1; padding: 0.5rem 0.75rem; border: 1px solid var(--borde); background: var(--papel); font-family: var(--font-body); font-size: 0.9rem; border-radius: 2px; }
.gh-subscribe-input button { padding: 0.5rem 1rem; background: var(--tinta); color: var(--papel); font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; border: none; cursor: pointer; border-radius: 2px; }
.gh-subscribe-input button:hover { background: var(--acento); }
@media (min-width: 768px) {
  .post-feed {
    grid-template-columns: 1fr 1fr;
    gap: 0 3rem;
  }

  .post-card:first-child {
    grid-column: 1 / -1;
  }

  .article-title { font-size: 3rem; }
}

@media (max-width: 640px) {
  .site-title { font-size: 2rem; }
  .article-title { font-size: 1.8rem; }
  .site-main { padding: 1.5rem 1rem; }
  .site-header { padding: 1.2rem 1rem; }
}
