/*
 Theme Name: CrediConecta2 – Hello Child
 Theme URI: https://crediconecta2.com
 Description: Tema hijo ligero basado en Hello para el comparador CrediConecta2.
 Author: CrediConecta2
 Template: hello-elementor
 Version: 1.0.5
 Text Domain: hello-child-crediconecta2
*/

/* ============================================
   IDENTIDAD VISUAL · CrediConecta2
   ============================================ */
:root {
  --cc2-azul: #0066FF;
  --cc2-azul-oscuro: #0B214A;
  --cc2-gris-fondo: #F7F9FC;
  --cc2-borde: #E4E8EE;
  --cc2-blanco: #ffffff;
}

/* ============================================
   BASE GLOBAL + STICKY FOOTER
   ============================================ */
* { box-sizing: border-box; }
html, body { height: 100%; }

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  font-family: 'Poppins', 'Helvetica Neue', Arial, sans-serif;
  color: var(--cc2-azul-oscuro);
  background-color: var(--cc2-gris-fondo);
  line-height: 1.6;
  font-size: 15px;
}

/* el <main> lo abre header.php con id="cc2-main" */
#cc2-main { flex: 1 0 auto; display: block; }
.cc2-footer { margin-top: auto; }

h1, h2, h3, h4 { font-weight: 600; line-height: 1.25; color: var(--cc2-azul-oscuro); }
a { color: var(--cc2-azul); text-decoration: none; }
a:hover { opacity: .88; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible {
  outline: 2px solid rgba(0,102,255,.35);
  outline-offset: 2px;
}

img { max-width: 100%; height: auto; display: block; border: 0; }

/* ============================================
   CONTENEDORES Y SECCIONES
   ============================================ */
.cc2-wrap { max-width: 1080px; margin: 50px auto; padding: 0 16px; }
.section-title { text-align: center; margin-bottom: 30px; color: var(--cc2-azul-oscuro); }

/* ============================================
   FORMULARIOS Y FILTROS · Botón centrado
   ============================================ */
.cc2-wrap form {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 18px 16px;
  margin-bottom: 40px;
  padding: 8px 0;
}

.cc2-wrap input,
.cc2-wrap select {
  height: 48px;
  padding: 0 14px;
  border: 1px solid var(--cc2-borde);
  border-radius: 12px;
  font-size: 15px;
  background: var(--cc2-blanco);
  transition: all 0.2s ease;
  box-shadow: 0 1px 2px rgba(0,0,0,0.03);
}

.cc2-wrap input::placeholder { color: #9aa3af; }

.cc2-wrap input:focus,
.cc2-wrap select:focus {
  border-color: var(--cc2-azul);
  box-shadow: 0 0 0 2px rgba(0,102,255,0.15);
}

/* contenedor del botón */
.cc2-form-actions {
  grid-column: 1 / -1;
  text-align: center;
  margin-top: 10px;
}

.cc2-form-actions button {
  background: var(--cc2-azul);
  color: var(--cc2-blanco);
  font-weight: 600;
  border: none;
  cursor: pointer;
  border-radius: 12px;
  padding: 12px 28px;
  font-size: 15px;
  transition: background .25s ease, transform .2s ease;
}
.cc2-form-actions button:hover { background: #0050CC; transform: translateY(-1px); }

@media (max-width: 600px) {
  .cc2-wrap form { grid-template-columns: 1fr; gap: 16px; }
  .cc2-form-actions { margin-top: 16px; }
}

/* ============================================
   TARJETAS DE ENTIDADES
   ============================================ */
.cc2-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 18px;
}

.cc2-card {
  display: flex;
  gap: 16px;
  align-items: center;
  padding: 18px;
  border: 1px solid var(--cc2-borde);
  border-radius: 16px;
  background: var(--cc2-blanco);
  transition: transform .2s ease, box-shadow .2s ease;
}
.cc2-card:hover { transform: translateY(-3px); box-shadow: 0 4px 12px rgba(0,0,0,0.05); }

.cc2-card h3 { margin: 0 0 6px; font-size: 18px; color: var(--cc2-azul-oscuro); }
.cc2-card p  { margin: 0; font-size: 14px; color: #5f6774; }

.cc2-badge {
  background:#eef3ff;
  border:1px solid var(--cc2-borde);
  color:#0B214A;
  font-size:12px;
  padding:4px 8px;
  border-radius:8px;
}

/* ===== Logo sin recortes (añadido) ===== */
.cc2-logo-wrap{
  flex: 0 0 120px;                /* reserva ancho fijo para el logo */
  display:flex;
  align-items:center;
  justify-content:center;
}
.cc2-logo-img{
  width:120px;
  height:50px;
  object-fit:contain;             /* encaja el logo completo */
  background:#f5f7fb;
  border:1px solid #e6eaf0;
  border-radius:8px;
  padding:4px;
  display:block;
}
.cc2-logo-placeholder{
  background:#f5f7fb;
  border:1px solid #e6eaf0;
  border-radius:8px;
  width:120px; height:50px;
}

/* Botón genérico */
.cc2-btn {
  display: inline-block;
  padding: 10px 16px;
  border-radius: 10px;
  background: var(--cc2-azul);
  color: var(--cc2-blanco);
  text-decoration: none;
  font-weight: 600;
  transition: background .25s ease;
}
.cc2-btn:hover { background: #0050CC; }

/* ============================================
   PIE DE PÁGINA
   ============================================ */
footer {
  text-align: center;
  font-size: 14px;
  color: #777;
  padding: 40px 0;
  border-top: 1px solid var(--cc2-borde);
}

/* ============================================
   HOME · CrediConecta2
   ============================================ */
.cc2-hero{
  position:relative;
  background: linear-gradient(120deg, #0066FF 0%, #0B214A 100%);
  color:#fff;
  text-align:center;
  padding:110px 20px 130px;
}
.cc2-hero__content{ max-width:760px; margin:0 auto; }
.cc2-hero h1{ font-size:2.6rem; font-weight:700; line-height:1.2; margin-bottom:22px; }
.cc2-hero p{ font-size:1.12rem; margin-bottom:30px; color:rgba(255,255,255,.9); }
.cc2-hero__btn{ font-size:1rem; padding:14px 28px; border-radius:12px; background:#fff; color:#0B214A; font-weight:600; }
.cc2-hero__btn:hover{ background:#f0f0f0; color:#0066FF; }

/* BENEFICIOS */
.cc2-benefits{ background:var(--cc2-blanco); padding:84px 16px; text-align:center; }
.cc2-benefits__grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:34px;
  max-width:1080px;
  margin:44px auto 0;
}
.cc2-benefit{
  background:var(--cc2-gris-fondo);
  border:1px solid var(--cc2-borde);
  border-radius:16px;
  padding:32px 22px;
  transition:all .3s ease;
}
.cc2-benefit:hover{ transform:translateY(-4px); box-shadow:0 4px 12px rgba(0,0,0,.05); }
.cc2-benefit__icon{ font-size:36px; margin-bottom:14px; }

/* CTA inferior */
.cc2-cta{ background:#0B214A; color:#fff; text-align:center; padding:84px 16px; }
.cc2-cta h2{ font-size:2rem; margin-bottom:14px; }
.cc2-cta p{ margin-bottom:28px; color:rgba(255,255,255,.9); }

/* ENTIDADES en Home */
.cc2-entities-home .section-title{ margin-bottom:18px; }
.cc2-entities-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:22px;
}
.cc2-entity-card{ display:flex; gap:16px; align-items:flex-start; padding:18px; border:1px solid var(--cc2-borde); border-radius:16px; background:#fff; }
.cc2-entity-card__media img{ border-radius:12px; }
.cc2-entity-card__media .cc2-thumb-placeholder{ width:100%; aspect-ratio:16/9; background:#eef2f7; border-radius:12px; }
.cc2-entity-card__title{ margin:0 0 8px; font-size:18px; }
.cc2-entity-card__facts{ list-style:none; margin:0 0 10px; padding:0; font-size:14px; color:#5f6774; }
.cc2-entity-card__facts li{ display:flex; gap:6px; }
.cc2-entity-card__facts li span{ color:#0B214A; font-weight:600; }
.cc2-entities-home__actions{ text-align:center; margin-top:16px; }

/* ÚLTIMOS ARTÍCULOS */
.cc2-latest-posts .section-title{ margin-bottom:18px; }
.cc2-posts-grid.--home{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:22px; }
.cc2-post-card.--vertical{
  display:flex; flex-direction:column;
  padding:14px; border-radius:14px; background:#fff;
  border:1px solid var(--cc2-borde);
  box-shadow:0 6px 14px rgba(0,0,0,.04);
}
.cc2-post-card__media{ display:block; }
.cc2-post-thumb{ width:100%; aspect-ratio:16/9; object-fit:cover; border-radius:10px; }
.cc2-post-card__content{ padding:10px 6px 6px; }
.cc2-post-card__title{ margin:0 0 6px; font-size:18px; line-height:1.25; }
.cc2-post-card__title a{ color:var(--cc2-azul-oscuro); text-decoration:none; }
.cc2-post-card__title a:hover{ color:var(--cc2-azul); }
.cc2-post-card__meta{ margin:0 0 8px; color:#6b7280; font-size:13px; }
.cc2-post-card__excerpt{ margin:0 0 12px; color:#5f6774; }

/* Truncado elegante en home */
.cc2-posts-grid.--home .cc2-post-card__title a{
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.cc2-posts-grid.--home .cc2-post-card__excerpt{
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}

/* Responsive hero */
@media (max-width:900px){
  .cc2-hero{ padding:90px 16px 100px; }
  .cc2-hero h1{ font-size:2.2rem; }
}
@media (max-width:600px){
  .cc2-hero{ padding:80px 16px; }
  .cc2-hero h1{ font-size:1.9rem; }
}

/* ============================================
   FOOTER · CrediConecta2
   ============================================ */
.cc2-footer { background: #0B214A; color: #fff; padding: 60px 20px 30px; text-align: center; font-size: 14px; }
.cc2-footer__inner {
  max-width: 1080px; margin: 0 auto 40px; display: flex; flex-wrap: wrap; justify-content: center; gap: 40px;
}
.cc2-footer__brand { flex: 1 1 280px; }
.cc2-footer__brand img { width: 120px; height: auto; margin: 0 auto 12px; display: block; }
.cc2-footer__brand p { color: rgba(255,255,255,0.8); font-size: 14px; line-height: 1.5; max-width: 300px; margin: 0 auto; }
.cc2-footer__nav { flex: 1 1 300px; }
.cc2-footer__nav ul { list-style: none; padding: 0; margin: 0; }
.cc2-footer__nav li { margin: 6px 0; }
.cc2-footer__nav a { color: rgba(255,255,255,0.9); transition: color 0.3s ease; }
.cc2-footer__nav a:hover { color: var(--cc2-azul); }
.cc2-footer__bottom { border-top: 1px solid rgba(255,255,255,0.1); padding-top: 20px; max-width: 1080px; margin: 0 auto; }
.cc2-footer__disclaimer {
  font-size: 12px; line-height: 1.4; color: rgba(255,255,255,0.6);
  margin-top: 12px; max-width: 720px; margin-left: auto; margin-right: auto;
}
@media (max-width: 600px) {
  .cc2-footer__inner { flex-direction: column; gap: 30px; }
  .cc2-footer__brand img { width: 100px; }
}

/* ============================================
   HEADER · CrediConecta2
   ============================================ */
.cc2-header { position: sticky; top: 0; z-index: 100; background: var(--cc2-blanco); border-bottom: 1px solid var(--cc2-borde); }
.cc2-header__inner {
  max-width: 1080px; margin: 0 auto; padding: 12px 20px; display: flex; justify-content: space-between; align-items: center; gap: 24px;
}
.cc2-logo img { height: 56px; width: auto; display: block; }
.cc2-nav { flex-grow: 1; display: flex; justify-content: flex-end; }
.cc2-menu { list-style: none; margin: 0; padding: 0; display: flex; gap: 22px; }
.cc2-menu a { color: var(--cc2-azul-oscuro); font-weight: 500; transition: color 0.25s ease; }
.cc2-menu a:hover { color: var(--cc2-azul); }

/* BURGER MÓVIL */
.cc2-burger { display: none; background: transparent; border: 0; width: 36px; height: 32px; padding: 0; cursor: pointer; }
.cc2-burger span { display: block; height: 2px; background: var(--cc2-azul-oscuro); margin: 6px 0; transition: 0.2s; }

@media (max-width: 900px) {
  .cc2-header__inner { padding: 10px 16px; }
  .cc2-nav { display: none; }
  .cc2-burger { display: block; margin-left: auto; }
  .cc2-nav.is-open {
    display: block; position: absolute; top: 60px; left: 0; right: 0;
    background: var(--cc2-blanco); border-bottom: 1px solid var(--cc2-borde);
  }
  .cc2-nav.is-open .cc2-menu { flex-direction: column; align-items: flex-start; }
  .cc2-nav.is-open .cc2-menu li { width: 100%; border-top: 1px solid var(--cc2-borde); }
  .cc2-nav.is-open .cc2-menu a { display: block; width: 100%; padding: 12px 20px; }
}
@media (max-width: 600px) { .cc2-logo img { height: 46px; } }

/* ============================================
   COOKIES · Banner + Modal
   ============================================ */
.cc2-cookie-banner {
  position: fixed; bottom: 20px; left: 20px; right: 20px; z-index: 9999;
  background: rgba(255, 255, 255, 0.96); backdrop-filter: blur(8px);
  color: #0B214A; border: 1px solid var(--cc2-borde); border-radius: 14px;
  padding: 22px; box-shadow: 0 4px 20px rgba(0,0,0,0.1); font-size: 14px;
  max-width: 960px; margin: 0 auto; animation: fadeInUp 0.5s ease;
}
@keyframes fadeInUp { from { opacity: 0; transform: translateY(20px);} to { opacity: 1; transform: translateY(0);} }

.cc2-cookie-banner__inner { display: flex; flex-wrap: wrap; gap: 20px; align-items: center; justify-content: space-between; }
.cc2-cookie-banner__text { flex: 1; line-height: 1.55; }
.cc2-cookie-banner__actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.cc2-cookie-banner a { color: var(--cc2-azul); font-weight: 500; }

.cc2-cookie-link-inline { background: none; border: none; color: var(--cc2-azul); cursor: pointer; font-weight: 500; padding: 0; transition: color 0.2s ease; }
.cc2-cookie-link-inline:hover { color: #004bcb; }

/* Botones SOLO dentro del banner/modal (evita colisiones) */
.cc2-cookie-banner .cc2-btn,
.cc2-cookie-modal__actions .cc2-btn {
  display: inline-block; padding: 10px 16px; border-radius: 10px; font-weight: 600; cursor: pointer;
  transition: all 0.2s ease; border: none; outline: none; background: var(--cc2-azul); color: #fff;
}
.cc2-cookie-banner .cc2-btn:hover,
.cc2-cookie-modal__actions .cc2-btn:hover { background:#0056e0; transform: translateY(-1px); }
.cc2-cookie-banner .cc2-btn:active,
.cc2-cookie-modal__actions .cc2-btn:active { transform: scale(0.97); box-shadow:none; }

.cc2-btn--ghost { background: #EEF2FA !important; color: #0B214A !important; }
.cc2-btn--ghost:hover { background: #E2E8F7 !important; }
.cc2-btn--secondary { background: #1EA69A !important; color: #fff !important; }
.cc2-btn--secondary:hover { background: #188f85 !important; }

/* MODAL */
.cc2-cookie-modal { position: fixed; inset: 0; z-index: 10000; display: none; }
.cc2-cookie-modal__backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.45); backdrop-filter: blur(4px); }
.cc2-cookie-modal__panel {
  position: relative; background: #fff; color: #0B214A; max-width: 520px; margin: 8% auto;
  border-radius: 16px; padding: 34px 26px; z-index: 2; box-shadow: 0 6px 20px rgba(0,0,0,0.12);
  animation: fadeIn 0.3s ease;
}
@keyframes fadeIn { from { opacity: 0; transform: scale(0.95);} to { opacity: 1; transform: scale(1);} }

.cc2-cookie-modal__panel h2 { margin-top: 0; font-size: 20px; margin-bottom: 10px; font-weight: 600; }
.cc2-cookie-opt { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 10px; font-size: 14px; }
.cc2-cookie-opt input { margin-top: 2px; accent-color: var(--cc2-azul); }
.cc2-cookie-modal__actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }
.cc2-cookie-modal__actions .cc2-btn { flex: 1 1 auto; text-align: center; min-width: 120px; }

@media (max-width: 600px) {
  .cc2-cookie-banner__inner { flex-direction: column; align-items: flex-start; gap: 16px; }
  .cc2-cookie-banner__actions { width: 100%; justify-content: flex-end; }
  .cc2-cookie-modal__panel { width: calc(100% - 30px); margin: 20% auto; padding: 22px; }
}

/* ============================================
   BLOG · Listado de artículos (layout horizontal)
   ============================================ */
.cc2-blog { padding: 80px 16px; background: var(--cc2-gris-fondo); }
.cc2-blog-grid { display: flex; flex-direction: column; gap: 40px; margin-top: 40px; }
.cc2-blog-card {
  display: flex; flex-wrap: wrap; align-items: center; background: var(--cc2-blanco);
  border: 1px solid var(--cc2-borde); border-radius: 16px; overflow: hidden;
  box-shadow: 0 4px 14px rgba(0,0,0,0.04); transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.cc2-blog-card:hover { transform: translateY(-3px); box-shadow: 0 8px 20px rgba(0,0,0,0.06); }

.cc2-blog-thumb { flex: 1 1 45%; min-width: 320px; max-height: 240px; overflow: hidden; }
.cc2-blog-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }

.cc2-blog-content { flex: 1 1 55%; padding: 28px 32px; }
.cc2-blog-title { font-size: 1.4rem; font-weight: 600; color: var(--cc2-azul-oscuro); margin-bottom: 8px; line-height: 1.3; }
.cc2-blog-title a { text-decoration: none; color: inherit; transition: color 0.2s ease; }
.cc2-blog-title a:hover { color: var(--cc2-azul); }
.cc2-blog-meta { font-size: 0.85rem; color: #7a8599; margin-bottom: 10px; }
.cc2-blog-excerpt { font-size: 0.95rem; color: #4c5566; line-height: 1.6; margin-bottom: 20px; }

.cc2-btn--small {
  display: inline-block; padding: 9px 18px; font-size: 14px; font-weight: 600;
  background: var(--cc2-azul); color: var(--cc2-blanco); border-radius: 8px; transition: all 0.25s ease; margin-top: 10px;
}
.cc2-btn--small:hover { background: #0050cc; transform: translateY(-1px); }

/* RESPONSIVE */
@media (max-width: 800px) {
  .cc2-blog-card { flex-direction: column; }
  .cc2-blog-thumb { width: 100%; max-height: 220px; }
  .cc2-blog-content { padding: 22px 20px; }
}

/* ============================================
   BLOG · Relacionados (cards verticales)
   ============================================ */
.cc2-related { margin-top: 36px; }
.cc2-related h3 { font-size: 1.25rem; margin: 0 0 14px; color: var(--cc2-azul-oscuro); }

/* Rejilla flexible para 2–3 columnas según ancho */
.cc2-related .cc2-posts-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 18px; }

/* En relacionados, las tarjetas pasan a layout vertical */
.cc2-related .cc2-post-card { display: flex; flex-direction: column; align-items: stretch; gap: 12px; padding: 14px; }

/* Imagen full width en 16:9 */
.cc2-related .cc2-post-card__media { width: 100%; }
.cc2-related .cc2-post-thumb,
.cc2-related .cc2-post-card__media img { width: 100%; aspect-ratio: 16 / 9; object-fit: cover; border-radius: 10px; }

/* Título/extracto más compactos */
.cc2-related .cc2-post-card__title { font-size: 17px !important; margin-bottom: 6px !important; line-height: 1.3 !important; }
.cc2-related .cc2-post-card__excerpt { font-size: 14px !important; color: #5f6774 !important; margin-bottom: 10px !important; }

/* Pequeño respiro entre la navegación y los relacionados */
.cc2-post-nav { display:flex; justify-content:space-between; gap:12px; margin: 28px 0 8px; }
.cc2-post-nav__prev a, .cc2-post-nav__next a { color: var(--cc2-azul); }