/* ================================================================
   DEKEVA — blog.css
   Estilos sobrios para single, archive, page y 404.
   Comparte variables/header/footer con core.css NO se carga en blog
   (el blog usa fuentes y un sistema más editorial sin GSAP).
================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Inter:wght@300;400;500&display=swap');

:root {
  --bg:        #ffffff;
  --bg-soft:   #f5f5f3;
  --text:      #0d0d0b;
  --muted:     #999894;
  --border:    rgba(13,13,11,0.08);
  --blue:      #032FD4;
  --f-display: 'Cormorant Garamond', Georgia, serif;
  --f-body:    'Inter', system-ui, sans-serif;
  --cont:      min(960px, 92vw);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg); color: var(--text);
  font-family: var(--f-body); font-weight: 300;
  font-size: 17px; line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; transition: color 0.3s; }
a:hover { color: var(--blue); }
img { display: block; max-width: 100%; height: auto; }

.cont { width: var(--cont); margin-inline: auto; }

/* ── Header simplificado ─────────────────────────────────────── */
#site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(255,255,255,0.94);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
  padding: 1.1rem 0;
}
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  width: var(--cont); margin-inline: auto;
}
.logo {
  display: inline-flex; align-items: center;
  font-size: 0; line-height: 0;
}
.logo img {
  display: block; height: 32px; width: auto;
  transition: opacity .4s ease;
}
.logo:hover img { opacity: .75; }
@media (max-width: 800px) { .logo img { height: 26px; } }
.nav-main { display: flex; gap: 2rem; }
.nav-link {
  font-size: 10px; font-weight: 400;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--muted); transition: color 0.3s;
}
.nav-link:hover, .nav-link.is-active { color: var(--text); }

.btn-nav {
  font-size: 10px; font-weight: 400;
  letter-spacing: 0.18em; text-transform: uppercase;
  padding: 0.65rem 1.6rem;
  background: var(--blue); border: 1px solid var(--blue); color: #fff;
  transition: background 0.3s, color 0.3s;
}
.btn-nav:hover { background: transparent; color: var(--blue); }

.burger { display: none; }
.offcanvas, .offcanvas-overlay { display: none; }

/* ── Layout principal ────────────────────────────────────────── */
.blog-main { padding: 5rem 0; min-height: 60vh; }

/* ── Archivo / listado ───────────────────────────────────────── */
.blog-archive__head { margin-bottom: 4rem; text-align: center; }
.blog-archive__eyebrow {
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--blue); margin-bottom: 1rem;
}
.blog-archive__title {
  font-family: var(--f-display); font-weight: 300;
  font-size: clamp(2.5rem, 5vw, 4rem); line-height: 1.05;
  letter-spacing: -0.02em;
}
.blog-archive__desc { color: var(--muted); margin-top: 1rem; }

.blog-archive__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 3rem 2rem;
}
.blog-card { border-bottom: 1px solid var(--border); padding-bottom: 2rem; }
.blog-card__media {
  margin-bottom: 1.2rem; aspect-ratio: 16/10; overflow: hidden;
  background: var(--bg-soft);
}
.blog-card__media img { width: 100%; height: 100%; object-fit: cover; }
.blog-card__meta {
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--muted); margin-bottom: 0.6rem;
}
.blog-card__title {
  font-family: var(--f-display); font-weight: 400;
  font-size: 1.55rem; line-height: 1.2;
  margin-bottom: 0.6rem; transition: color 0.3s;
}
.blog-card__link:hover .blog-card__title { color: var(--blue); }
.blog-card__excerpt { color: var(--muted); font-size: 0.95rem; }

.blog-archive__pagination {
  margin-top: 5rem; display: flex; justify-content: center; gap: 0.6rem;
}
.blog-archive__pagination .page-numbers {
  padding: 0.6rem 1rem; border: 1px solid var(--border);
  font-size: 13px; letter-spacing: 0.1em;
  transition: background 0.3s, color 0.3s;
}
.blog-archive__pagination .current,
.blog-archive__pagination a:hover { background: var(--blue); color: #fff; border-color: var(--blue); }

/* ── Post individual ─────────────────────────────────────────── */
.blog-single { max-width: 760px; margin-inline: auto; }
.blog-single__head { margin-bottom: 3rem; text-align: center; }
.blog-single__meta {
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--blue); margin-bottom: 1.2rem;
}
.blog-single__title {
  font-family: var(--f-display); font-weight: 400;
  font-size: clamp(2.2rem, 4.5vw, 3.5rem); line-height: 1.1;
  letter-spacing: -0.02em;
}
.blog-single__excerpt {
  color: var(--muted); font-size: 1.15rem;
  font-family: var(--f-display); font-style: italic; font-weight: 300;
  margin-top: 1.5rem;
}
.blog-single__media { margin-bottom: 3rem; }
.blog-single__body {
  font-size: 1.08rem; line-height: 1.85;
}
.blog-single__body > * + * { margin-top: 1.4em; }
.blog-single__body h2 {
  font-family: var(--f-display); font-weight: 400;
  font-size: 2rem; line-height: 1.2;
  margin-top: 2.5em; margin-bottom: 0.6em;
}
.blog-single__body h3 {
  font-family: var(--f-display); font-weight: 400;
  font-size: 1.45rem; margin-top: 2em; margin-bottom: 0.4em;
}
.blog-single__body a { color: var(--blue); border-bottom: 1px solid currentColor; }
.blog-single__body blockquote {
  border-left: 2px solid var(--blue); padding-left: 1.5rem;
  font-family: var(--f-display); font-style: italic; font-size: 1.3rem;
  color: var(--text); margin: 2.5em 0;
}
.blog-single__body code {
  background: var(--bg-soft); padding: 0.15em 0.4em;
  font-family: 'JetBrains Mono', monospace; font-size: 0.9em;
}
.blog-single__body pre {
  background: var(--bg-soft); padding: 1.5rem; overflow-x: auto;
  font-family: 'JetBrains Mono', monospace; font-size: 0.85rem;
}
.blog-single__body img { margin: 2em 0; }
.blog-single__body ul, .blog-single__body ol { padding-left: 1.5em; }
.blog-single__body li + li { margin-top: 0.4em; }

.blog-single__foot {
  margin-top: 4rem; padding-top: 2rem; border-top: 1px solid var(--border);
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 2rem;
}
.blog-tag-label { color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: 0.14em; margin-right: 0.5em; }
.blog-single__nav { display: flex; gap: 2rem; font-size: 0.9rem; color: var(--muted); }

/* ── Page (legales, etc.) ────────────────────────────────────── */
.blog-page { max-width: 760px; margin-inline: auto; }
.blog-page__title {
  font-family: var(--f-display); font-weight: 400;
  font-size: clamp(2rem, 4vw, 3rem); line-height: 1.15;
  margin-bottom: 2.5rem;
}
.blog-page__body { font-size: 1.05rem; line-height: 1.8; }
.blog-page__body > * + * { margin-top: 1.4em; }

/* ── 404 ─────────────────────────────────────────────────────── */
.blog-404 { text-align: center; padding: 6rem 0; }
.blog-404__code {
  font-family: var(--f-display); font-style: italic; font-weight: 300;
  font-size: clamp(6rem, 14vw, 11rem); line-height: 1;
  color: var(--blue); opacity: 0.4; margin-bottom: 1rem;
}
.blog-404__title {
  font-family: var(--f-display); font-weight: 400;
  font-size: clamp(2rem, 4vw, 3rem); margin-bottom: 1rem;
}
.blog-404__sub { color: var(--muted); margin-bottom: 2.5rem; }
.blog-404 .btn-cta-final {
  display: inline-flex; align-items: center;
  font-size: 10px; font-weight: 400;
  letter-spacing: 0.2em; text-transform: uppercase;
  padding: 1.1rem 2.8rem;
  background: var(--blue); color: #fff;
  border: 1px solid var(--blue);
  transition: background 0.3s, color 0.3s;
}
.blog-404 .btn-cta-final:hover { background: transparent; color: var(--blue); }

/* ── Footer (heredamos del core en realidad — pero por si acaso) ── */
.site-footer {
  background: var(--text); color: rgba(255,255,255,0.6);
  padding: 4rem 0 2rem; margin-top: 6rem;
  position: relative; overflow: hidden;
}
.footer-inner { width: var(--cont); margin-inline: auto; position: relative; z-index: 1; }
.footer-top {
  display: grid; grid-template-columns: 1.5fr repeat(3, 1fr);
  gap: 3rem; margin-bottom: 3rem;
}
.footer-brand .footer-logo {
  font-family: var(--f-display); font-size: 1.3rem;
  letter-spacing: 0.32em; text-transform: uppercase; color: #fff;
}
.footer-tagline { margin-top: 1rem; color: rgba(255,255,255,0.45); font-size: 0.9rem; line-height: 1.6; }
.footer-col-title {
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.4); margin-bottom: 1rem;
}
.footer-links { display: flex; flex-direction: column; gap: 0.6rem; }
.footer-link { font-size: 0.9rem; color: rgba(255,255,255,0.65); transition: color 0.3s; }
.footer-link:hover { color: #fff; }
.footer-link.is-active { color: var(--blue); }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.08); padding-top: 1.5rem;
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem;
  font-size: 11px; color: rgba(255,255,255,0.4); letter-spacing: 0.06em;
}
.footer-bg-word {
  position: absolute; bottom: -20%; left: 50%; transform: translateX(-50%);
  font-family: var(--f-display); font-style: italic; font-weight: 200;
  font-size: 30vw; color: rgba(255,255,255,0.025); pointer-events: none; line-height: 1;
}

@media (max-width: 800px) {
  .footer-top { grid-template-columns: 1fr; }
  .nav-main { display: none; }
}
