.elementor-11 .elementor-element.elementor-element-b227bef{--display:flex;--min-height:70vh;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--justify-content:center;--overlay-opacity:0.8;}.elementor-11 .elementor-element.elementor-element-b227bef::before, .elementor-11 .elementor-element.elementor-element-b227bef > .elementor-background-video-container::before, .elementor-11 .elementor-element.elementor-element-b227bef > .e-con-inner > .elementor-background-video-container::before, .elementor-11 .elementor-element.elementor-element-b227bef > .elementor-background-slideshow::before, .elementor-11 .elementor-element.elementor-element-b227bef > .e-con-inner > .elementor-background-slideshow::before, .elementor-11 .elementor-element.elementor-element-b227bef > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-color:var( --e-global-color-6db878d );--background-overlay:'';}.elementor-11 .elementor-element.elementor-element-b227bef .elementor-background-slideshow__slide__image{background-position:top center;}.elementor-11 .elementor-element.elementor-element-b227bef > .elementor-shape-bottom .elementor-shape-fill, .elementor-11 .elementor-element.elementor-element-b227bef > .e-con-inner > .elementor-shape-bottom .elementor-shape-fill{fill:var( --e-global-color-6db878d );}.elementor-11 .elementor-element.elementor-element-b227bef > .elementor-shape-bottom svg, .elementor-11 .elementor-element.elementor-element-b227bef > .e-con-inner > .elementor-shape-bottom svg{width:calc(100% + 1.3px);height:49px;}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Montserrat;font-size:var( --e-global-typography-primary-font-size );font-weight:var( --e-global-typography-primary-font-weight );line-height:var( --e-global-typography-primary-line-height );color:var( --e-global-color-primary );}.elementor-11 .elementor-element.elementor-element-f6802bd{text-align:center;}.elementor-11 .elementor-element.elementor-element-f6802bd .elementor-heading-title{font-family:"Arya", Montserrat;font-size:48px;font-weight:600;line-height:90px;letter-spacing:1px;text-shadow:0px 0px 10px #641919;color:var( --e-global-color-41ee71c );}.elementor-widget-button .elementor-button{background-color:var( --e-global-color-accent );font-family:var( --e-global-typography-accent-font-family ), Montserrat;font-size:var( --e-global-typography-accent-font-size );font-weight:var( --e-global-typography-accent-font-weight );text-transform:var( --e-global-typography-accent-text-transform );line-height:var( --e-global-typography-accent-line-height );}.elementor-11 .elementor-element.elementor-element-9368992.elementor-element{--align-self:center;}.elementor-11 .elementor-element.elementor-element-9368992 .elementor-button{border-style:none;}.elementor-11 .elementor-element.elementor-element-f08564e{--display:flex;}.elementor-11 .elementor-element.elementor-element-45b4236 .elementor-heading-title{font-family:"Arya", Montserrat;font-size:36px;font-weight:600;color:var( --e-global-color-41ee71c );}.elementor-11 .elementor-element.elementor-element-9914a36{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-widget-loop-grid .elementor-button{background-color:var( --e-global-color-accent );font-family:var( --e-global-typography-accent-font-family ), Montserrat;font-size:var( --e-global-typography-accent-font-size );font-weight:var( --e-global-typography-accent-font-weight );text-transform:var( --e-global-typography-accent-text-transform );line-height:var( --e-global-typography-accent-line-height );}.elementor-widget-loop-grid .elementor-pagination{font-family:var( --e-global-typography-secondary-font-family ), Montserrat;font-size:var( --e-global-typography-secondary-font-size );font-weight:var( --e-global-typography-secondary-font-weight );line-height:var( --e-global-typography-secondary-line-height );}.elementor-widget-loop-grid .e-load-more-message{font-family:var( --e-global-typography-secondary-font-family ), Montserrat;font-size:var( --e-global-typography-secondary-font-size );font-weight:var( --e-global-typography-secondary-font-weight );line-height:var( --e-global-typography-secondary-line-height );}.elementor-11 .elementor-element.elementor-element-2c20bb1{--grid-columns:3;}.elementor-11 .elementor-element.elementor-element-2c20bb1 .elementor-loop-container{grid-auto-rows:1fr;}.elementor-11 .elementor-element.elementor-element-2c20bb1 .e-loop-item > .elementor-section, .elementor-11 .elementor-element.elementor-element-2c20bb1 .e-loop-item > .elementor-section > .elementor-container, .elementor-11 .elementor-element.elementor-element-2c20bb1 .e-loop-item > .e-con, .elementor-11 .elementor-element.elementor-element-2c20bb1 .e-loop-item .elementor-section-wrap  > .e-con{height:100%;}.elementor-11 .elementor-element.elementor-element-d95946c{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}:root{--page-title-display:none;}@media(max-width:1024px){.elementor-widget-heading .elementor-heading-title{font-size:var( --e-global-typography-primary-font-size );line-height:var( --e-global-typography-primary-line-height );}.elementor-widget-button .elementor-button{font-size:var( --e-global-typography-accent-font-size );line-height:var( --e-global-typography-accent-line-height );}.elementor-widget-loop-grid .elementor-pagination{font-size:var( --e-global-typography-secondary-font-size );line-height:var( --e-global-typography-secondary-line-height );}.elementor-widget-loop-grid .elementor-button{font-size:var( --e-global-typography-accent-font-size );line-height:var( --e-global-typography-accent-line-height );}.elementor-widget-loop-grid .e-load-more-message{font-size:var( --e-global-typography-secondary-font-size );line-height:var( --e-global-typography-secondary-line-height );}.elementor-11 .elementor-element.elementor-element-2c20bb1{--grid-columns:2;}}@media(max-width:767px){.elementor-widget-heading .elementor-heading-title{font-size:var( --e-global-typography-primary-font-size );line-height:var( --e-global-typography-primary-line-height );}.elementor-widget-button .elementor-button{font-size:var( --e-global-typography-accent-font-size );line-height:var( --e-global-typography-accent-line-height );}.elementor-widget-loop-grid .elementor-pagination{font-size:var( --e-global-typography-secondary-font-size );line-height:var( --e-global-typography-secondary-line-height );}.elementor-widget-loop-grid .elementor-button{font-size:var( --e-global-typography-accent-font-size );line-height:var( --e-global-typography-accent-line-height );}.elementor-widget-loop-grid .e-load-more-message{font-size:var( --e-global-typography-secondary-font-size );line-height:var( --e-global-typography-secondary-line-height );}.elementor-11 .elementor-element.elementor-element-2c20bb1{--grid-columns:1;}}/* Start custom CSS */.glitter-section {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,0.35) 0 1px, transparent 2px),
    radial-gradient(circle at 70% 60%, rgba(255,255,255,0.25) 0 1px, transparent 2px),
    radial-gradient(circle at 40% 80%, rgba(255,255,255,0.3) 0 1px, transparent 2px),
    linear-gradient(135deg, #ff1493 0%, #d41473 45%, #ff4eb8 100%);
  background-size: 80px 80px, 120px 120px, 60px 60px, cover;
}

.glitter-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle, rgba(255,255,255,0.9) 0 1px, transparent 2px),
    radial-gradient(circle, rgba(255,255,255,0.5) 0 1px, transparent 2px);
  background-size: 55px 55px, 90px 90px;
  opacity: 0.35;
  animation: glitterMove 8s linear infinite;
  mix-blend-mode: screen;
}

@keyframes glitterMove {
  from {
    background-position: 0 0, 0 0;
  }
  to {
    background-position: 120px 80px, -90px 120px;
  }
}

.glitter-title,
.glitter-subtitle {
  position: relative;
  display: inline-block;
  color: #ffffff;
  font-weight: 900;
  text-shadow:
    0 0 4px #ff69c8,
    0 0 8px #ff1493,
    0 0 14px #ffffff;
}

.glitter-title {
  font-size: clamp(4rem, 8vw, 8rem);
}

.glitter-subtitle {
  font-size: clamp(2.4rem, 5vw, 5rem);
}

.glitter-title::after,
.glitter-subtitle::after {
  content: attr(data-text);
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    transparent 0%,
    rgba(255,255,255,0.1) 35%,
    rgba(255,255,255,0.95) 50%,
    rgba(255,255,255,0.1) 65%,
    transparent 100%
  );
  background-size: 220% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: glitterText 3s ease-in-out infinite;
  pointer-events: none;
}

@keyframes glitterText {
  0% {
    background-position: 220% 0;
  }
  100% {
    background-position: -220% 0;
  }
}

.glitter-button .elementor-button,
.elementor-button.glitter-button {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #ff1493, #ff4eb8);
  border: 2px solid #ffffff;
  box-shadow:
    0 0 10px rgba(255,255,255,0.7),
    0 0 20px rgba(255,20,147,0.8);
}

.glitter-button .elementor-button::before,
.elementor-button.glitter-button::before {
  content: "";
  position: absolute;
  top: 0;
  left: -120%;
  width: 80%;
  height: 100%;
  background: linear-gradient(
    120deg,
    transparent,
    rgba(255,255,255,0.8),
    transparent
  );
  transform: skewX(-20deg);
  animation: buttonShine 2.8s infinite;
}

@keyframes buttonShine {
  0% {
    left: -120%;
  }
  60% {
    left: 140%;
  }
  100% {
    left: 140%;
  }
}

/* =========================
   GLITTER SHIMMER TEXT
========================= */

.glitter-shimmer-title,
.glitter-shimmer-subtitle {
  position: relative;
  display: inline-block;
  font-weight: 900;
  color: #fff;
  line-height: 1.05;

  text-shadow:
    0 0 2px #ffffff,
    0 0 6px #ff4fbd,
    0 0 12px #ff1493,
    0 0 22px rgba(255, 20, 147, 0.85);
}

.glitter-shimmer-title {
  font-size: clamp(4rem, 8vw, 8rem);
}

.glitter-shimmer-subtitle {
  font-size: clamp(2.4rem, 4.8vw, 4.8rem);
}

/* capa de purpurina */
.glitter-shimmer-title::before,
.glitter-shimmer-subtitle::before {
  content: "";
  position: absolute;
  inset: -6px;
  pointer-events: none;

  background:
    radial-gradient(circle, rgba(255,255,255,1) 0 1px, transparent 1.6px),
    radial-gradient(circle, rgba(255,210,250,0.95) 0 1px, transparent 1.8px),
    radial-gradient(circle, rgba(255,255,255,0.75) 0 0.8px, transparent 1.4px),
    linear-gradient(
      110deg,
      transparent 0%,
      transparent 35%,
      rgba(255,255,255,0.95) 48%,
      rgba(255,210,255,1) 50%,
      rgba(255,255,255,0.9) 52%,
      transparent 65%,
      transparent 100%
    );

  background-size:
    18px 18px,
    27px 27px,
    11px 11px,
    220% 100%;

  background-position:
    0 0,
    8px 4px,
    3px 7px,
    220% 0;

  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;

  animation:
    glitterSparkle 1.6s steps(2, end) infinite,
    shimmerSweep 3.2s ease-in-out infinite;

  mix-blend-mode: screen;
  opacity: 0.95;
}

/* brillo extra puntual */
.glitter-shimmer-title::after,
.glitter-shimmer-subtitle::after {
  content: "";
  position: absolute;
  inset: -8px;
  pointer-events: none;

  background:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,1) 0 1px, transparent 3px),
    radial-gradient(circle at 70% 40%, rgba(255,255,255,0.95) 0 1px, transparent 4px),
    radial-gradient(circle at 45% 75%, rgba(255,220,255,1) 0 1px, transparent 3px);

  background-size: 120px 70px;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;

  animation: glitterBlink 2.4s infinite alternate;
  opacity: 0.75;
}

@keyframes shimmerSweep {
  0% {
    background-position:
      0 0,
      8px 4px,
      3px 7px,
      220% 0;
  }

  100% {
    background-position:
      12px 8px,
      -10px 12px,
      8px -5px,
      -220% 0;
  }
}

@keyframes glitterSparkle {
  0%, 100% {
    opacity: 0.85;
    filter: brightness(1);
  }

  50% {
    opacity: 1;
    filter: brightness(1.45);
  }
}

@keyframes glitterBlink {
  0% {
    opacity: 0.35;
    transform: translateX(0);
  }

  100% {
    opacity: 0.95;
    transform: translateX(6px);
  }
}

/* =========================
   GLITTER SHIMMER BUTTON
========================= */

.glitter-shimmer-button .elementor-button {
  position: relative;
  overflow: hidden;
  border: 2px solid #fff;
  background: linear-gradient(135deg, #ff1493, #ff4fbd, #ff1493);
  box-shadow:
    0 0 8px rgba(255,255,255,0.7),
    0 0 18px rgba(255,20,147,0.9);
}

.glitter-shimmer-button .elementor-button::before {
  content: "";
  position: absolute;
  inset: 0;

  background:
    radial-gradient(circle, rgba(255,255,255,1) 0 1px, transparent 1.6px),
    linear-gradient(
      110deg,
      transparent 0%,
      transparent 35%,
      rgba(255,255,255,0.95) 50%,
      transparent 65%,
      transparent 100%
    );

  background-size: 16px 16px, 220% 100%;
  background-position: 0 0, 220% 0;

  animation:
    buttonGlitter 1.5s steps(2, end) infinite,
    buttonShimmer 2.8s ease-in-out infinite;

  opacity: 0.75;
  pointer-events: none;
}

.glitter-shimmer-button .elementor-button-text {
  position: relative;
  z-index: 2;
}

@keyframes buttonShimmer {
  from {
    background-position: 0 0, 220% 0;
  }

  to {
    background-position: 12px 8px, -220% 0;
  }
}

@keyframes buttonGlitter {
  0%, 100% {
    filter: brightness(1);
  }

  50% {
    filter: brightness(1.5);
  }
}

/* Panel lateral del carrito de Elementor */
.elementor-menu-cart__container {
  font-size: 14px;
}

/* Caja interior */
.elementor-menu-cart__main {
  font-size: 14px;
}

/* Título del panel */
.elementor-menu-cart__main .elementor-menu-cart__header,
.elementor-menu-cart__main .elementor-menu-cart__title {
  font-size: 18px;
  line-height: 1.2;
}

/* Nombre del producto */
.elementor-menu-cart__product-name,
.elementor-menu-cart__product-name a {
  font-size: 14px;
  line-height: 1.3;
  font-weight: 500;
}

/* Precio, cantidad y subtotal del producto */
.elementor-menu-cart__product-price,
.elementor-menu-cart__product-quantity,
.elementor-menu-cart__product-subtotal,
.elementor-menu-cart__subtotal,
.elementor-menu-cart__subtotal strong,
.elementor-menu-cart__subtotal .amount {
  font-size: 13px;
  line-height: 1.3;
}

/* Botón de eliminar producto */
.elementor-menu-cart__product-remove {
  font-size: 14px;
}

/* Botones Ver carrito / Finalizar compra */
.elementor-menu-cart__footer-buttons .elementor-button {
  font-size: 13px;
  padding: 10px 14px;
  line-height: 1.2;
}

/* Espaciado entre productos */
.elementor-menu-cart__product {
  padding: 12px 0;
}

/* Imagen de producto */
.elementor-menu-cart__product-image img {
  width: 60px;
  height: auto;
}

/* Icono del carrito */
.elementor-menu-cart__toggle .elementor-button-icon {
  font-size: 20px;
}

/* Contador */
.elementor-menu-cart__toggle .elementor-button-icon-qty {
  font-size: 11px;
  min-width: 18px;
  height: 18px;
  line-height: 18px;
}/* End custom CSS */