/* ==========================================================
   Casa Polska – Categoría como Landing Page
   Scope: .casapolska-catlanding
   Mobile-first · Hero fullscreen · Grid limpio de artículos
   ========================================================== */

/* ── Tokens ── */
:root {
  /* Colores */
  --cp-l-brand:        #2c5f2d;
  --cp-l-brand-dark:   #1e4220;
  --cp-l-brand-light:  rgba(44, 95, 45, .12);
  --cp-l-bg:           #f7f4ee;
  --cp-l-surface:      #ffffff;
  --cp-l-text:         #1f2328;
  --cp-l-muted:        rgba(31, 35, 40, .62);
  --cp-l-line:         rgba(31, 35, 40, .10);
  --cp-l-white:        #ffffff;

  /* Hero */
  --cp-l-hero-overlay: linear-gradient(
    160deg,
    rgba(0, 0, 0, .55) 0%,
    rgba(0, 0, 0, .30) 50%,
    rgba(0, 0, 0, .50) 100%
  );

  /* Tipografía */
  --cp-l-font-display: var(--cp-fuente-titulo, Georgia, serif);
  --cp-l-font-body:    var(--cp-fuente-texto, system-ui, sans-serif);

  /* Espaciado */
  --cp-l-wrap-max:  1180px;
  --cp-l-wrap-px:   1.25rem;
  --cp-l-section-py: 4rem;

  /* Card */
  --cp-l-card-radius: 18px;
  --cp-l-card-shadow: 0 4px 20px rgba(17, 24, 39, .07);
  --cp-l-card-shadow-hover: 0 12px 32px rgba(17, 24, 39, .13);

  /* Transiciones */
  --cp-l-ease: cubic-bezier(.25, .46, .45, .94);
  --cp-l-t-fast: .16s;
  --cp-l-t-med:  .28s;
}

/* ── Reset local ── */
.casapolska-catlanding *,
.casapolska-catlanding *::before,
.casapolska-catlanding *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.casapolska-catlanding {
  background: var(--cp-l-bg);
  color: var(--cp-l-text);
  font-family: var(--cp-l-font-body);
}

.casapolska-catlanding img {
  max-width: 100%;
  height: auto;
  display: block;
}

.casapolska-catlanding a {
  color: inherit;
  text-decoration: none;
}

/* ==========================================================
   1) HERO – pantalla completa
   ========================================================== */

.casapolska-catlanding__hero {
  position: relative;
  width: 100%;
  /* 100dvh en navegadores modernos, 100vh como fallback */
  height: 100vh;
  height: 100dvh;
  min-height: 520px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  /* Imagen de fondo inyectada via style inline en el PHP */
  background-image: var(--cp-hero-bg);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;

  /* Evita que el hero tape el header del tema si es sticky */
  overflow: hidden;
}

/* Overlay oscuro sobre la imagen */
.casapolska-catlanding__heroOverlay {
  position: absolute;
  inset: 0;
  background: var(--cp-l-hero-overlay);
  z-index: 1;
  pointer-events: none;
}

/* Contenido dentro del hero */
.casapolska-catlanding__heroContent {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--cp-l-wrap-max);
  padding: 0 var(--cp-l-wrap-px);
  text-align: center;

  /* Entrada animada */
  animation: cpHeroFadeUp .9s var(--cp-l-ease) both;
}

@keyframes cpHeroFadeUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Kicker / sobretítulo */
.casapolska-catlanding__heroKicker {
  display: inline-block;
  font-family: var(--cp-l-font-body);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .75);
  margin-bottom: 1rem;
  animation: cpHeroFadeUp .9s var(--cp-l-ease) .1s both;
}

/* Título principal */
.casapolska-catlanding__heroTitle {
  font-family: var(--cp-l-font-display);
  font-size: clamp(2.2rem, 7vw, 5rem);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--cp-l-white);
  margin-bottom: 1rem;
  animation: cpHeroFadeUp .9s var(--cp-l-ease) .2s both;
}

/* Subtítulo */
.casapolska-catlanding__heroSubtitle {
  font-size: clamp(1rem, 2.2vw, 1.2rem);
  line-height: 1.65;
  color: rgba(255, 255, 255, .85);
  max-width: 56ch;
  margin: 0 auto 2.2rem;
  animation: cpHeroFadeUp .9s var(--cp-l-ease) .32s both;
}

/* Botón CTA del hero */
.casapolska-catlanding__heroCta {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .9rem 2rem;
  background: var(--cp-l-white);
  color: var(--cp-l-brand-dark);
  border-radius: 999px;
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: .01em;
  text-decoration: none;
  transition: transform var(--cp-l-t-fast) var(--cp-l-ease),
              box-shadow var(--cp-l-t-fast) var(--cp-l-ease),
              background var(--cp-l-t-fast) var(--cp-l-ease);
  animation: cpHeroFadeUp .9s var(--cp-l-ease) .44s both;
}

.casapolska-catlanding__heroCta:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(0, 0, 0, .22);
  background: #f0f0f0;
}

.casapolska-catlanding__heroCtaIcon {
  font-size: .85em;
  transition: transform var(--cp-l-t-med) var(--cp-l-ease);
}

.casapolska-catlanding__heroCta:hover .casapolska-catlanding__heroCtaIcon {
  transform: scale(1.15);
}

/* Flecha de scroll al fondo del hero */
.casapolska-catlanding__heroScroll {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1.5px solid rgba(255, 255, 255, .45);
  color: var(--cp-l-white);
  font-size: .9rem;
  text-decoration: none;
  animation: cpScrollBounce 2s var(--cp-l-ease) 1.2s infinite;
  transition: background var(--cp-l-t-fast) var(--cp-l-ease),
              border-color var(--cp-l-t-fast) var(--cp-l-ease);
}

.casapolska-catlanding__heroScroll:hover {
  background: rgba(255, 255, 255, .18);
  border-color: rgba(255, 255, 255, .75);
}

@keyframes cpScrollBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(6px); }
}

/* ==========================================================
   2) SECCIÓN DE CONTENIDO – artículos
   ========================================================== */

.casapolska-catlanding__content {
  background: var(--cp-l-bg);
  padding: var(--cp-l-section-py) 0;
}

.casapolska-catlanding__contentWrap {
  max-width: var(--cp-l-wrap-max);
  margin: 0 auto;
  padding: 0 var(--cp-l-wrap-px);
  display: grid;
  gap: 3rem;
}

/* Grid de cards – 1 columna mobile, 2 en tablet, 3 en desktop */
.casapolska-catlanding__grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr;
}

@media (min-width: 640px) {
  .casapolska-catlanding__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 980px) {
  .casapolska-catlanding__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* ==========================================================
   3) CARD de artículo
   ========================================================== */

.casapolska-catlanding__card {
  background: var(--cp-l-surface);
  border: 1px solid var(--cp-l-line);
  border-radius: var(--cp-l-card-radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--cp-l-card-shadow);
  transition: transform var(--cp-l-t-med) var(--cp-l-ease),
              box-shadow var(--cp-l-t-med) var(--cp-l-ease);
}

.casapolska-catlanding__card:hover {
  transform: translateY(-4px);
  box-shadow: var(--cp-l-card-shadow-hover);
}

/* Imagen de la card */
.casapolska-catlanding__cardMedia {
  display: block;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.casapolska-catlanding__cardImg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--cp-l-t-med) var(--cp-l-ease);
}

.casapolska-catlanding__cardMedia:hover .casapolska-catlanding__cardImg {
  transform: scale(1.04);
}

/* Cuerpo de la card */
.casapolska-catlanding__cardBody {
  padding: 1.1rem 1.25rem 1.4rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Meta: fecha y tiempo de lectura */
.casapolska-catlanding__cardMeta {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .82rem;
  color: var(--cp-l-muted);
  margin-bottom: .55rem;
  flex-wrap: wrap;
}

.casapolska-catlanding__cardDot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: rgba(31, 35, 40, .4);
  flex-shrink: 0;
}

/* Título de la card */
.casapolska-catlanding__cardTitle {
  font-family: var(--cp-l-font-display);
  font-size: 1.08rem;
  line-height: 1.35;
  letter-spacing: -.01em;
  margin-bottom: .5rem;
}

.casapolska-catlanding__cardTitle a {
  color: var(--cp-l-text);
  text-decoration: none;
  transition: color var(--cp-l-t-fast) var(--cp-l-ease);
}

.casapolska-catlanding__cardTitle a:hover {
  color: var(--cp-l-brand);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* Extracto */
.casapolska-catlanding__cardExcerpt {
  font-size: .94rem;
  line-height: 1.65;
  color: var(--cp-l-muted);
  flex: 1;
  margin-bottom: .9rem;

  /* Limitar a 3 líneas */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* CTA de la card */
.casapolska-catlanding__cardCta {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-weight: 700;
  font-size: .9rem;
  color: var(--cp-l-brand);
  text-decoration: none;
  margin-top: auto;
  transition: gap var(--cp-l-t-fast) var(--cp-l-ease),
              color var(--cp-l-t-fast) var(--cp-l-ease);
}

.casapolska-catlanding__cardCta:hover {
  gap: .7rem;
  color: var(--cp-l-brand-dark);
}

.casapolska-catlanding__cardCtaIcon {
  font-size: .8em;
  flex-shrink: 0;
  transition: transform var(--cp-l-t-fast) var(--cp-l-ease);
}

.casapolska-catlanding__cardCta:hover .casapolska-catlanding__cardCtaIcon {
  transform: translateX(3px);
}

/* ==========================================================
   4) PAGINACIÓN
   ========================================================== */

.casapolska-catlanding__pagination {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  justify-content: center;
}

.casapolska-catlanding__pageBtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .55rem 1rem;
  border-radius: 999px;
  border: 1px solid var(--cp-l-line);
  background: rgba(255, 255, 255, .85);
  font-weight: 700;
  font-size: .88rem;
  color: var(--cp-l-text);
  text-decoration: none;
  transition: transform var(--cp-l-t-fast) var(--cp-l-ease),
              background var(--cp-l-t-fast) var(--cp-l-ease);
}

.casapolska-catlanding__pageBtn:hover {
  transform: translateY(-1px);
  background: var(--cp-l-white);
}

.casapolska-catlanding__pageBtn--active {
  background: var(--cp-l-brand-light);
  border-color: rgba(44, 95, 45, .3);
  color: var(--cp-l-brand-dark);
}

.casapolska-catlanding__pageBtn--ellipsis {
  background: transparent;
  border-color: transparent;
  cursor: default;
}

/* ==========================================================
   5) ESTADO VACÍO
   ========================================================== */

.casapolska-catlanding__empty {
  background: var(--cp-l-surface);
  border: 1px solid var(--cp-l-line);
  border-radius: var(--cp-l-card-radius);
  padding: 3rem 1.5rem;
  text-align: center;
  color: var(--cp-l-muted);
  line-height: 1.7;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.2rem;
}

/* ==========================================================
   6) RESPONSIVE – ajustes específicos mobile
   ========================================================== */

@media (max-width: 480px) {
  .casapolska-catlanding__heroTitle {
    font-size: clamp(1.9rem, 9vw, 2.8rem);
  }

  .casapolska-catlanding__heroSubtitle {
    font-size: .97rem;
  }

  .casapolska-catlanding__heroCta {
    padding: .8rem 1.5rem;
    font-size: .95rem;
  }

  .casapolska-catlanding__content {
    padding: 2.5rem 0;
  }
}

/* Preferencias de movimiento reducido */
@media (prefers-reduced-motion: reduce) {
  .casapolska-catlanding__heroContent,
  .casapolska-catlanding__heroKicker,
  .casapolska-catlanding__heroTitle,
  .casapolska-catlanding__heroSubtitle,
  .casapolska-catlanding__heroCta {
    animation: none;
  }

  .casapolska-catlanding__heroScroll {
    animation: none;
  }
}

/* ==========================================================
   7) BANNER DE CIERRE – imagen a pantalla completa + texto
   Editable desde el Customizer de WordPress
   ========================================================== */

.casapolska-catlanding__banner {
  position: relative;
  width: 100%;
  height: 100vh;
  height: 100dvh;
  min-height: 480px;
  display: flex;
  align-items: center;
  justify-content: center;

  /* Imagen inyectada desde PHP via custom property */
  background-image: var(--cp-banner-bg, none);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;

  /* Si no hay imagen, fondo sólido brand */
  background-color: var(--cp-l-brand-dark);
}

/* Overlay del banner desactivado – la imagen se muestra tal cual */
.casapolska-catlanding__bannerOverlay {
  display: none;
}

/* Contenedor del texto: anclado abajo a la derecha */
.casapolska-catlanding__bannerContent {
  position: absolute;
  z-index: 2;
  bottom: 2rem;
  right: 2rem;
  max-width: 340px;
  text-align: right;
}

/* Leyenda pequeña con cápsula de legibilidad */
.casapolska-catlanding__bannerText {
  display: inline-block;
  font-family: var(--cp-l-font-body);
  font-size: .8rem;
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: .01em;
  color: rgba(255, 255, 255, .92);

  /* Cápsula de legibilidad: fondo oscuro difuminado detrás del texto */
  background: rgba(0, 0, 0, .38);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 8px;
  padding: .55rem .85rem;

  /* Sombra de texto adicional para refuerzo */
  text-shadow: 0 1px 6px rgba(0, 0, 0, .5);
}

/* Responsive mobile */
@media (max-width: 480px) {
  .casapolska-catlanding__banner {
    min-height: 380px;
  }

  .casapolska-catlanding__bannerContent {
    bottom: 1.2rem;
    right: 1rem;
    max-width: 260px;
  }

  .casapolska-catlanding__bannerText {
    font-size: .75rem;
    padding: .45rem .7rem;
  }
}