/* =====================================================
   css_noticias.css
   Listado de noticias – Diseño premium sin curvas
===================================================== */

.news-container{
  max-width:1100px;
  margin:0 auto;
}

.news-container > h2{
  font-family:"Raleway",sans-serif;
  font-weight:900;
  font-size:1.15em;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:#3c3b3b;
  margin:0 0 1.4em;
}

/* ===== Card ===== */
.news-block{
  border:1px solid rgba(0,0,0,0.10);
  background:#fafafa;
  margin:0 0 1.6em;
  box-shadow:0 18px 40px rgba(0,0,0,0.06);
}

/* Header */
.news-block-header{
  display:flex;
  justify-content:space-between;
  gap:2em;
  padding:1.7em 2.2em;
  background:#fff;
  border-bottom:1px solid rgba(0,0,0,0.08);
}

.nb-title-area{ flex:1; min-width:0; }

.nb-main-title{
  font-family:"Raleway",sans-serif;
  font-weight:900;
  font-size:1.08em;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:#3c3b3b;
  margin:0 0 .55em;
  line-height:1.25;

  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.nb-subtitle{
  font-family:"Raleway",sans-serif;
  font-size:.70em;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#9a9a9a;
}

/* Fecha */
.nb-date-area{
  min-width:180px;
  padding-left:2.5em;
  margin-left:2.5em;
  border-left:1px solid #e5e5e5;

  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;

  font-family:"Raleway",sans-serif;
  font-size:.7em;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#777;
}

.nb-date{
  margin-bottom:.2em;
}
.nb-author{
  font-size:.65em;
  letter-spacing:.28em;
  margin-bottom:.6em;
  color:#777;
}
/* 🔴 CÍRCULO DECORATIVO */
/* 🔴 CÍRCULO DECORATIVO (FORZADO 100% REDONDO) */
.nb-circle{
  width:40px !important;
  height:40px !important;
  aspect-ratio:1 / 1;          /* refuerzo */
  border-radius:9999px !important;

  display:block !important;     /* evita inline raro */
  flex:0 0 40px !important;     /* evita que flex lo estire */
  overflow:hidden;

  background:#215732;

  margin-top:.4em;

  box-shadow:
    0 6px 14px rgba(0,0,0,.12),
    inset 0 0 0 3px rgba(255,255,255,.18);
}

/* Imagen */
.news-block-image img{
  display:block;
  width:100%;
  height:auto;
}

/* Resumen */
.news-block-body{
  padding:1.7em 2.2em 1.2em;
  background:#fff;
}
.news-block-body p{
  font-size:.98em;
  line-height:1.9;
  color:#555;
}

/* Meta */
.news-meta{
  padding:2.2em 2.2em 2.8em;  /* 👈 más aire abajo */
  background:#fff;
  display:flex;
  justify-content:space-between;
  gap:1.4em;
  flex-wrap:wrap;
  border-top:1px solid rgba(0,0,0,0.06);
}

.btn-continue{
  padding:.85em 2.2em;
  border:1px solid rgba(0,0,0,0.18);
  background:#fff;

  font-family:"Raleway",sans-serif;
  font-size:.70em;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:#333;
}

.btn-continue:hover{
  background:#f4f4f4;
}

.news-meta-right{
  display:flex;
  align-items:center;
  gap:1.5em;

  font-family:"Raleway",sans-serif;
  font-size:.65em;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#999;
}

.news-meta-right .sep{
  color:#d0d0d0;
}

/* ===== Mobile ===== */
@media(max-width:480px){
  .news-block-header{
    flex-direction:column;
    padding:1.2em;
  }
  .nb-date-area{
    border-left:none;
    border-top:1px solid rgba(0,0,0,0.08);
    padding-left:0;
    padding-top:1em;
  }
  .news-block-body,
  .news-meta{
    padding:1.1em;
  }
}


/* =====================================================
   MOBILE PRO – News list + Modal (solo celular)
===================================================== */
@media (max-width: 768px){

  .news-container{ max-width: 980px; padding: 0 .6rem; }

  .news-container > h2{
    font-size:.9em;
    letter-spacing:.22em;
    margin: .2em 0 1em;
  }

  /* Card base */
  .news-block{
    background:#fff;
    border:1px solid rgba(0,0,0,.10);
    box-shadow: 0 16px 40px rgba(0,0,0,.08);
    margin:0 0 1rem;
    overflow:hidden;
  }

  /* Header compacto */
  .news-block-header{
    padding: .95rem .95rem .75rem;
    gap: .8rem;
    border-bottom: 1px solid rgba(0,0,0,.06);
  }

  /* Quita el layout “separado” de fecha en móvil */
  .nb-date-area{
    min-width: auto;
    margin-left: 0;
    padding-left: 0;
    border-left: none;

    flex-direction: row;
    align-items: center;
    gap: .65rem;

    font-size: .62em;
    letter-spacing:.18em;
  }

  .nb-date{ margin: 0; opacity:.75; }
  .nb-author{
    margin: 0;
    font-size: .62em;
    letter-spacing: .22em;
    opacity:.85;
  }

  /* Círculo SIEMPRE redondo */
  .nb-circle{
    width: 14px !important;
    height: 14px !important;
    aspect-ratio:1/1;
    border-radius:9999px !important;
    flex:0 0 14px !important;
    display:block !important;
    background:#215732;
    box-shadow: 0 6px 14px rgba(0,0,0,.15), inset 0 0 0 2px rgba(255,255,255,.25);
    margin-top:0 !important;
  }

  /* Imagen estilo “hero” pero más editorial */
  .news-block-image{
    position: relative;
    background:#f3f3f3;
  }
  .news-block-image img{
    display:block;
    width:100%;
    height: 190px;          /* 👈 look premium */
    object-fit: cover;
  }

  /* Texto */
  .news-block-body{
    padding: .85rem .95rem .6rem;
  }
  .news-block-body p{
    font-size:.96em;
    line-height: 1.7;
    color:#4b4b4b;

    display:-webkit-box;
    -webkit-line-clamp:4;
    -webkit-box-orient:vertical;
    overflow:hidden;
    margin:0;
  }

  /* Meta abajo más “delgada” */
  .news-meta{
    padding: .7rem .95rem .95rem;
    border-top: 1px solid rgba(0,0,0,.06);
    gap:.8rem;
    align-items:center;
  }

  /* Botón minimal */
  .btn-continue{
    padding:.72rem 1rem;
    border:1px solid rgba(0,0,0,.16);
    letter-spacing:.24em;
    font-size:.68em;
    width: 100%;
    text-align:center;
  }

  .news-meta-right{
    width:100%;
    justify-content: space-between;
    gap:.6rem;
    font-size:.62em;
  }

  /* Botón like táctil */
  .like-btn{
    border:1px solid rgba(0,0,0,.10);
    padding:.55rem .7rem;
    background:#fff;
    display:inline-flex;
    align-items:center;
    gap:.45rem;
    cursor:pointer;
  }

  .like-btn i{ font-size:1.05em; }
  .like-btn.liked{
    border-color: rgba(33,87,50,.35);
  }

  /* ✅ Tap “card” para abrir modal (sin afectar botones) */
  .news-block{
    -webkit-tap-highlight-color: transparent;
  }
  .news-block:active{
    transform: scale(.995);
  }

  /* =========================
     MODAL
  ========================= */
  .news-modal{
    position: fixed;
    inset: 0;
    z-index: 999999;
    display:none;
  }
  .news-modal.open{ display:block; }

  .news-modal-backdrop{
    position:absolute;
    inset:0;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }

  .news-modal-sheet{
    position:absolute;
    left: 0; right: 0;
    bottom: 0;
    max-height: 88vh;
    background:#fff;
    border-top: 1px solid rgba(255,255,255,.35);
    box-shadow: 0 -20px 60px rgba(0,0,0,.25);
    overflow:hidden;
    transform: translateY(12px);
    animation: modalUp .18s ease forwards;
  }

  @keyframes modalUp{
    from{ transform: translateY(20px); opacity:.9; }
    to{ transform: translateY(0); opacity:1; }
  }

  .news-modal-topbar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:.8rem;
    padding: .9rem .95rem;
    border-bottom:1px solid rgba(0,0,0,.06);
  }

  .news-modal-title{
    font-family:"Raleway",sans-serif;
    font-weight:900;
    font-size:.85em;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:#2f2f2f;

    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
    margin:0;
  }

  .news-modal-close{
    border:1px solid rgba(0,0,0,.15);
    background:#fff;
    padding:.55rem .8rem;
    font-family:"Raleway",sans-serif;
    font-size:.7em;
    letter-spacing:.22em;
    text-transform:uppercase;
    cursor:pointer;
  }

  .news-modal-content{
    overflow:auto;
    -webkit-overflow-scrolling: touch;
    max-height: calc(88vh - 58px);
  }

  .news-modal-hero img{
    width:100%;
    height: 220px;
    object-fit: cover;
    display:block;
    background:#f3f3f3;
  }

  .news-modal-body{
    padding: 1rem .95rem 1.2rem;
  }

  .news-modal-meta{
    font-family:"Raleway",sans-serif;
    font-size:.65em;
    letter-spacing:.20em;
    text-transform:uppercase;
    color:#8a8a8a;
    display:flex;
    gap:.7rem;
    align-items:center;
    flex-wrap:wrap;
    margin-bottom:.85rem;
  }

  .news-modal-text{
    font-size:1.02em;
    line-height:1.85;
    color:#333;
  }

  /* Si tu texto trae saltos */
  .news-modal-text p{ margin: 0 0 1em; }
}