.elementor-5349 .elementor-element.elementor-element-205283a{--display:flex;--background-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-205283a, .elementor-5349 .elementor-element.elementor-element-205283a::before{--border-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-47dae8b{--display:flex;--background-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-47dae8b, .elementor-5349 .elementor-element.elementor-element-47dae8b::before{--border-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-d38249e{text-align:center;z-index:100;}.elementor-5349 .elementor-element.elementor-element-d38249e .elementor-heading-title{color:var( --e-global-color-64363bd );font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );}.elementor-5349 .elementor-element.elementor-element-71f0a14 .elementor-countdown-wrapper{max-width:100%;}.elementor-5349 .elementor-element.elementor-element-71f0a14 .elementor-countdown-item{background-color:#0000004F;}body:not(.rtl) .elementor-5349 .elementor-element.elementor-element-71f0a14 .elementor-countdown-item:not(:first-of-type){margin-left:calc( 10px/2 );}body:not(.rtl) .elementor-5349 .elementor-element.elementor-element-71f0a14 .elementor-countdown-item:not(:last-of-type){margin-right:calc( 10px/2 );}body.rtl .elementor-5349 .elementor-element.elementor-element-71f0a14 .elementor-countdown-item:not(:first-of-type){margin-right:calc( 10px/2 );}body.rtl .elementor-5349 .elementor-element.elementor-element-71f0a14 .elementor-countdown-item:not(:last-of-type){margin-left:calc( 10px/2 );}.elementor-5349 .elementor-element.elementor-element-71f0a14{z-index:100;}.elementor-5349 .elementor-element.elementor-element-c9406c5{--display:flex;--background-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-8160f57{--divider-border-style:solid;--divider-color:#000;--divider-border-width:1px;}.elementor-5349 .elementor-element.elementor-element-8160f57 .elementor-divider-separator{width:0%;}.elementor-5349 .elementor-element.elementor-element-8160f57 .elementor-divider{padding-top:15px;padding-bottom:15px;}.elementor-5349 .elementor-element.elementor-element-1320589{--display:flex;--background-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-77b4c9a{--divider-border-style:solid;--divider-color:#000;--divider-border-width:1px;}.elementor-5349 .elementor-element.elementor-element-77b4c9a .elementor-divider-separator{width:0%;}.elementor-5349 .elementor-element.elementor-element-77b4c9a .elementor-divider{padding-top:15px;padding-bottom:15px;}.elementor-5349 .elementor-element.elementor-element-da18e38{--display:flex;--background-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-5ca3cf3{--divider-border-style:solid;--divider-color:#000;--divider-border-width:1px;}.elementor-5349 .elementor-element.elementor-element-5ca3cf3 .elementor-divider-separator{width:0%;}.elementor-5349 .elementor-element.elementor-element-5ca3cf3 .elementor-divider{padding-top:15px;padding-bottom:15px;}.elementor-5349 .elementor-element.elementor-element-b4afe3c{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--background-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-cc8ba13{--display:flex;--background-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-cc8ba13:not(.elementor-motion-effects-element-type-background), .elementor-5349 .elementor-element.elementor-element-cc8ba13 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F0F0F0;}.elementor-5349 .elementor-element.elementor-element-cc8ba13, .elementor-5349 .elementor-element.elementor-element-cc8ba13::before{--border-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-cc8ba13.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-5349 .elementor-element.elementor-element-6517e97{text-align:center;}.elementor-5349 .elementor-element.elementor-element-6517e97 .elementor-heading-title{color:#B0204B;font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );}.elementor-5349 .elementor-element.elementor-element-2ed4abe{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );}.elementor-5349 .elementor-element.elementor-element-b2db7ae{--display:flex;--background-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-f2a121f{--divider-border-style:solid;--divider-color:#000;--divider-border-width:1px;}.elementor-5349 .elementor-element.elementor-element-f2a121f .elementor-divider-separator{width:0%;}.elementor-5349 .elementor-element.elementor-element-f2a121f .elementor-divider{padding-top:15px;padding-bottom:15px;}.elementor-5349 .elementor-element.elementor-element-594da1e{--display:flex;--background-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-e433016{--divider-border-style:solid;--divider-color:#000;--divider-border-width:1px;}.elementor-5349 .elementor-element.elementor-element-e433016 .elementor-divider-separator{width:0%;}.elementor-5349 .elementor-element.elementor-element-e433016 .elementor-divider{padding-top:15px;padding-bottom:15px;}.elementor-5349 .elementor-element.elementor-element-c576126{--display:flex;--background-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-d0923bb{--divider-border-style:solid;--divider-color:#000;--divider-border-width:1px;}.elementor-5349 .elementor-element.elementor-element-d0923bb .elementor-divider-separator{width:0%;}.elementor-5349 .elementor-element.elementor-element-d0923bb .elementor-divider{padding-top:15px;padding-bottom:15px;}.elementor-5349 .elementor-element.elementor-element-cf537a5{--display:flex;--background-transition:0.3s;border-style:dotted;--border-style:dotted;--border-radius:30px 30px 30px 30px;}.elementor-5349 .elementor-element.elementor-element-cf537a5, .elementor-5349 .elementor-element.elementor-element-cf537a5::before{--border-transition:0.3s;}.elementor-5349 .elementor-element.elementor-element-cf537a5.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-5349 .elementor-element.elementor-element-7184413{text-align:center;}.elementor-5349 .elementor-element.elementor-element-7184413 .elementor-heading-title{color:var( --e-global-color-64363bd );}.elementor-5349 .elementor-element.elementor-element-418819b{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );}.elementor-5349 .elementor-element.elementor-element-4597d2e .elementor-button{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );fill:#B0204B;color:#B0204B;background-color:var( --e-global-color-64363bd );}@media(min-width:768px){.elementor-5349 .elementor-element.elementor-element-cc8ba13{--width:100%;}.elementor-5349 .elementor-element.elementor-element-cf537a5{--width:64.937%;}}/* Start custom CSS for html, class: .elementor-element-3ab5c13 */.lp-section.juego-arbol {
  padding: 80px 20px;
  background: #fff7f9;
}

.lp-section.juego-arbol .lp-title {
  text-align: center;
  font-size: 2.2rem;
  margin-bottom: 8px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #b0204b;
}

.lp-section.juego-arbol .lp-subtitle {
  text-align: center;
  margin-bottom: 32px;
  color: #444;
}

.tree-game-wrapper {
  display: grid;
  grid-template-columns: 1fr 1.2fr 1fr;
  gap: 24px;
  align-items: flex-start;
}

.tree-game-pieces,
.tree-game-help {
  background: #ffffff;
  border-radius: 16px;
  padding: 20px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.06);
}

.tree-game-pieces h3,
.tree-game-help h3 {
  margin-top: 0;
  margin-bottom: 12px;
  font-size: 1.1rem;
  color: #b0204b;
}

.tree-game-pieces .piece {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 48px;
  height: 48px;
  margin: 6px;
  border-radius: 50%;
  background: #ffe1ec;
  cursor: grab;
  font-size: 1.6rem;
  transition: transform 0.15s, box-shadow 0.15s, background 0.15s;
}

.tree-game-pieces .piece:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.12);
  background: #ffd1e1;
}

.tree-game-canvas {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.tree-dropzone {
  position: relative;
  width: 260px;
  height: 360px;
  background: linear-gradient(180deg, #0a7c3b 0%, #055529 100%);
  border-radius: 0 0 40px 40px;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.25);
  overflow: hidden;
}

.tree-base {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 40px;
  background: #5b3924;
  border-radius: 12px 12px 0 0;
}

/* Adornos colocados sobre el árbol */
.piece-on-tree {
  position: absolute;
  transform: translate(-50%, -50%);
  font-size: 1.7rem;
  cursor: pointer;
}

/* Botón de reinicio */
.tree-reset-btn {
  border: none;
  border-radius: 20px;
  padding: 10px 22px;
  background: #ff4b6a;
  color: #ffffff;
  font-weight: 600;
  cursor: pointer;
  font-size: 0.95rem;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.18);
  transition: transform 0.15s, box-shadow 0.15s, background 0.15s;
}

.tree-reset-btn:hover {
  background: #e23b59;
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.22);
}

/* Responsivo */
@media (max-width: 900px) {
  .tree-game-wrapper {
    grid-template-columns: 1fr;
  }

  .tree-game-canvas {
    order: -1;
  }
}/* End custom CSS */
/* Start custom CSS *//* =========
   PALETA Y BASE GLOBAL
   ========= */

body {
  font-family: "Helvetica Neue", Arial, sans-serif;
  background: linear-gradient(180deg, #b00030 0%, #7c0022 45%, #3f0012 100%);
  color: #ffffff;
}

/* Contenedor principal de la landing (ajusta el body.elementor-page-5349 si usas otro) */
.landing-pesebres {
  min-height: 100vh;
  padding-top: 80px; /* espacio para navbar fija */
}

/* Contenedor genérico de secciones */
.lp-section {
  padding: 80px 20px;
}

.lp-container {
  max-width: 1100px;
  margin: 0 auto;
}

/* Títulos generales */
.lp-title {
  font-size: 2.2rem;
  text-align: center;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 8px;
  color: #ffffff;
}

.lp-subtitle {
  text-align: center;
  margin-bottom: 32px;
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.85);
}

/* Texto genérico dentro de secciones */
.lp-section p {
  font-size: 1rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.92);
}

/* Tarjetas blancas sobre fondo rojo (útil para catálogo, formulario, etc.) */
.lp-card {
  background: #ffffff;
  color: #333333;
  border-radius: 18px;
  padding: 22px 20px;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
}

/* Botones principales */
.lp-button,
.lp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 12px 26px;
  border: none;
  background: #ffffff;
  color: #b00030;
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.lp-button:hover,
.lp-btn:hover {
  background: #ffe5ee;
  color: #900026;
  transform: translateY(-1px);
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.32);
}

/* Separación entre secciones */
.lp-section + .lp-section {
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

/* =========
   NAVBAR (roja/blanca)
   ========= */

/* Ajusta el body.elementor-page-5349 .lp-navbar al que uses en Elementor */
.lp-navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: rgba(176, 0, 48, 0.96);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.16);
}

.lp-navbar .lp-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
}

.lp-navbar-logo {
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-size: 0.9rem;
  color: #ffffff;
}

.lp-navbar-menu {
  display: flex;
  gap: 22px;
}

.lp-navbar-menu a {
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.13em;
  text-decoration: none;
  color: rgba(255, 255, 255, 0.82);
  position: relative;
  padding-bottom: 4px;
}

.lp-navbar-menu a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 2px;
  background: #ffffff;
  transition: width 0.18s ease;
}

.lp-navbar-menu a:hover {
  color: #ffffff;
}

.lp-navbar-menu a:hover::after {
  width: 100%;
}

/* =========
   HERO (por si haces una sección principal)
   ========= */

.hero-pesebres {
  padding: 110px 20px 80px;
  text-align: center;
}

.hero-pesebres h1 {
  font-size: 2.8rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 18px;
}

.hero-pesebres p {
  max-width: 620px;
  margin: 0 auto 26px;
}

/* =========
   CONTADOR PERSONALIZADO (si usas #custom-countdown-timer)
   ========= */

#custom-countdown-timer {
  margin: 32px auto 0;
  max-width: 600px;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 18px;
  flex-wrap: wrap;
}

#custom-countdown-timer .countdown-unit {
  display: flex;
  flex-direction: column;
  align-items: center;
}

#custom-countdown-timer .countdown-number {
  font-size: 3rem;
  font-weight: 700;
  padding: 10px 18px;
  border-radius: 16px;
  background: rgba(0, 0, 0, 0.24);
  color: #ffffff;
  letter-spacing: 0.08em;
}

#custom-countdown-timer .countdown-label {
  margin-top: 8px;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: rgba(255, 255, 255, 0.85);
}

#custom-countdown-timer .separator {
  font-size: 2.3rem;
  align-self: center;
  padding: 0 2px;
}

/* Responsivo */
@media (max-width: 768px) {
  .lp-section {
    padding: 60px 16px;
  }

  .lp-title {
    font-size: 1.9rem;
  }

  .hero-pesebres h1 {
    font-size: 2.2rem;
  }

  #custom-countdown-timer .countdown-number {
    font-size: 2.1rem;
    padding: 8px 12px;
  }
}


/*COPOS DE NUEVE*/


.snow-layer {
  pointer-events: none;
  position: fixed;
  inset: 0;
  z-index: 999;
  overflow: hidden;
}

/* Capa 1: Copos pequeños y muy densos */
.snow-layer {
  background-image:
    /* Múltiples copos pequeños (tamaño 2px-3px) */
    radial-gradient(2px 2px at 4% 8%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(2px 2px at 10% 18%, rgba(255, 255, 255, 0.8) 50%, transparent 51%),
    radial-gradient(3px 3px at 26% 12%, rgba(255, 255, 255, 0.85) 50%, transparent 51%),
    radial-gradient(2px 2px at 40% 6%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(3px 3px at 54% 16%, rgba(255, 255, 255, 0.85) 50%, transparent 51%),
    radial-gradient(2px 2px at 63% 5%, rgba(255, 255, 255, 0.85) 50%, transparent 51%),
    radial-gradient(2px 2px at 79% 14%, rgba(255, 255, 255, 0.8) 50%, transparent 51%),
    radial-gradient(3px 3px at 7% 45%, rgba(255, 255, 255, 0.85) 50%, transparent 51%),
    radial-gradient(2px 2px at 21% 40%, rgba(255, 255, 255, 0.8) 50%, transparent 51%),
    radial-gradient(3px 3px at 35% 46%, rgba(255, 255, 255, 0.85) 50%, transparent 51%),
    radial-gradient(2px 2px at 49% 48%, rgba(255, 255, 255, 0.85) 50%, transparent 51%),
    radial-gradient(3px 3px at 64% 44%, rgba(255, 255, 255, 0.85) 50%, transparent 51%),
    radial-gradient(2px 2px at 80% 50%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(3px 3px at 18% 90%, rgba(255, 255, 255, 0.85) 50%, transparent 51%),
    radial-gradient(2px 2px at 33% 86%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(3px 3px at 41% 82%, rgba(255, 255, 255, 0.85) 50%, transparent 51%),
    radial-gradient(2px 2px at 56% 76%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(3px 3px at 71% 79%, rgba(255, 255, 255, 0.8) 50%, transparent 51%);
  
  /* CAMBIO CLAVE: Repetir el patrón y reducir su tamaño para más densidad */
  background-repeat: repeat; 
  background-size: 150px 150px; 
  animation: snowLayer1 26s linear infinite;
  opacity: 0.78;
}

/* Capa 2: Copos medianos, muy densos */
.snow-layer::before {
  content: "";
  position: absolute;
  inset: -30%;
  background-image:
    /* Múltiples copos medianos (tamaño 4px-5px) */
    radial-gradient(4px 4px at 12% 18%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(5px 5px at 22% 8%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(4px 4px at 34% 20%, rgba(255, 255, 255, 0.85) 50%, transparent 51%),
    radial-gradient(5px 5px at 72% 9%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(4px 4px at 84% 18%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(5px 5px at 30% 38%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(4px 4px at 46% 50%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(5px 5px at 78% 53%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(4px 4px at 9% 78%, rgba(255, 255, 255, 0.85) 50%, transparent 51%),
    radial-gradient(5px 5px at 23% 88%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(4px 4px at 39% 72%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(5px 5px at 71% 78%, rgba(255, 255, 255, 0.9) 50%, transparent 51%);

  /* CAMBIO CLAVE: Repetir el patrón y reducir su tamaño */
  background-repeat: repeat;
  background-size: 200px 200px;
  animation: snowLayer2 32s linear infinite;
  opacity: 0.55;
}

/* Capa 3: Copos grandes, muy densos */
.snow-layer::after {
  content: "";
  position: absolute;
  inset: -40%;
  background-image:
    /* Múltiples copos grandes (tamaño 7px-8px) */
    radial-gradient(7px 7px at 8% 28%, rgba(255, 255, 255, 0.95) 50%, transparent 51%),
    radial-gradient(8px 8px at 26% 16%, rgba(255, 255, 255, 0.95) 50%, transparent 51%),
    radial-gradient(7px 7px at 46% 26%, rgba(255, 255, 255, 0.95) 50%, transparent 51%),
    radial-gradient(8px 8px at 86% 30%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(7px 7px at 16% 60%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(8px 8px at 38% 70%, rgba(255, 255, 255, 0.95) 50%, transparent 51%),
    radial-gradient(7px 7px at 60% 58%, rgba(255, 255, 255, 0.9) 50%, transparent 51%),
    radial-gradient(8px 8px at 48% 82%, rgba(255, 255, 255, 0.95) 50%, transparent 51%),
    radial-gradient(7px 7px at 74% 90%, rgba(255, 255, 255, 0.9) 50%, transparent 51%);

  /* CAMBIO CLAVE: Repetir el patrón y reducir su tamaño */
  background-repeat: repeat;
  background-size: 250px 250px;
  animation: snowLayer3 40s linear infinite;
  opacity: 0.5;
}

/* Animaciones: (Se mantienen, usando transform para rendimiento) */

@keyframes snowLayer1 {
  0% {
    transform: translate3d(0, -6%, 0);
  }
  100% {
    transform: translate3d(-4%, 10%, 0);
  }
}

@keyframes snowLayer2 {
  0% {
    transform: translate3d(5%, -10%, 0);
  }
  100% {
    transform: translate3d(-7%, 14%, 0);
  }
}

@keyframes snowLayer3 {
  0% {
    transform: translate3d(-6%, -12%, 0);
  }
  100% {
    transform: translate3d(6%, 16%, 0);
  }
}/* End custom CSS */