/* ===============================
   Blog – Estilos completos
   Tema oscuro + responsive
   =============================== */

/* Variables base */
:root{
  --color-primary:#181818;
  --color-secondary:#25d366;
  --color-light:#fff;
  --color-muted:#ddd;
  --color-dimmer:#bdbdbd;
  --color-card:#222;
  --color-card-alt:#1b1b1b;
  --border:#2b2b2b;
  --shadow:0 6px 22px rgba(0,0,0,.35);
  --radius:14px;
  --radius-sm:10px;
  --gap:1.2rem;
  --font:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;
}

/* Layout base */
body{background:#111;color:#eee;font-family:var(--font);line-height:1.6;}
.container{width:95%;max-width:1100px;margin:0 auto;}
.blog-main{padding-top:80px;} /* si tu header es fixed */

/* ---------- Hero ---------- */
.blog-hero{
  text-align:center;
  padding:.8rem 1rem .6rem;
  margin-top:-.4rem;
}
.blog-hero h1{
  font-weight:700;
  font-size:1.9rem;
  color:var(--color-light);
  margin-bottom:.25rem;
  letter-spacing:.5px;
}
.blog-hero p{
  color:#cfcfcf;
  font-size:.95rem;
  opacity:.9;
  margin-top:0;
}

/* =================================
   DESTACADO (post más reciente)
   ================================= */
.blog-featured{padding:1.2rem 0;}
/* En desktop: imágenes arriba y texto debajo (stack vertical limpio) */
.blog-featured-card{
  display:grid;
  grid-template-columns:1fr;
  grid-auto-rows:auto;
  gap:0;
  background:var(--color-card);
  border:1px solid var(--border);
  border-radius:18px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.blog-featured-media{
  order:1;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.5rem;
  padding:.8rem;
  background:#181818;
}
.blog-featured-media .featured-img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
  border-radius:10px;
  cursor:zoom-in;
  transition:transform .2s ease;
}
.blog-featured-media .featured-img:hover{transform:scale(1.01);}

.blog-featured-body{
  order:2;
  padding:1.1rem 1rem 1.2rem;
  color:#eee;
}
.blog-card-meta{
  display:flex;
  align-items:center;
  gap:.6rem;
  font-size:.92rem;
  color:var(--color-dimmer);
  margin-bottom:.35rem;
}
.blog-card-date,
.blog-card-author{opacity:.95;}
.featured-title{
  font-size:1.5rem;
  margin:.15rem 0 .5rem;
  color:var(--color-light);
  line-height:1.25;
}
.featured-excerpt{
  color:#dcdcdc;
  line-height:1.8;
  margin-top:.35rem;
}
.featured-actions{margin-top:.9rem;}

/* ---------- Chips de tags ---------- */
.blog-card-tags,
.blog-modal-tags{
  display:flex;
  flex-wrap:wrap;
  gap:.4rem .5rem;
  margin:.4rem 0 .2rem;
}
.blog-tag-chip{
  display:inline-block;
  font-size:.78rem;
  line-height:1;
  padding:.45rem .6rem;
  border-radius:999px;
  background:#2a2a2a;
  border:1px solid #333;
  color:#cfcfcf;
}
.blog-tag-empty{opacity:.65}

/* ---------- Botón primario (blog) ---------- */
.blog-btn-ver{
  display:inline-block;
  padding:.7rem 1.1rem;
  background:transparent;
  border:2px solid var(--color-secondary);
  color:var(--color-secondary);
  border-radius:999px;
  font-weight:700;
  cursor:pointer;
  transition:background .2s,color .2s,transform .06s;
}
.blog-btn-ver:hover{background:var(--color-secondary);color:#121212;}
.blog-btn-ver:active{transform:scale(.98);}

/* =================================
   LISTA DE POSTS (resto)
   ================================= */
.blog-posts-list{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:var(--gap);
  padding:1.4rem 1rem 2.4rem;
}

/* Card */
.blog-post-card{
  background:var(--color-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
  cursor:pointer;
  transition:transform .16s ease, box-shadow .2s ease, border-color .2s ease;
  display:flex;
  flex-direction:column;
}
.blog-post-card:hover{
  transform:translateY(-3px);
  border-color:#3a3a3a;
}
.blog-card-images{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:3px;
  background:#151515;
  padding:3px;
}
.blog-card-images img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
  border-radius:6px;
}
.blog-card-body{
  padding:.9rem .95rem 1rem;
}
.blog-post-card h2{
  font-size:1.05rem;
  color:#fff;
  margin:.25rem 0 .4rem;
  line-height:1.35;
}
.blog-post-card p{
  color:#d8d8d8;
  margin-top:.25rem;
}

/* ==========================
   MODAL: Post completo
   ========================== */
.blog-modal{
  position:fixed; inset:0;
  background:rgba(0,0,0,.78);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:4000;
  padding:1rem;
}
.blog-modal-content{
  display:flex;
  flex-direction:column;
  width:min(950px, 96vw);
  max-height:92vh;
  overflow:auto;
  background:#1c1c1c;
  border:1px solid #2d2d2d;
  border-radius:18px;
  box-shadow:0 14px 60px rgba(0,0,0,.6);
  position:relative;
}
.blog-modal-close{
  position:absolute; top:10px; right:16px;
  color:#fff; font-size:2rem;
  cursor:pointer;
  line-height:1;
  opacity:.9; transition:opacity .15s;
}
.blog-modal-close:hover{opacity:1}
#blog-modal-body{padding:1.2rem 1rem 1.3rem;}
.blog-modal-header h2{
  margin:.1rem 0 .35rem;
  color:#fff; font-size:1.35rem;
}
.blog-modal-meta{
  color:#cfcfcf; opacity:.9; font-size:.92rem;
  margin-bottom:.45rem;
}
/* Galería dentro del modal (imagenes arriba, texto debajo) */
.blog-modal-images{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  gap:.6rem;
  margin:.9rem 0 1rem;
}
.blog-modal-img{
  width:100%; aspect-ratio:16/10; object-fit:cover;
  border-radius:10px; cursor:zoom-in;
}
/* Texto del modal con buen wrapping */
.blog-modal-historia{
  color:#e8e8e8;
  line-height:1.85;
  white-space:pre-line;      /* respeta saltos de línea */
  overflow-wrap:anywhere;    /* rompe palabras larguísimas/URLs */
  word-break:break-word;
}

/* ==========================
   LIGHTBOX (imagenes)
   ========================== */
.img-lightbox{
  position:fixed; inset:0;
  background:rgba(0,0,0,.85);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:5000;
  padding:1rem;
}
.img-lightbox.show{display:flex;}
.img-lightbox img{
  max-width:92vw; max-height:88vh;
  border-radius:12px;
  box-shadow:0 10px 40px rgba(0,0,0,.6);
}
.lb-close, .lb-prev, .lb-next{
  position:absolute;
  background:transparent; border:none;
  color:#fff; font-size:2.2rem;
  cursor:pointer; padding:.2rem .6rem;
  line-height:1; opacity:.88;
  transition:transform .12s, opacity .12s;
}
.lb-close{top:10px; right:16px; font-size:2.6rem;}
.lb-prev{left:18px; top:50%; transform:translateY(-50%);}
.lb-next{right:18px; top:50%; transform:translateY(-50%);}
.lb-prev:hover, .lb-next:hover, .lb-close:hover{opacity:1; transform:scale(1.06);}

/* ==========================
   Utilidades / mensajes
   ========================== */
.error{
  width:90%; max-width:900px;
  margin:1rem auto;
  background:#2b1d1d;
  border:1px solid #522;
  color:#ffb3b3;
  padding:.9rem 1rem;
  border-radius:10px;
}

/* ==========================
   Responsive
   ========================== */
/* Desktop mediano: si quieres que el destacado use 2 columnas, descomenta.
@media (min-width:1025px){
  .blog-featured-card{grid-template-columns:1.15fr 1fr;}
}
*/

@media (max-width:1024px){
  /* El destacado ya es vertical por defecto; ajusta la rejilla de imágenes */
  .blog-featured-media{grid-template-columns:1fr 1fr;}
}

@media (max-width:768px){
  /* La lista pasa a 1 columna en tablets pequeñas */
  .blog-posts-list{
    grid-template-columns:1fr;
    gap:1rem;
  }

  /* El destacado se “compacta” como card: miniaturas lado a lado */
  .blog-featured-card{
    border-radius:12px;
  }
  .blog-featured-media{
    grid-template-columns:repeat(3,1fr);
    gap:.45rem;
    padding:.75rem;
  }
  .blog-featured-media .featured-img{
    height:90px; aspect-ratio:auto; object-fit:cover;
    border-radius:8px;
  }
  .featured-title{font-size:1.2rem;}
}

@media (max-width:640px){
  .blog-hero h1{font-size:1.5rem;}
  .blog-modal-content{width:96vw;}
  .blog-modal-images{grid-template-columns:1fr;}
}

@media (max-width:420px){
  .blog-posts-list{grid-template-columns:1fr;}
}
