/* news-v20.css — Noticias y artículos CIBERPRO (headless WP) sobre el sistema
   visual v20. Sin estilos inline (CSP estricta). Hereda tokens de v19-system.css:
   --navy --cyan --orange --magenta --blue --text --muted --line --radius --shadow. */

/* ---------- Buscador del hero ---------- */
.hero-noticias .news-search{display:flex;gap:.6rem;max-width:520px;margin-top:1.6rem;flex-wrap:wrap}
.hero-noticias .news-search input[type=search]{flex:1 1 240px;min-width:0;padding:.85rem 1.1rem;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--text);font:inherit}
.hero-noticias .news-search input[type=search]::placeholder{color:var(--muted)}
.hero-noticias .news-search input[type=search]:focus{outline:2px solid var(--cyan);outline-offset:2px}

/* ---------- Tarjeta ---------- */
.news-card{display:flex;flex-direction:column;overflow:hidden;padding:0}
.news-card-media{display:block;aspect-ratio:16/9;overflow:hidden;background:var(--panel2)}
.news-card-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.news-card-media:hover img{transform:scale(1.05)}
.news-card-body{padding:1.3rem 1.4rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.news-card-body h3{margin:.1rem 0 .15rem;line-height:1.3}
.news-card-body h3 a{color:inherit;text-decoration:none}
.news-card-body h3 a:hover{text-decoration:underline}
.news-card-body p{flex:1;margin:0;color:var(--muted);font-size:.96rem;line-height:1.55}
.news-card-meta{margin-top:.3rem;font-size:.82rem;color:var(--muted)}

/* ---------- Chips de palabras clave ---------- */
.news-keywords{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}
.news-keyword{display:inline-block;padding:.22rem .65rem;border-radius:999px;border:1px solid var(--line);background:rgba(87,201,255,.10);color:var(--blue);font-size:.78rem;text-decoration:none;transition:background .2s ease}
.news-keyword:hover{background:rgba(87,201,255,.22)}

/* ---------- Carrusel en bucle (CSS marquee) ---------- */
.news-carousel-head{margin-bottom:1.2rem}
.news-carousel{overflow:hidden;position:relative;margin:0 -4px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.news-carousel-track{display:flex;width:max-content;animation:newsMarquee 80s linear infinite}
.news-carousel:hover .news-carousel-track{animation-play-state:paused}
.news-carousel .news-card{flex:0 0 340px;width:340px;margin-right:1.5rem}
@keyframes newsMarquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.news-carousel-cta{justify-content:center;margin-top:1.8rem}

/* ---------- Paginación / vacío ---------- */
.news-pagination{display:flex;align-items:center;justify-content:center;gap:1.2rem;margin-top:2.6rem;flex-wrap:wrap}
.news-page-info{color:var(--muted);font-size:.9rem}
.news-empty{max-width:640px;margin:1rem auto;text-align:center;padding:2.4rem}
.news-empty h3{margin-top:0}
.news-empty .btn{margin-top:1rem}

/* ---------- Artículo (detalle) ---------- */
.news-article-inner{max-width:820px;margin:0 auto}
.news-breadcrumb{margin:0 0 1rem}
.news-breadcrumb a{color:var(--blue);text-decoration:none;font-size:.92rem}
.news-breadcrumb a:hover{text-decoration:underline}
.news-article h1{margin:.3rem 0 .6rem;line-height:1.18}
.news-article-meta{color:var(--muted);font-size:.9rem;margin:0 0 1.4rem}
.news-article-media{margin:0 0 1.8rem;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.news-article-media img{width:100%;height:auto;display:block}
.news-article-body{font-size:1.06rem;line-height:1.75;color:var(--ink)}
.news-article-body p{margin:0 0 1.2rem}
.news-article-body h2,.news-article-body h3{margin:2rem 0 .8rem;line-height:1.25}
.news-article-body a{color:var(--blue)}
.news-article-body img{max-width:100%;height:auto;border-radius:14px;margin:1.4rem 0}
.news-article-body ul,.news-article-body ol{margin:0 0 1.2rem 1.3rem;line-height:1.7}
.news-article-body blockquote{margin:1.4rem 0;padding:.6rem 1.2rem;border-left:3px solid var(--cyan);color:#33485f;font-style:italic}

/* ---------- Bloque de palabras clave al final del artículo ---------- */
.news-tags-block{margin:2.4rem 0 1.2rem;padding-top:1.4rem;border-top:1px solid var(--line)}
.news-tags-label{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.6rem}

/* ---------- Aviso de IA al pie (pequeño, discreto) ---------- */
.ai-notice-foot{margin:1.4rem 0 0;font-size:.8rem;color:var(--muted);line-height:1.5}
.ai-notice-foot a{color:var(--blue)}

/* ---------- Sección de relacionadas ---------- */
.news-related-section{padding-top:1rem}
.news-related-section .section-head{margin-bottom:1.2rem}

/* ---------- Módulo de servicio relacionado ---------- */
.service-module{padding:3rem 0}
.service-module-inner{max-width:820px;margin:0 auto;padding:0 24px;text-align:center}
.service-module-inner h3{margin:.4rem 0 .8rem;font-size:1.55rem;color:#eaf3ff}
.service-module-inner p{color:#cdddee;max-width:640px;margin:0 auto 1.4rem;line-height:1.6}

/* ---------- Responsivo / accesibilidad ---------- */
@media (max-width:700px){
  .news-article-body{font-size:1rem}
  .service-module{padding:2.2rem 0}
  .news-carousel .news-card{flex:0 0 78vw;width:78vw}
}
@media (prefers-reduced-motion:reduce){
  .news-carousel-track{animation:none}
  .news-carousel{overflow-x:auto;-webkit-mask-image:none;mask-image:none}
}

/* ============ v21: iconos, colores rotativos en carrusel y flechas ============ */

/* Espacio tras el icono dentro del título (carrusel y cuadrícula de noticias) */
.news-card h3{display:flex;align-items:flex-start;gap:.5rem}
.news-card h3 .card-ic{flex:0 0 auto;margin-top:.12em}

/* Colores rotativos (igual que la cuadrícula en section-light) para el carrusel */
.news-carousel-track > .card:nth-child(3n+1) h3{color:#0d5aa0}
.news-carousel-track > .card:nth-child(3n+1) .card-ic{color:#0d6fc4;background:rgba(13,111,196,.10)}
.news-carousel-track > .card:nth-child(3n+2) h3{color:#7b1fb0}
.news-carousel-track > .card:nth-child(3n+2) .card-ic{color:#8b1ab8;background:rgba(139,26,184,.10)}
.news-carousel-track > .card:nth-child(3n+3) h3{color:#c2540a}
.news-carousel-track > .card:nth-child(3n+3) .card-ic{color:#e0670a;background:rgba(224,103,10,.10)}

/* Cuando el JS controla el carrusel, se desactiva la animación CSS */
.news-carousel[data-js] .news-carousel-track{animation:none}

/* Flechas grandes superpuestas, centradas a media altura de las tarjetas */
.news-carousel-wrap{position:relative}
.news-carousel-wrap > .news-carousel{margin:0}
.news-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:58px;height:58px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.92);color:var(--blue);font-size:2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(8,22,44,.18);transition:background .2s ease,transform .1s ease;-webkit-user-select:none;user-select:none;touch-action:manipulation}
.news-arrow:hover{background:#fff;color:#0d5aa0}
.news-arrow:active{transform:translateY(-50%) scale(.9);background:rgba(87,201,255,.3)}
.news-arrow:focus-visible{outline:2px solid var(--cyan);outline-offset:2px}
.news-arrow--prev{left:-4px}
.news-arrow--next{right:-4px}
@media (max-width:760px){
  .news-arrow{width:50px;height:50px;font-size:1.8rem}
  .news-arrow--prev{left:6px}
  .news-arrow--next{right:6px}
}
