/* =========================
   BLOG PAGE — CONSOLIDADO
   ========================= */
:root{
  --brand-green:#0db14b;
  --brand-green-2:#13c26a;
  --brand-magenta:#ff4370;
  --brand-fuchsia:#ff1f8b; /* solicitado */
  --ink-900:#0f172a; --ink-700:#334155; --ink-500:#64748b;
  --surface:#fff; --radius:16px; --shadow:0 6px 16px rgba(0,0,0,.08);
  --gap:24px;
}

/* ========== HERO ========== */
.nos-hero{
  position:relative; width:100%; min-height:62vh;
  padding:6rem 1rem 4rem; background-repeat:no-repeat;
  background-size:cover; background-position:center;
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center;
}
.nos-hero__overlay{ display:none; }
.nos-hero__logo{ width:370px; max-width:40vw; height:auto; margin:0 auto 1rem; }
.nos-hero__title{ margin:0; font-weight:700; font-size:clamp(1.8rem,2vw + 1.5rem,2.4rem); color:#fff; }
.nos-hero__endorse{
  position:absolute; left:2rem; bottom:2rem; z-index:2;
  display:inline-flex; flex-direction:column; gap:.25rem;
  background:rgba(255,255,255,.92); border-radius:10px; padding:.75rem 1rem; box-shadow:var(--shadow);
}
.nos-hero__endorse > span,.nos-endorse__caption{ font-size:.9rem; color:#777; font-style:italic; line-height:1; }
.nos-endorse__brand{ display:flex; align-items:center; gap:.5rem; }
.nos-hero__endorselogo,.nos-endorse__img{ height:22px; width:auto; }
@media (max-width:768px){
  .nos-hero__endorse{ left:1rem; bottom:1rem; transform:scale(.95); }
  .nos-hero__logo{ width:220px; }
}

/* ========== WRAP & INTRO ========== */
.blog-wrap{ max-width:1120px; margin:48px auto; padding:0 16px; }
.blog-intro{ font-size:1.05rem; color:var(--ink-700); margin-bottom:24px; }

/* ========== CHIPS (Orden/Categorías) ========== */
.blog-tags{
  display:flex; align-items:center; flex-wrap:wrap; gap:.5rem;
  margin:.75rem 0 1rem;
}
.blog-tags .chip-label{
  padding:.45rem .7rem; border-radius:9999px;
  background:#f1f5f9; border:1px solid #e2e8f0;
  color:#64748b; font-weight:700; line-height:1;
}

/* Base chip */
.blog-chip{
  --chip-bg:#fff; --chip-bd:#e2e8f0; --chip-ink:#0f172a;
  display:inline-flex; align-items:center; gap:.35rem;
  padding:.46rem .9rem; background:var(--chip-bg); color:var(--chip-ink);
  border:1px solid var(--chip-bd); border-radius:9999px; text-decoration:none;
  font-weight:700; line-height:1; transition:.2s ease; box-shadow:0 1px 0 rgba(15,23,42,.04);
}
.blog-chip:hover{ background:#f8fafc; border-color:#cbd5e1; transform:translateY(-1px); }
.blog-chip:focus-visible{ outline:none; box-shadow:0 0 0 3px rgba(13,177,75,.25); }

/* Variante inactiva */
.chip--ghost{ --chip-bg:#f8fafc; --chip-bd:#e2e8f0; --chip-ink:#0f172a; }

/* Activos por tipo: 
   - sort-chip => fucsia (pedido)
   - cat-chip  => verde de marca
*/
.sort-chip.is-active{
  background:linear-gradient(135deg,var(--brand-fuchsia), #ff6ab2);
  border-color:transparent; color:#fff;
  box-shadow:0 10px 26px rgba(255,31,139,.26);
}
.cat-chip.is-active{
  background:linear-gradient(135deg,var(--brand-green-2),var(--brand-green));
  border-color:transparent; color:#fff;
  box-shadow:0 10px 26px rgba(13,177,75,.22);
}

/* “Todas” como ghost activo (neutral oscuro) */
.chip--ghost.is-active{
  background:#111; color:#fff; border-color:#111;
  box-shadow:0 8px 22px rgba(17,17,17,.18);
}

/* ========== DESTACADOS ========== */
.blog-featured-list{ display:grid; gap:var(--gap); margin-bottom:var(--gap); }
.blog-featured{
  display:grid; grid-template-columns:1.1fr .9fr; gap:var(--gap); align-items:center;
  background:var(--surface); border-radius:var(--radius); box-shadow:var(--shadow);
  padding:16px;
}
.blog-featured__imgwrap{ display:block; border-radius:16px; overflow:hidden; aspect-ratio:16/9; background:#f1f5f9; }
.blog-featured__imgwrap img{ width:100%; height:100%; object-fit:cover; display:block; }
.blog-chip.badge{ background:var(--brand-magenta); } /* por si quieres otro badge */
.blog-featured__title{ font-size:clamp(22px,3vw,32px); margin:.25rem 0 .5rem; }
.blog-featured__excerpt{ color:var(--ink-700); margin:0 0 .5rem; }
.blog-link{ color:var(--brand-green); font-weight:700; text-decoration:none; }
@media (max-width:1024px){ .blog-featured{ grid-template-columns:1fr; } }

/* ========== GRID (NO destacados) ========== */
/* Fuerza 2 columnas en desktop y 1 en mobile. 
   Soporta .blog-grid, .blog-grid--two y .two-cols. */
.blog-grid,
.blog-grid.blog-grid--two,
.blog-grid.two-cols{
  display:grid; gap:var(--gap);
  grid-template-columns:repeat(2, minmax(0,1fr));
}
@media (max-width:768px){
  .blog-grid,
  .blog-grid.blog-grid--two,
  .blog-grid.two-cols{ grid-template-columns:1fr; }
}

.blog-card{
  background:#fff; border:1px solid #eef2f7;
  border-radius:.75rem; overflow:hidden;
  box-shadow:var(--shadow);
  display:flex; flex-direction:column;
}
.blog-card__imgwrap{ 
  position: relative;
  aspect-ratio: 16/9;
  background:#f1f5f9;
  overflow: hidden;
  border-top-left-radius: .75rem;
  border-top-right-radius: .75rem;
}
.blog-card__imgwrap img{
  width:100%;
  height:100% !important;   /* <- anula cualquier height:200px previo */
  object-fit:cover;
  display:block;
}
.blog-card__body{ padding:14px; }
.blog-card__title{ font-size:1.08rem; margin:.2rem 0 .35rem; }
.blog-card__excerpt{ color:var(--ink-700); margin:0 0 .4rem; }
.blog-meta{ color:var(--ink-500); font-size:.9rem; margin:.1rem 0 .5rem; }

.card-cat{
  position:absolute; top:10px; left:10px; z-index:2;
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.35rem .6rem; border-radius:999px;
  background:linear-gradient(135deg,#ff1f8b,#ff6ab2); /* fucsia solicitado */
  color:#fff; font-weight:700; font-size:.76rem; line-height:1; letter-spacing:.01em;
  box-shadow:0 8px 18px rgba(255,31,139,.22);
}
.card-cat svg{ width:14px; height:14px; opacity:.9; }

/* ========== RELACIONADOS (detalle) ========== */
.related-wrap{ margin:2rem 0 0; }
.related-grid{
  list-style:none; padding:0; margin:.6rem 0 0;
  display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:.75rem;
}
.related-grid a{ display:block; padding:.6rem .75rem; border:1px solid #e2e8f0; border-radius:.5rem; }

/* ========== ACCESIBILIDAD PEQUEÑOS DETALLES ========== */
.blog-chip svg{ width:14px; height:14px; opacity:.9; }
.blog-chip.is-active svg{ opacity:1; filter:brightness(1.1); }


/* =========================
   SINGLE POST — CONSOLIDADO
   ========================= */

.post-layout{
  max-width: 1200px;
  margin: 0 auto 56px;
  padding: 50px 16px;
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 36px;
  align-items: start;
}
@media (max-width: 1100px){ .post-layout{ grid-template-columns: 320px 1fr; } }
@media (max-width: 992px){  .post-layout{ grid-template-columns: 1fr; } }

.post-aside{ position: sticky; top: 96px; align-self: start; }
.aside-heading{
  font-size: 1.35rem; font-weight: 900; letter-spacing: .02em;
  color: #111827; text-transform: uppercase; margin: 6px 0 10px;
}
.aside-heading--bar{ position: relative; padding-bottom: 8px; }
.aside-heading--bar::after{
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 3px;
  background: #ff1f8b; border-radius: 999px;
}
.aside-heading--spaced{ margin-top: 26px; }

.aside-list.textual{ list-style: none; padding: 0; margin: 10px 0 0; }
.aside-item{ padding: 14px 0; border-bottom: 1px solid #e5e7eb; }
.aside-link{ text-decoration: none; display: block; color: inherit; }
.aside-title{
  display: block; font-weight: 900; font-size: 1.35rem;
  color: #111827; line-height: 1.2;
}
.aside-excerpt{ display: block; margin: .45rem 0 .35rem; color: #4b5563; font-size: 1rem; }
.aside-source{ display: block; color: #9ca3af; font-weight: 700; font-size: .95rem; }
.aside-empty{ color: #9ca3af; padding: 8px 0; }

/* ===== 2) COLUMNA DERECHA (MAIN) ===== */
.post-main{ min-width: 0; } /* evita overflow en grid */

/* HERO dentro del main (una sola definición) */
.post-main .post-hero{
  position: relative; overflow: hidden; min-height: 38vh;
  border-radius: 22px;
  box-shadow: var(--shadow, 0 12px 36px rgba(0,0,0,.12));
  background: #0b1b12;
}
/* Oculta el título dentro del héroe (faja) */
.post-main .post-hero .post-ribbon{ display:none; }

/* Título debajo de la meta, centrado */
.post-title-below{
  margin: 10px auto 18px;
  max-width: 920px;
  text-align: center;

  font-weight: 900;
  letter-spacing: -.02em;
  color: #ff1f8b;
  font-size: clamp(24px, 2.6vw, 42px);
  line-height: 1.15;
  text-wrap: balance;       
  overflow-wrap: anywhere;
  word-break: normal;
  hyphens: auto;
}
@media (max-width: 768px){
  .post-title-below{ font-size: clamp(22px, 5vw, 32px); }
}

.post-hero__bg{ position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.post-hero__overlay{
  position: absolute; inset: 0;
  background:
    radial-gradient(90% 70% at 50% 0%, rgba(0,0,0,.10), rgba(0,0,0,.40)),
    linear-gradient(to bottom, rgba(0,0,0,.0) 0%, rgba(0,0,0,.35) 65%, rgba(0,0,0,.6) 100%);
}
.post-hero__content{ position: relative; z-index: 2; width: 100%; height: 100%; }

/* Faja magenta del título */
.post-ribbon{
  position: absolute; left: 18px; bottom: 18px;
  background: linear-gradient(135deg,#ff1f8b,#ff6ab2);
  color: #fff; padding: 12px 16px; border-radius: 12px;
  box-shadow: 0 12px 24px rgba(255,31,139,.24);
  max-width: calc(100% - 36px);
}
.post-title{ margin: 0; font-weight: 900; letter-spacing: -.02em; font-size: clamp(22px, 2vw + 1rem, 34px); }

/* Meta bajo el hero */
.post-meta-row{
  color: #4b5563; display: flex; align-items: center; gap: .65rem; font-weight: 700;
  margin: 10px 0 6px;
}
.post-meta-dot{ opacity: .5; }
.post-meta-cat{ color: #ff1f8b; }

/* Cuerpo y footer */
.post-body{ color: #1f2937; line-height: 1.9; font-size: 1.06rem; }
.post-body img{ border-radius: 16px; box-shadow: var(--shadow, 0 6px 16px rgba(0,0,0,.08)); }

.post-footer{ margin-top: 22px; }
.post-footer .blog-link{
  display: inline-flex; align-items: center; gap: .55rem; font-weight: 900;
  color: var(--brand-green, #0db14b); text-decoration: none; transition: color .2s ease;
}
.post-footer .blog-link:hover{ color: #ff1f8b; }

/* ===== 3) RESPONSIVE ===== */
@media (max-width: 768px){
  .post-main .post-hero{ min-height: 32vh; border-radius: 18px; }
  .post-ribbon{ left: 12px; bottom: 12px; max-width: calc(100% - 24px); }
}


/* ====== Animaciones suaves ====== */
.reveal{
  opacity:0;
  transform:translateY(16px);
  transition:opacity .5s ease, transform .5s ease;
  transition-delay: calc(var(--i, 0) * 60ms);
  will-change: opacity, transform;
}
.reveal.is-in{ opacity:1; transform:none; }

/* Respeta accesibilidad */
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
}

/* ====== Badge de categoría en cards (BlogPage) ====== */
.blog-card__imgwrap{ position:relative; } /* asegura posicionamiento */
.blog-badge{
  position:absolute; top:10px; left:10px; z-index:2;
  padding:.35rem .6rem; border-radius:999px;
  font-weight:800; font-size:.78rem; color:#fff;
  background:var(--cat-default, #ff1f8b);
  box-shadow:0 8px 22px rgba(0,0,0,.14);
}

/* Mapa de colores por categoría (ajusta a tus keys reales) */
:root{
  --cat-noticias:#0ea5e9;
  --cat-eventos:#22c55e;
  --cat-novedades:#a855f7;
  --cat-tags:#f59e0b;
  --cat-default:#ff1f8b; /* fucsia por defecto */
}
.blog-badge--noticias{ background:var(--cat-noticias); }
.blog-badge--eventos{  background:var(--cat-eventos); }
.blog-badge--novedades{background:var(--cat-novedades); }
.blog-badge--tags{     background:var(--cat-tags); }

/* ====== Breadcrumbs (detalle) ====== */
.crumbs{ margin:8px 0 12px; font-size:.92rem; color:#64748b; }
.crumbs ol{ list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap:.5rem; }
.crumbs li{ display:flex; align-items:center; gap:.5rem; }
.crumbs li+li::before{ content:"/"; opacity:.45; }
.crumbs a{ color:#0f172a; text-decoration:none; font-weight:700; }
.crumbs a:hover{ color:#ff1f8b; }

/* ====== Color por categoría en meta (detalle) ====== */
.post-main .post-meta-cat{ color: var(--cat-color, #ff1f8b); }
.post-main.cat-noticias { --cat-color: var(--cat-noticias); }
.post-main.cat-eventos  { --cat-color: var(--cat-eventos); }
.post-main.cat-novedades{ --cat-color: var(--cat-novedades); }
.post-main.cat-tags     { --cat-color: var(--cat-tags); }
/* 2 columnas para la grilla de artículos NO destacados (1 en mobile) */
.blog-grid.blog-grid--two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2rem;
}
@media (max-width: 768px) {
  .blog-grid.blog-grid--two { grid-template-columns: 1fr; }
}

/* ====== Sección ¡NO TE PIERDAS DE NUESTRAS ÚLTIMAS NOVEDADES! ====== */
.nl-section{ margin:56px auto 24px; padding:0 16px; }
.nl-container{
  max-width:1120px; margin:0 auto; display:grid; gap:24px;
  grid-template-columns: 1fr 1.2fr; align-items:center;
  background:#fff; border-radius:18px;
  overflow:hidden;
}
.nl-media{ padding:16px; display:flex; align-items:flex-end; justify-content:center; }
.nl-media img{ max-width:100%; height:auto; display:block; }
.nl-formwrap{ padding:28px 28px 32px; }
.nl-title{
  margin:0 0 4px; text-align:center; font-weight:900;
  color:#ff1f8b; font-size: clamp(22px, 2.4vw, 34px); letter-spacing:.02em;
}
.nl-sub{ margin:0 0 18px; text-align:center; color:#475569; font-weight:700; }
.nl-form{ display:grid; gap:14px; }
.nl-field label{ display:block; font-weight:800; color:#111827; margin:6px 0; }
.nl-field input{
  width:100%; border:0; background:#f1f1f1; border-radius:12px;
  padding:16px 14px; font-size:1rem; outline:none;
}
.nl-field input:focus{ box-shadow:0 0 0 3px rgba(255,31,139,.2); background:#f8f8f8; }
.nl-btn{
  width:100%; border:0; border-radius:12px; padding:16px 18px; font-weight:900;
  background:#86cf6b; color:#fff; cursor:pointer; box-shadow:0 8px 18px rgba(134,207,107,.35);
}
.nl-btn:hover{ filter:brightness(1.03); transform:translateY(-1px); }
.nl-msg{ margin:10px 0 0; text-align:center; font-weight:700; }
@media (max-width: 900px){
  .nl-container{ grid-template-columns: 1fr; }
  .nl-media{ order:2; }
}

/* ===== Modales (reutilizables) ===== */

/* Contenedores del <dialog> */
#nl-modal,
#lead-modal{
  position: fixed;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  border: 0;
  padding: 0;
  border-radius: var(--radius);
  max-width: 520px;
  width: min(92%, 520px);
  background: var(--surface);
  color: var(--ink-900);
  box-shadow: var(--shadow);
  overflow: hidden;
}

/* Contenido interno */
.nl-modal-content,
.lead-modal-content{ padding: var(--gap); }

.nl-modal-title,
.lead-modal-title{
  margin: 0 0 8px;
  font-size: 1.25rem;
  line-height: 1.25;
  font-weight: 700;
  color: var(--ink-900);
}

.nl-modal-text,
.lead-modal-text{
  margin: 0 0 16px;
  line-height: 1.55;
  font-size: 1rem;
  color: var(--ink-700);
}

.nl-modal-actions,
.lead-modal-actions{
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

/* Botones dentro del modal */
#nl-modal .nl-btn,
#lead-modal .nl-btn{
  border-radius: 9999px;
  padding: 10px 16px;
  font-weight: 600;
  border: 1px solid transparent;
  background: var(--brand-green);
  color: #fff;
  transition: transform .12s ease, opacity .12s ease, background .12s ease, border-color .12s ease;
}
#nl-modal .nl-btn:hover,
#lead-modal .nl-btn:hover{ background: var(--brand-green-2); }
#nl-modal .nl-btn:active,
#lead-modal .nl-btn:active{ transform: translateY(1px); }
#nl-modal .nl-btn[disabled],
#lead-modal .nl-btn[disabled]{ opacity: .6; cursor: not-allowed; }

/* Variante “ghost” opcional para botones secundarios */
#nl-modal .nl-btn--ghost,
#lead-modal .nl-btn--ghost{
  background: transparent;
  color: var(--ink-900);
  border-color: rgba(0,0,0,.12);
}
#nl-modal .nl-btn--ghost:hover,
#lead-modal .nl-btn--ghost:hover{
  background: rgba(0,0,0,.04);
}

/* Backdrop: overlay + blur */
#nl-modal::backdrop,
#lead-modal::backdrop{
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(3px);
}

/* Animación de entrada (respeta reduce motion) */
@keyframes nl-fade-scale{
  from{ opacity: 0; transform: translate(-50%, -48%) scale(.98); }
  to{   opacity: 1; transform: translate(-50%, -50%) scale(1); }
}
#nl-modal[open],
#lead-modal[open]{ animation: nl-fade-scale .18s ease-out; }
@media (prefers-reduced-motion: reduce){
  #nl-modal[open],
  #lead-modal[open]{ animation: none; }
}

/* Desenfoque del fondo cuando el modal está abierto */
body.nl-blur > *:not(#nl-modal):not(#lead-modal){
  filter: blur(4px);
  transition: filter .2s ease;
  pointer-events: none;
  user-select: none;
}

/* ===== Responsivo ===== */
@media (max-width: 640px){
  #nl-modal,
  #lead-modal{ width: min(94%, 520px); border-radius: calc(var(--radius) - 2px); }
  .nl-modal-content,
  .lead-modal-content{ padding: 16px; }
  .nl-modal-title,
  .lead-modal-title{ font-size: 1.125rem; }
  .nl-modal-text,
  .lead-modal-text{ font-size: .95rem; margin-bottom: 12px; }
  .nl-modal-actions,
  .lead-modal-actions{ flex-direction: column; gap: 8px; }
  #nl-modal .nl-btn,
  #lead-modal .nl-btn{ width: 100%; padding: 12px 16px; }
}

/* Ultra-compacto (<=375px) */
@media (max-width: 375px){
  .nl-modal-title,
  .lead-modal-title{ font-size: 1.05rem; }
  .nl-modal-text,
  .lead-modal-text{ font-size: .93rem; }
}
