.elementor-6908 .elementor-element.elementor-element-1646f8c{--display:flex;}.elementor-6908 .elementor-element.elementor-element-2859322{--display:flex;--min-height:400px;--flex-direction:column;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--justify-content:center;--align-items:center;}.elementor-6908 .elementor-element.elementor-element-2859322:not(.elementor-motion-effects-element-type-background), .elementor-6908 .elementor-element.elementor-element-2859322 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFFFF;}.elementor-6908 .elementor-element.elementor-element-2859322 > .elementor-shape-top svg, .elementor-6908 .elementor-element.elementor-element-2859322 > .e-con-inner > .elementor-shape-top svg{height:50px;}.elementor-6908 .elementor-element.elementor-element-2859322 > .elementor-shape-top, .elementor-6908 .elementor-element.elementor-element-2859322 > .e-con-inner > .elementor-shape-top{z-index:2;pointer-events:none;}.elementor-6908 .elementor-element.elementor-element-0917068 .elementor-heading-title{font-family:"Montserrat", Sans-serif;font-size:32px;font-weight:600;}.elementor-6908 .elementor-element.elementor-element-5c0218d{text-align:center;font-family:"Montserrat", Sans-serif;font-size:16px;font-weight:400;}.elementor-6908 .elementor-element.elementor-element-3b0172b{--display:flex;--flex-direction:row-reverse;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap-reverse;--align-items:center;--gap:0px 0px;--row-gap:0px;--column-gap:0px;}.elementor-6908 .elementor-element.elementor-element-3b0172b:not(.elementor-motion-effects-element-type-background), .elementor-6908 .elementor-element.elementor-element-3b0172b > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F0EDE8;}.elementor-6908 .elementor-element.elementor-element-3b0172b > .elementor-shape-bottom svg, .elementor-6908 .elementor-element.elementor-element-3b0172b > .e-con-inner > .elementor-shape-bottom svg{height:96px;}.elementor-6908 .elementor-element.elementor-element-d3dcdbd{--display:flex;--flex-direction:column;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--align-items:center;}.elementor-6908 .elementor-element.elementor-element-f709023 img{width:80%;border-radius:15px 15px 15px 15px;}.elementor-6908 .elementor-element.elementor-element-b724ab2{--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-6908 .elementor-element.elementor-element-c755ab0 .elementor-heading-title{font-family:"Montserrat", Sans-serif;font-size:16px;font-weight:700;text-transform:uppercase;color:#EB6D10;}.elementor-6908 .elementor-element.elementor-element-816207e .elementor-heading-title{font-family:"Montserrat", Sans-serif;font-size:32px;font-weight:600;}.elementor-6908 .elementor-element.elementor-element-cd7ee71{font-family:"Montserrat", Sans-serif;font-size:16px;font-weight:400;}.elementor-6908 .elementor-element.elementor-element-d0b1ccc{--display:flex;--min-height:865px;--justify-content:center;}.elementor-6908 .elementor-element.elementor-element-d0b1ccc:not(.elementor-motion-effects-element-type-background), .elementor-6908 .elementor-element.elementor-element-d0b1ccc > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FEFEFE;}.elementor-6908 .elementor-element.elementor-element-b9851fd{text-align:center;}.elementor-6908 .elementor-element.elementor-element-b9851fd .elementor-heading-title{font-family:"Montserrat", Sans-serif;font-size:32px;font-weight:900;}.elementor-6908 .elementor-element.elementor-element-ab813f9{--spacer-size:50px;}.elementor-6908 .elementor-element.elementor-element-9ad987e{--display:flex;--min-height:1100px;--justify-content:flex-start;}.elementor-6908 .elementor-element.elementor-element-34dd403{--display:flex;}.elementor-6908 .elementor-element.elementor-element-1c170a8 > .elementor-widget-container{margin:0px 0px 0px 0px;padding:0px 0px 0px 0px;}.elementor-6908 .elementor-element.elementor-element-379ffce{--display:flex;}.elementor-6908 .elementor-element.elementor-element-775052a{--display:flex;--min-height:700px;--justify-content:center;}.elementor-6908 .elementor-element.elementor-element-9592a4c{--display:flex;--min-height:600px;--justify-content:center;}:root{--page-title-display:none;}.elementor-widget .tippy-tooltip .tippy-content{text-align:center;}@media(min-width:768px){.elementor-6908 .elementor-element.elementor-element-2859322{--content-width:850px;}.elementor-6908 .elementor-element.elementor-element-d3dcdbd{--width:50%;}.elementor-6908 .elementor-element.elementor-element-b724ab2{--width:50%;}.elementor-6908 .elementor-element.elementor-element-d0b1ccc{--content-width:968px;}}@media(max-width:1024px){.elementor-6908 .elementor-element.elementor-element-0917068{text-align:center;}.elementor-6908 .elementor-element.elementor-element-0917068 .elementor-heading-title{font-size:32px;letter-spacing:1.4px;}}@media(max-width:767px){.elementor-6908 .elementor-element.elementor-element-0917068 .elementor-heading-title{font-size:24px;}.elementor-6908 .elementor-element.elementor-element-d3dcdbd{--min-height:539px;--justify-content:flex-start;}.elementor-6908 .elementor-element.elementor-element-f709023 > .elementor-widget-container{padding:0px 0px 0px 0px;}.elementor-6908 .elementor-element.elementor-element-816207e .elementor-heading-title{font-size:24px;}.elementor-6908 .elementor-element.elementor-element-cd7ee71{font-size:14px;}.elementor-6908 .elementor-element.elementor-element-b9851fd .elementor-heading-title{font-size:24px;}}/* Start custom CSS for container, class: .elementor-element-1646f8c */:root {
  --naranja: #D68552;
  --naranja-hover: #c47645;
}

.hero-victoria {
  position: relative !important; width: 100vw !important; max-width: 100vw !important;
  height: 100vh !important; min-height: 640px !important;
  margin-top: -10px !important; margin-left: calc(-50vw + 50%) !important;
  padding: 0 !important; overflow: hidden;
  display: flex !important; align-items: center; justify-content: center;
  font-family: 'Montserrat', sans-serif; background: #0a0a0a;
}
.hero-victoria *, .hero-victoria *::before, .hero-victoria *::after { box-sizing: border-box; }

/* Cubre la línea con el color del hero */
.hero-victoria::before {
  content: '';
  position: absolute;
  top: -5px;
  left: 0;
  right: 0;
  height: 6px;
  background: #0a0a0a;
  z-index: 10;
}

/* ════════════════════════════════════════
   SLIDER Y FONDOS
════════════════════════════════════════ */
.hero-slider { position: absolute; inset: 0; z-index: 0; }
.hero-slide {
  position: absolute; inset: 0; opacity: 0; visibility: hidden;
  transition: opacity 1.5s ease-in-out, visibility 1.5s;
}
.hero-slide.active { opacity: 1; visibility: visible; }
.hero-slide img, .hero-slide video {
  width: 100%; height: 100%; object-fit: cover; display: block;
  transform: scale(1.08); transition: transform 8s cubic-bezier(0.23,1,0.32,1);
}
.hero-slide.active img, .hero-slide.active video { transform: scale(1); }

.hero-overlay {
  position: absolute; inset: 0; z-index: 2;
  background: radial-gradient(circle at center, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0.8) 100%),
              linear-gradient(to bottom, rgba(0,0,0,0.4) 0%, rgba(0,0,0,0.1) 40%, rgba(0,0,0,0.7) 100%);
}

/* ════════════════════════════════════════
   CONTENIDO CENTRAL
════════════════════════════════════════ */
.hero-contenido {
  position: relative; z-index: 3; text-align: center;
  padding: 0 24px 100px 24px; 
  max-width: 900px; display: flex; flex-direction: column; align-items: center;
}

.hero-tag {
  font-size: 0.65rem; font-weight: 800; letter-spacing: 0.35em; text-transform: uppercase;
  color: rgba(255,255,255,0.9); margin-bottom: 29px;
  opacity: 0; animation: fadeUp 0.8s ease 0.4s forwards;
}

.hero-titulo {
  font-family: 'Montserrat', sans-serif; font-size: clamp(3.5rem, 8vw, 6.5rem);
  font-weight: 900; color: #fff; letter-spacing: -0.02em; line-height: 0.95; margin-bottom: 20px;
  text-shadow: 0 10px 30px rgba(0,0,0,0.5);
  opacity: 0; animation: fadeUp 0.8s ease 0.7s forwards;
}

.hero-linea {
  width: 0; height: 3px; background: linear-gradient(90deg, var(--naranja), #fff);
  border-radius: 2px; margin: 0 auto 32px;
  animation: lineaExpand 0.8s ease 1s forwards;
}

.hero-desc {
  font-size: 1.05rem; font-weight: 500; color: rgba(255,255,255,0.85);
  line-height: 1.8; max-width: 650px; margin: 0 auto 40px;
  opacity: 0; animation: fadeUp 0.8s ease 1.2s forwards;
}

/* ════════════════════════════════════════
   BOTONES
════════════════════════════════════════ */
.hero-btns {
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
  opacity: 0; animation: fadeUp 0.8s ease 1.5s forwards;
}

.btn-principal, .btn-secundario {
  text-decoration: none !important; 
  border-bottom: none !important;
}

.btn-principal {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 32px; border-radius: 50px;
  background: var(--naranja); color: #fff !important;
  font-family: 'Montserrat', sans-serif; font-size: 0.75rem; font-weight: 800;
  letter-spacing: 0.1em; text-transform: uppercase; 
  transition: background 0.2s, transform 0.2s;
}
.btn-principal:hover {
  background: var(--naranja-hover); transform: translateY(-3px);
}
.btn-principal svg { width:16px; height:16px; fill:none; stroke:#fff; stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round; transition:transform 0.2s; }
.btn-principal:hover svg { transform: translateX(3px); }

.btn-secundario {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 32px; border-radius: 50px;
  border: 1.5px solid rgba(255,255,255,0.5) !important; color: #fff !important;
  font-family: 'Montserrat', sans-serif; font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase; 
  backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px);
  transition: background 0.2s, border-color 0.2s, transform 0.2s;
}
.btn-secundario:hover {
  background: rgba(255,255,255,0.15); border-color: #fff !important; transform: translateY(-3px);
}
.btn-secundario svg { width:16px; height:16px; fill:none; stroke:#fff; stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round; transition:transform 0.2s; }
.btn-secundario:hover svg { transform: translateX(3px); }

/* ════════════════════════════════════════
   SCROLL (Ajustado un poco más arriba)
════════════════════════════════════════ */
.hero-scroll {
  position: absolute; 
  bottom: 50px; /* <--- Subido de 30px a 50px */
  left: 50%; transform: translateX(-50%); z-index: 3;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  opacity: 0; animation: fadeIn 0.8s ease 2s forwards;
}
.hero-scroll span { font-size: 0.55rem; font-weight: 700; letter-spacing: 0.25em; text-transform: uppercase; color: rgba(255,255,255,0.6); }
.hero-scroll-flechas { display: flex; flex-direction: column; align-items: center; }
.hero-scroll-flechas svg { width:30px; height: 20px; display: block; fill: none; stroke: #fff; stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; margin-top: -8px; }
.hero-scroll-flechas svg:nth-child(1) { animation: flechaPulse 1.5s ease infinite 0s; opacity: 1; }
.hero-scroll-flechas svg:nth-child(2) { animation: flechaPulse 1.5s ease infinite 0.2s; opacity: 0.6; }
.hero-scroll-flechas svg:nth-child(3) { animation: flechaPulse 1.5s ease infinite 0.4s; opacity: 0.3; }


/* ════════════════════════════════════════
   ANIMACIONES Y RESPONSIVE
════════════════════════════════════════ */
@keyframes fadeUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes lineaExpand { from { width: 0; } to { width: 70px; } }
@keyframes flechaPulse {
  0%   { transform: translateY(-3px); }
  50%  { transform: translateY(3px);  }
  100% { transform: translateY(-3px); }
    }

@media (max-width: 768px) {
  .hero-titulo { font-size: 3rem; }
  .hero-desc { font-size: 0.95rem; }
  .hero-contenido { padding-bottom: 80px; }
  .hero-btns { flex-direction: column; width: 100%; max-width: 300px; }
  .btn-principal, .btn-secundario { width: 100%; justify-content: center; }
  .hero-scroll { bottom: 40px; } /* <--- Subido de 20px a 40px en móvil */
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-2859322 */:root {
  --naranja: #D68552;
  --teal: #03586A;
}

/* ── Contenedor sección ── */
.elementor-6908 .elementor-element.elementor-element-2859322 {
  background: #f0ede8 !important;
  padding: 80px 32px !important;
  text-align: center !important;
}

/* ── Tag naranja arriba ── */
.elementor-6908 .elementor-element.elementor-element-2859322 .intro-tag {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.6rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.35em !important;
  text-transform: uppercase !important;
  color: var(--naranja) !important;
  display: block !important;
  margin-bottom: 18px !important;
}

/* ── H2 título ── */
.elementor-6908 .elementor-element.elementor-element-2859322 h2,
.elementor-6908 .elementor-element.elementor-element-2859322 .elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: clamp(1.9rem, 3.5vw, 2.8rem) !important;
  font-weight: 900 !important;
  color: #111 !important;
  line-height: 1.1 !important;
  letter-spacing: -0.03em !important;
  text-align: center !important;
  margin-bottom: 0 !important;
}

/* Palabras con color */
.elementor-6908 .elementor-element.elementor-element-2859322 h2 .teal,
.elementor-6908 .elementor-element.elementor-element-2859322 .elementor-heading-title .teal {
  color: var(--teal) !important;
}
.elementor-6908 .elementor-element.elementor-element-2859322 h2 .naranja,
.elementor-6908 .elementor-element.elementor-element-2859322 .elementor-heading-title .naranja {
  color: var(--naranja) !important;
}

/* ── Línea degradada debajo del H2 ── */
.elementor-6908 .elementor-element.elementor-element-2859322 h2::after,
.elementor-6908 .elementor-element.elementor-element-2859322 .elementor-heading-title::after {
  content: '' !important;
  display: block !important;
  width: 0 !important;
  height: 3px !important;
  background: linear-gradient(90deg, var(--teal), var(--naranja)) !important;
  border-radius: 2px !important;
  margin: 18px auto 28px !important;
  animation: introLinea 0.8s ease 0.3s forwards !important;
}

/* ── Párrafo ── */
.elementor-6908 .elementor-element.elementor-element-2859322 p,
.elementor-6908 .elementor-element.elementor-element-2859322 .elementor-text-editor p {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.92rem !important;
  font-weight: 500 !important;
  color: #666 !important;
  line-height: 2 !important;
  text-align: center !important;
  max-width: 780px !important;
  margin: 0 auto !important;
}

.elementor-6908 .elementor-element.elementor-element-2859322 p strong,
.elementor-6908 .elementor-element.elementor-element-2859322 .elementor-text-editor strong {
  font-weight: 700 !important;
  color: var(--teal) !important;
}


/* ── Animación línea ── */
@keyframes introLinea {
  from { width: 0; }
  to   { width: 60px; }
}

/* ── Responsive ── */
@media (max-width: 600px) {
  .elementor-6908 .elementor-element.elementor-element-2859322 {
    padding: 60px 20px !important;
  }
  .elementor-6908 .elementor-element.elementor-element-2859322 h2,
  .elementor-6908 .elementor-element.elementor-element-2859322 .elementor-heading-title {
    font-size: 1.8rem !important;
  }
  .elementor-6908 .elementor-element.elementor-element-2859322 p,
  .elementor-6908 .elementor-element.elementor-element-2859322 .elementor-text-editor p {
    font-size: 0.86rem !important;
  }
}/* End custom CSS */
/* Start custom CSS for image, class: .elementor-element-f709023 *//* Contenedor */
.elementor-6908 .elementor-element.elementor-element-f709023 {
  position: relative !important;
  overflow: hidden !important;
  border-radius: 12px !important;
  box-shadow: 0 16px 48px rgba(0,0,0,0.16) !important;
  display: block !important;
  cursor: pointer !important;
  width: 400px !important;         /* ← un poco más ancho */
  height: 570px !important;        /* ← un poco más alto */
  margin-top: 48px !important;
  margin-bottom: 48px !important;
  margin-left: auto !important;    /* ← centrado */
  margin-right: auto !important;   /* ← centrado */
}

/* Imagen */
.elementor-6908 .elementor-element.elementor-element-f709023 img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: top center !important;
  display: block !important;
  border-radius: 0 !important;
  transition: transform 0.6s ease, filter 0.5s ease !important;
}

/* Zoom + oscurecer al hover */
.elementor-6908 .elementor-element.elementor-element-f709023:hover img {
  transform: scale(1.05) !important;
  filter: brightness(0.82) !important;
}

/* Overlay degradado siempre visible abajo */
.elementor-6908 .elementor-element.elementor-element-f709023::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(
    to top,
    rgba(3,30,35,0.82) 0%,
    rgba(3,30,35,0.15) 50%,
    transparent 100%
  ) !important;
  z-index: 1 !important;
  opacity: 0 !important;
  transition: opacity 0.4s ease !important;
}

.elementor-6908 .elementor-element.elementor-element-f709023:hover::before {
  opacity: 1 !important;
}

/* Texto flotante abajo */
.elementor-6908 .elementor-element.elementor-element-f709023::after {
  content: 'Alfarería · La Victoria' !important;
  position: absolute !important;
  bottom: 28px !important;
  left: 24px !important;
  z-index: 2 !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.65rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.25em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.85) !important;
  opacity: 0 !important;
  transform: translateY(8px) !important;
  transition: opacity 0.4s ease 0.1s, transform 0.4s ease 0.1s !important;
}

.elementor-6908 .elementor-element.elementor-element-f709023:hover::after {
  opacity: 1 !important;
  transform: translateY(0) !important;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-3b0172b *//* ── Tag ── */
.elementor-6908 .elementor-element.elementor-element-3b0172b .proyecto-tag,
.elementor-6908 .elementor-element.elementor-element-3b0172b .elementor-widget-heading .proyecto-tag {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.55rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.35em !important;
  text-transform: uppercase !important;
  color: #D68552 !important;
  display: block !important;
  margin-bottom: 12px !important;
}
/* ── H2 título ── */
.elementor-6908 .elementor-element.elementor-element-3b0172b h2.elementor-heading-title {
  font-family: 'Montserrat', sans-serif !important;
  font-size: clamp(1.8rem, 3vw, 2.5rem) !important;
  font-weight: 900 !important;
  color: #111 !important;
  line-height: 1.1 !important;
  letter-spacing: -0.03em !important;
  text-transform: none !important;
  position: relative !important;
  display: inline-block !important;
  padding-bottom: 18px !important;
  margin-bottom: 20px !important;
}
/* ── Línea naranja a la IZQUIERDA con animación ── */
.elementor-6908 .elementor-element.elementor-element-3b0172b h2.elementor-heading-title::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  width: 44px !important;
  height: 4px !important;
  background: #D68552 !important;
  border-radius: 2px !important;
  box-shadow: 0 3px 10px rgba(214,133,82,0.5) !important;
  transition: width 0.4s cubic-bezier(0.23,1,0.32,1) !important;
}
/* Crece al pasar el cursor */
.elementor-6908 .elementor-element.elementor-element-3b0172b:hover h2.elementor-heading-title::after {
  width: 110px !important;
}
/* ── Párrafos ── */
.elementor-6908 .elementor-element.elementor-element-3b0172b .elementor-text-editor p {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  color: #555 !important;
  line-height: 1.95 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  margin-bottom: 18px !important;
}
.elementor-6908 .elementor-element.elementor-element-3b0172b .elementor-text-editor strong {
  font-weight: 600 !important;
  color: #03586A !important;
}

@media (max-width: 768px) {
  .elementor-6908 .elementor-element.elementor-element-3b0172b h2.elementor-heading-title { 
    font-size: 1.7rem !important; 
    text-align: center !important;
  }
  .elementor-6908 .elementor-element.elementor-element-3b0172b h4.elementor-heading-title { 
    text-align: center !important;  /* ← agrega esto */
  }
  .elementor-6908 .elementor-element.elementor-element-3b0172b .elementor-text-editor p { 
    font-size: 0.86rem !important; 
    text-align: center !important;
  }
  .elementor-6908 .elementor-element.elementor-element-3b0172b .elementor-image::after  { width: 40px !important; height: 40px !important; }
  .elementor-6908 .elementor-element.elementor-element-3b0172b .proyecto-tag            { text-align: center !important; }

  .elementor-6908 .elementor-element.elementor-element-3b0172b h2.elementor-heading-title::after {
    left: 50% !important;
    transform: translateX(-50%) !important;
  }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-d0b1ccc */:root {
  --color-panel: #D68552;
  --color-texto: #D68552;
  --sombra: rgba(0,0,0,0.14);
}

.vic-sl-wrap {
  width: 100%;
  font-family: 'Montserrat', sans-serif;
  padding-bottom: 20px;
  overflow: hidden;
}
.vic-sl-outer { overflow: hidden; width: 100%; }
.vic-sl-track {
  display: flex;
  gap: 28px;
  will-change: transform;
  padding: 16px 4px 20px;
}

.sala-wrap {
  flex: 0 0 300px;
  height: 420px;
  cursor: pointer;
}
.sala-card {
  position: relative;
  width: 100%; height: 100%;
  border-radius: 18px; overflow: hidden;
  box-shadow: 0 6px 24px var(--sombra);
  transition: transform 0.4s cubic-bezier(0.23,1,0.32,1), box-shadow 0.4s ease;
}
.sala-wrap:hover .sala-card {
  transform: translateY(-10px);
  box-shadow: 0 22px 55px rgba(0,0,0,0.24);
}
.sala-front { position: absolute; inset: 0; z-index: 1; }
.sala-front img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform 0.6s ease;
}
.sala-wrap:hover .sala-front img { transform: scale(1.07); }
.sala-front-header {
  position: absolute; top: 0; left: 0; right: 0;
  padding: 18px 20px;
  background: linear-gradient(to bottom, rgba(0,0,0,0.65) 0%, transparent 100%);
  display: flex; align-items: center; gap: 8px;
  z-index: 3; transition: opacity 0.3s ease;
}
.sala-wrap:hover .sala-front-header { opacity: 0; }
.sala-front-header .gad {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.48rem; font-weight: 700;
  color: rgba(255,255,255,0.9); line-height: 1.3;
  text-transform: uppercase;
  border-right: 1.5px solid rgba(255,255,255,0.4);
  padding-right: 8px; letter-spacing: 0.05em;
}
.sala-front-header .nombre {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.95rem; font-weight: 900; color: #fff;
}
.sala-front-tag {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 50px 24px 22px;
  background: linear-gradient(to top, rgba(0,0,0,0.75) 0%, transparent 100%);
  z-index: 3; transition: opacity 0.3s ease;
}
.sala-wrap:hover .sala-front-tag { opacity: 0; }
.sala-front-tag span {
  font-family: 'Montserrat', sans-serif;
  font-size: 1.4rem; font-weight: 900; color: #fff;
  text-transform: uppercase; letter-spacing: 0.04em;
  line-height: 1.1; display: block;
}
.sala-front-tag small {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.6rem; font-weight: 700;
  color: rgba(255,255,255,0.6); text-transform: uppercase;
  letter-spacing: 0.2em; margin-top: 4px; display: block;
}
.sala-back {
  position: absolute; inset: 0; z-index: 5;
  background: var(--color-panel);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 40px 30px; text-align: center;
  transform: translateY(100%);
  transition: transform 0.48s cubic-bezier(0.23,1,0.32,1);
}
.sala-wrap:hover .sala-back { transform: translateY(0%); }
.sala-back h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: 1.3rem; font-weight: 900; color: #fff;
  text-transform: uppercase; letter-spacing: 0.04em;
  line-height: 1.1; margin-bottom: 8px;
  opacity: 0; transform: translateY(16px);
  transition: opacity 0.32s ease 0.26s, transform 0.32s ease 0.26s;
}
.sala-wrap:hover .sala-back h3 { opacity: 1; transform: translateY(0); }
.sala-back .subtitulo {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.6rem; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(255,255,255,0.55); margin-bottom: 18px;
  opacity: 0; transform: translateY(12px);
  transition: opacity 0.32s ease 0.3s, transform 0.32s ease 0.3s;
}
.sala-wrap:hover .sala-back .subtitulo { opacity: 1; transform: translateY(0); }
.sala-back .linea {
  width: 0; height: 2px;
  background: rgba(255,255,255,0.35);
  margin: 0 auto 18px; border-radius: 1px;
  transition: width 0.38s ease 0.34s;
}
.sala-wrap:hover .sala-back .linea { width: 48px; }
.sala-back p {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.82rem; font-weight: 500;
  color: rgba(255,255,255,0.9); line-height: 1.8;
  opacity: 0; transform: translateY(14px);
  transition: opacity 0.32s ease 0.36s, transform 0.32s ease 0.36s;
}
.sala-wrap:hover .sala-back p { opacity: 1; transform: translateY(0); }
.sala-back a {
  font-family: 'Montserrat', sans-serif;
  display: inline-block; margin-top: 22px; padding: 10px 28px;
  border: 2px solid rgba(255,255,255,0.75); border-radius: 30px;
  color: #fff; font-size: 0.68rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase; text-decoration: none;
  opacity: 0; transform: translateY(14px);
  transition: opacity 0.32s ease 0.42s, transform 0.32s ease 0.42s, background 0.2s, color 0.2s;
}
.sala-wrap:hover .sala-back a { opacity: 1; transform: translateY(0); }
.sala-back a:hover { background: #fff; color: var(--color-texto); }
.sala-shine {
  position: absolute; inset: 0; z-index: 6;
  pointer-events: none; overflow: hidden; border-radius: 18px;
}
.sala-shine::after {
  content: ''; position: absolute;
  top: -60%; left: -80%; width: 55%; height: 220%;
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,0.62) 50%, transparent 70%);
  transform: skewX(-15deg); opacity: 0;
}
.sala-wrap:hover .sala-shine::after { animation: vic-shine 0.72s ease forwards; }
@keyframes vic-shine {
  0%  { opacity: 0; transform: skewX(-15deg) translateX(0); }
  12% { opacity: 1; }
  100%{ opacity: 0; transform: skewX(-15deg) translateX(450%); }
}
.vic-controls {
  display: flex; align-items: center;
  justify-content: center; gap: 14px; margin-top: 22px;
}
.vic-arr {
  display: flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 50%;
  background: #fff; border: 2px solid rgba(214,133,82,0.2);
  box-shadow: 0 3px 14px rgba(0,0,0,0.12);
  cursor: pointer; transition: background 0.22s, transform 0.22s;
}
.vic-arr:hover { background: #D68552; transform: scale(1.1); }
.vic-arr svg {
  width: 16px; height: 16px; fill: none;
  stroke: #D68552; stroke-width: 2.4;
  stroke-linecap: round; stroke-linejoin: round;
  transition: stroke 0.22s;
}
.vic-arr:hover svg { stroke: #fff; }
.vic-dots { display: flex; align-items: center; gap: 7px; }
.vic-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: rgba(214,133,82,0.25);
  border: none; cursor: pointer; padding: 0;
  transition: background 0.3s, transform 0.3s;
}
.vic-dot.on { background: #D68552; transform: scale(1.5); }
@media (max-width: 860px) {
  .sala-wrap { flex: 0 0 calc((100% - 28px) / 2); }
}
@media (max-width: 600px) {
  .vic-sl-track { gap: 16px; padding-left: 20px; padding-right: 20px; }
  .sala-wrap { flex: 0 0 calc(100vw - 40px); height: 420px; }
}
/* ── Línea naranja CENTRADA con animación ── */
.elementor-6908 .elementor-element.elementor-element-d0b1ccc h2.elementor-heading-title::after {
  content: '' !important;
  position: absolute !important;
  bottom: -20px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 44px !important;
  height: 4px !important;
  background: #D68552 !important;
  border-radius: 2px !important;
  box-shadow: 0 3px 10px rgba(214,133,82,0.5) !important;
  transition: width 0.4s cubic-bezier(0.23,1,0.32,1) !important;
}
/* Crece al pasar el cursor */
.elementor-6908 .elementor-element.elementor-element-d0b1ccc:hover h2.elementor-heading-title::after {
  width: 110px !important;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-d353cf4 */.vic-h3 {
  max-width: 1080px;
  margin: 0 auto;
  padding: 48px 24px 32px;
  text-align: center;
  font-family: 'Montserrat', sans-serif;
  border: none !important;
  outline: none !important;
  position: relative;
}
.vic-h3 .tag {
  font-size: 0.55rem; font-weight: 700;
  letter-spacing: 0.35em; text-transform: uppercase;
  color: 
#03586A; display: block; margin-bottom: 14px;
  opacity: 0; transform: translateY(16px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.vic-h3.visible .tag { opacity: 1; transform: translateY(0); }
.vic-h3 h2 {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 2.6rem; font-weight: 900 !important;
  color: #111; line-height: 1.1; letter-spacing: -0.03em;
  display: inline-block; position: relative;
  margin-bottom: 20px; padding-bottom: 16px;
  opacity: 0; transform: translateY(24px);
  transition: opacity 0.7s ease 0.1s, transform 0.7s ease 0.1s;
}
.vic-h3.visible h2 { opacity: 1; transform: translateY(0); }
/* ── Línea animada  ── */
.vic-h3 h2::after {
  content: ''; position: absolute;
  bottom: 0; left: 50%; transform: translateX(-50%);
  width: 0; height: 4px;
  border-radius: 2px; background: 
#03586A;
  transition: width 0.7s cubic-bezier(0.23,1,0.32,1) 0.5s;
}
.vic-h3.visible h2::after { width: 60px; }
.vic-h3 p {
  font-size: 0.95rem; font-weight: 500;
  color: #555; line-height: 1.85;
  max-width: 880px; margin: 0 auto 28px;
  opacity: 0; transform: translateY(20px);
  transition: opacity 0.7s ease 0.22s, transform 0.7s ease 0.22s;
}
.vic-h3.visible p { opacity: 1; transform: translateY(0); }
/* ── Link con línea hover ── */
.vic-h3 .vic-h3-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.75rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: 
#03586A; text-decoration: none;
  position: relative; padding-bottom: 3px;
  opacity: 0; transform: translateY(14px);
  transition: opacity 0.7s ease 0.34s, transform 0.7s ease 0.34s;
}
.vic-h3.visible .vic-h3-link { opacity: 1; transform: translateY(0); }
.vic-h3 .vic-h3-link::after {
  content: ''; position: absolute;
  bottom: 0; left: 0; width: 0; height: 2px;
  background: 
#03586A; border-radius: 1px;
  transition: width 0.3s ease;
}
.vic-h3 .vic-h3-link:hover::after { width: 100%; }
.vic-h3 .vic-h3-link svg {
  width: 16px; height: 16px; fill: none;
  stroke: 
#03586A; stroke-width: 2.3;
  stroke-linecap: round; stroke-linejoin: round;
  transition: transform 0.25s ease;
}
.vic-h3 .vic-h3-link:hover svg { transform: translateX(6px); }
/* ── Línea animada hover ── */
.vic-h3 h2 {
  display: inline-block !important;
  position: relative !important;
  padding-bottom: 18px !important;
}
.vic-h3 h2::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 60px !important;
  height: 4px !important;
  border-radius: 2px !important;
  background: 
#03586A !important;
  transition: width 0.4s ease !important;
}
.vic-h3:hover h2::after {
  width: 100px !important;
}
a, a:hover, a:focus, a:visited { text-decoration: none !important; }
/* Quitar línea Elementor */
.elementor-widget-html .vic-h3 { border: none !important; box-shadow: none !important; }
/* ── Responsive ── */
@media (max-width: 600px) {
  .vic-h3 h2 { font-size: 1.9rem; }
  .vic-h3 p  { font-size: 0.85rem; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-1c170a8 */.vic-overlay { background: #03586A !important; }
.vic-overlay a:hover { color: #03586A !important; }

* { margin: 0; padding: 0; box-sizing: border-box; }

.vic-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 28px;
  justify-content: center;
  max-width: 1080px;
  width: 100%;
  margin: 0 auto;
  padding: 20px;
  font-family: 'Montserrat', sans-serif;
}

.vic-card {
  position: relative;
  width: 300px;
  height: 420px;
  border-radius: 18px;
  overflow: hidden;
  cursor: pointer;
  box-shadow: 0 6px 24px var(--sombra);
  transition: transform 0.4s cubic-bezier(0.23,1,0.32,1), box-shadow 0.4s ease;
}
.vic-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 22px 55px rgba(0,0,0,0.24);
}

.vic-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s ease;
}
.vic-card:hover img {
  transform: scale(1.07);
}

.vic-header {
  position: absolute;
  top: 0; left: 0; right: 0;
  padding: 18px 20px;
  background: linear-gradient(to bottom, rgba(0,0,0,0.65) 0%, transparent 100%);
  display: flex;
  align-items: center;
  gap: 8px;
  z-index: 3;
  transition: opacity 0.3s ease;
}
.vic-header .gad {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.48rem;
  font-weight: 700;
  color: rgba(255,255,255,0.9);
  line-height: 1.3;
  text-transform: uppercase;
  border-right: 1.5px solid rgba(255,255,255,0.4);
  padding-right: 8px;
  letter-spacing: 0.05em;
}
.vic-header .nombre {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.95rem;
  font-weight: 900;
  color: #fff;
  letter-spacing: -0.01em;
}
.vic-card:hover .vic-header { opacity: 0; }

.vic-overlay {
  position: absolute;
  inset: 0;
  z-index: 5;
  background: var(--color-panel);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 30px;
  text-align: center;
  transform: translateY(100%);
  transition: transform 0.48s cubic-bezier(0.23,1,0.32,1);
}
.vic-card:hover .vic-overlay { transform: translateY(0%); }

.vic-overlay h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: 1.9rem;
  font-weight: 900;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.1;
  margin-bottom: 8px;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.32s ease 0.26s, transform 0.32s ease 0.26s;
}
.vic-card:hover .vic-overlay h3 { opacity: 1; transform: translateY(0); }

.vic-overlay .subtitulo {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  margin-bottom: 18px;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.32s ease 0.3s, transform 0.32s ease 0.3s;
}
.vic-card:hover .vic-overlay .subtitulo { opacity: 1; transform: translateY(0); }

.vic-overlay .vic-linea {
  width: 0;
  height: 2px;
  background: rgba(255,255,255,0.35);
  margin: 0 auto 18px;
  border-radius: 1px;
  transition: width 0.38s ease 0.34s;
}
.vic-card:hover .vic-overlay .vic-linea { width: 48px; }

.vic-overlay p {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.82rem;
  font-weight: 500;
  color: rgba(255,255,255,0.9);
  line-height: 1.8;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.32s ease 0.36s, transform 0.32s ease 0.36s;
}
.vic-card:hover .vic-overlay p { opacity: 1; transform: translateY(0); }

.vic-overlay a {
  font-family: 'Montserrat', sans-serif;
  display: inline-block;
  margin-top: 22px;
  padding: 10px 28px;
  border: 2px solid rgba(255,255,255,0.75);
  border-radius: 30px;
  color: #fff;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.32s ease 0.42s, transform 0.32s ease 0.42s,
              background 0.2s, color 0.2s;
}
.vic-card:hover .vic-overlay a { opacity: 1; transform: translateY(0); }
.vic-overlay a:hover { background: #fff; color: var(--color-texto); }

@media (max-width: 700px) {
  .vic-card { width: 280px; height: 400px; }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-379ffce */@keyframes mv-slideLeft {
  from { opacity: 0; transform: translateX(-40px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes mv-slideRight {
  from { opacity: 0; transform: translateX(40px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes mv-fadeUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes mv-imgBreath {
  0%, 100% { transform: scale(1);     box-shadow: 0 4px 20px rgba(0,0,0,0.25); }
  50%       { transform: scale(1.025); box-shadow: 0 8px 32px rgba(214,133,82,0.25); }
}
@keyframes mv-pinFloat {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-6px); }
}
@keyframes mv-pinHalo {
  0%   { r: 16; opacity: 0.9; }
  70%  { r: 26; opacity: 0; }
  100% { r: 26; opacity: 0; }
}
@keyframes mv-zoneShimmer {
  0%, 100% { stroke-opacity: 0.32; }
  50%       { stroke-opacity: 0.75; }
}
@keyframes mv-kenBurns {
  from { transform: scale(1.03) translateX(0); }
  to   { transform: scale(1.08) translateX(-8px); }
}

/* ════ SECCIÓN ════ */
#mapa-wrap {
  position: relative;
  width: 100vw !important;
  max-width: 100vw !important;
  left: 50%;
  margin-left: -50vw !important;
  margin-right: -50vw !important;
  margin-top: -10px !important;
  margin-bottom: 0 !important;
  padding: 70px 40px 80px;
  font-family: 'Montserrat', sans-serif;
  background-image: url('https://artelavictoria.com/wp-content/uploads/2026/02/IMG_6731-scaled.jpg');
  background-size: cover;
  background-position: center center;
  background-attachment: fixed;
  overflow: hidden;
  box-sizing: border-box;
  line-height: normal;
}
#mapa-wrap::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to bottom,
    rgba(10,20,15,0.55) 0%,
    rgba(10,20,15,0.45) 50%,
    rgba(10,20,15,0.65) 100%);
  z-index: 0;
}
#mapa-wrap > * { position: relative; z-index: 1; }

/* ════ TÍTULO ════ */
#mapa-wrap .mv-titulo {
  color: #fff;
  font-size: 3rem;
  font-weight: 900;
  text-align: center;
  margin-bottom: 28px;
  font-family: 'Montserrat', sans-serif;
  letter-spacing: -0.02em;
  line-height: 1.1;
  max-width: 1100px;
  margin-left: auto;
  margin-right: auto;
  text-shadow: 0 2px 20px rgba(0,0,0,0.4);
  animation: mv-fadeUp 0.9s cubic-bezier(0.23,1,0.32,1) both;
}

/* ════ GRID ════ */
#mapa-wrap .mv-grid {
  display: flex;
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
  align-items: stretch;
}

/* ════ PANELES ════ */
#mapa-wrap .mv-panel {
  background: rgba(255,255,255,0.10);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 18px;
  padding: 28px;
  transition: box-shadow 0.35s ease, border-color 0.35s ease;
  box-sizing: border-box;
}
#mapa-wrap .mv-panel:hover {
  box-shadow: 0 12px 48px rgba(0,0,0,0.3);
  border-color: rgba(255,255,255,0.28);
}

/* Panel izquierdo */
#mapa-wrap .mv-panel-info {
  flex: 0 0 400px;
  max-width: 400px;
  animation: mv-slideLeft 0.9s cubic-bezier(0.23,1,0.32,1) 0.15s both;
}
/* Panel derecho */
#mapa-wrap .mv-panel-mapa {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: mv-slideRight 0.9s cubic-bezier(0.23,1,0.32,1) 0.3s both;
}

/* ════ CONTENIDO PANEL IZQUIERDO ════ */
#mapa-wrap .mv-subtitulo {
  color: #fff;
  font-size: 1.35rem;
  font-weight: 800;
  margin: 0 0 16px;
  font-family: 'Montserrat', sans-serif;
}
#mapa-wrap .mv-img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  object-position: center top;
  border-radius: 10px;
  margin-bottom: 14px;
  display: block;
  animation: mv-imgBreath 5s ease-in-out infinite;
  transition: opacity 0.35s ease;
  cursor: zoom-in;
}
#mapa-wrap .mv-img:hover {
  animation: mv-kenBurns 6s ease-in-out infinite alternate;
  box-shadow: 0 10px 36px rgba(214,133,82,0.35);
}
#mapa-wrap .mv-nombre {
  color: #D68552;
  font-size: 1.2rem;
  font-weight: 800;
  margin: 0 0 10px;
  font-family: 'Montserrat', sans-serif;
}
#mapa-wrap .mv-desc {
  color: rgba(255,255,255,0.85);
  font-size: 0.88rem;
  line-height: 1.75;
  margin: 0 0 16px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 500;
}

/* ════ MAPA SVG ════ */
#mapa-wrap .mv-svg {
  width: 100%;
  max-width: 500px;
  height: auto;
}

/* ── Zonas ── */
#mapa-wrap .mapa-grupo { cursor: pointer; }
#mapa-wrap .mapa-zona {
  transition: fill 0.35s ease, stroke 0.35s ease, stroke-width 0.35s ease;
  animation: mv-zoneShimmer 3.5s ease-in-out infinite;
}
#mapa-wrap .mapa-grupo:nth-of-type(1) .mapa-zona { animation-delay: 0s; }
#mapa-wrap .mapa-grupo:nth-of-type(2) .mapa-zona { animation-delay: 1.2s; }
#mapa-wrap .mapa-grupo:nth-of-type(3) .mapa-zona { animation-delay: 2.4s; }
#mapa-wrap .mapa-grupo:hover .mapa-zona,
#mapa-wrap .mapa-grupo.activo .mapa-zona {
  fill: rgba(214,133,82,0.22) !important;
  stroke: rgba(214,133,82,0.95) !important;
  stroke-width: 2.8 !important;
  animation: none;
}

/* ── Pins ── */
#mapa-wrap .mapa-pin-ext {
  transition: r 0.2s ease;
  animation: mv-pinFloat 3s ease-in-out infinite;
}
#mapa-wrap .mapa-grupo:nth-of-type(1) .mapa-pin-ext { animation-delay: 0s; }
#mapa-wrap .mapa-grupo:nth-of-type(2) .mapa-pin-ext { animation-delay: 1s; }
#mapa-wrap .mapa-grupo:nth-of-type(3) .mapa-pin-ext { animation-delay: 2s; }
#mapa-wrap .mapa-grupo:hover .mapa-pin-ext,
#mapa-wrap .mapa-grupo.activo .mapa-pin-ext {
  r: 20;
  animation: none;
  filter: drop-shadow(0 0 14px rgba(214,133,82,0.85));
}
#mapa-wrap .mapa-pin-med { transition: fill 0.2s ease; }
#mapa-wrap .mapa-grupo:hover .mapa-pin-med,
#mapa-wrap .mapa-grupo.activo .mapa-pin-med { fill: #E8720C !important; }
#mapa-wrap .mapa-pin-halo {
  fill: none;
  stroke: rgba(214,133,82,0.6);
  stroke-width: 2;
  animation: mv-pinHalo 2s ease-out infinite;
  pointer-events: none;
}
#mapa-wrap .mapa-grupo:nth-of-type(1) .mapa-pin-halo { animation-delay: 0s; }
#mapa-wrap .mapa-grupo:nth-of-type(2) .mapa-pin-halo { animation-delay: 0.7s; }
#mapa-wrap .mapa-grupo:nth-of-type(3) .mapa-pin-halo { animation-delay: 1.4s; }

/* ════ RESPONSIVE ════ */
@media (max-width: 900px) {
  #mapa-wrap .mv-panel-info { flex: 0 0 320px; max-width: 320px; }
}
@media (max-width: 768px) {
  #mapa-wrap { padding: 50px 20px 60px; background-attachment: scroll; }
  #mapa-wrap .mv-grid { flex-direction: column; }
  #mapa-wrap .mv-panel-info { flex: unset; max-width: 100%; }
  #mapa-wrap .mv-titulo { font-size: 2rem; }
  #mapa-wrap .mv-img { height: 220px; }
}

/* Para Astra, Hello, Blocksy, GeneratePress */
.ast-container,
.content-area,
#primary,
#content,
.hfeed,
.site-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-775052a */.vic-cards-op1 {
  display: flex; flex-wrap: wrap; gap: 24px; justify-content: center;
  max-width: 1080px; margin: 0 auto; padding: 48px 24px 32px;
  font-family: 'Montserrat', sans-serif;
}
.op1-card {
  flex: 1; min-width: 260px; max-width: 320px;
  background: #fff; border-radius: 14px;
  padding: 0 28px 32px;
  box-shadow: 0 4px 18px rgba(0,0,0,0.07);
  text-align: center;
  transition: transform 0.35s cubic-bezier(0.23,1,0.32,1), box-shadow 0.35s ease;
  position: relative; overflow: hidden;
}
.op1-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.12);
}
/* Línea superior — igual que h2::after de vic-h3 */
.op1-card::before {
  content: '';
  display: block; height: 4px; border-radius: 0 0 3px 3px;
  background: 
#03586A;
  width: 60px; margin: 0 auto 32px;
  transition: width 0.35s ease;
}
.op1-card:hover::before { width: 100%; border-radius: 0; }
.op1-icono {
  width: 64px; height: 64px;
  background: rgba(3,88,106,0.08); border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px;
  transition: background 0.3s;
}
.op1-card:hover .op1-icono { background: rgba(3,88,106,0.15); }
.op1-icono svg { width: 30px; height: 30px; fill: 
#03586A; }
.op1-card h3 {
  font-family: 'Montserrat', sans-serif; font-size: 1rem; font-weight: 900;
  color: #111; letter-spacing: -0.02em; line-height: 1.2; margin-bottom: 12px;
}
.op1-card p {
  font-family: 'Montserrat', sans-serif; font-size: 0.88rem; font-weight: 500;
  color: #555; line-height: 1.85; margin: 0;
}
/* ── Responsive ── */
@media (max-width: 768px) {
  .op1-card { min-width: 220px; }
}
@media (max-width: 560px) {
  .vic-cards-op1 { flex-direction: column; align-items: center; }
  .op1-card { width: 100%; max-width: 100%; }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-9592a4c */.vic-cta {
  max-width: 1080px; margin: 0 auto;
  padding: 80px 24px; text-align: center;
  font-family: 'Montserrat', sans-serif;
  position: relative;
}
.vic-cta h2 {
  font-family: 'Montserrat', sans-serif !important;
  font-size: clamp(2.6rem, 3vw, 2.6rem);
  font-weight: 900 !important;
  color: #111; line-height: 1.1;
  letter-spacing: -0.03em;
  display: inline-block; position: relative;
  padding-bottom: 18px; margin-bottom: 20px;
  /* Animación de entrada */
  opacity: 0; transform: translateY(24px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.vic-cta.visible h2 { opacity: 1; transform: translateY(0); }
/* Línea teal centrada — igual a vic-h3 */
.vic-cta h2::after {
  content: ''; position: absolute;
  bottom: 0; left: 50%; transform: translateX(-50%);
  width: 60px; height: 4px;
  border-radius: 2px; background: 
#03586A;
  transition: width 0.4s ease;
}
.vic-cta:hover h2::after { width: 100px; }
.vic-cta p {
  font-size: 0.95rem; font-weight: 500;
  color: #555; line-height: 1.85;
  max-width: 880px; margin: 0 auto 40px;
  opacity: 0; transform: translateY(20px);
  transition: opacity 0.7s ease 0.15s, transform 0.7s ease 0.15s;
}
.vic-cta.visible p { opacity: 1; transform: translateY(0); }
/* ── Botón teal sólido con efecto shine ── */
.btn-op2-solid {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 15px 38px; border-radius: 50px;
  background: 
#03586A; color: #fff !important;
  font-family: 'Montserrat', sans-serif;
  font-size: 0.75rem; font-weight: 800;
  letter-spacing: 0.12em; text-transform: uppercase;
  text-decoration: none !important;
  box-shadow: 0 6px 24px rgba(3,88,106,0.35);
  transition: background 0.25s, transform 0.3s cubic-bezier(0.23,1,0.32,1), box-shadow 0.25s;
  position: relative; overflow: hidden;
  opacity: 0; transform: translateY(16px);
  /* Transición de entrada */
  animation: none;
}
.vic-cta.visible .btn-op2-solid {
  opacity: 1; transform: translateY(0);
  transition: opacity 0.7s ease 0.28s, transform 0.7s ease 0.28s,
              background 0.25s, box-shadow 0.25s;
}
/* Efecto shine al hover */
.btn-op2-solid::before {
  content: '';
  position: absolute; top: -60%; left: -80%;
  width: 55%; height: 220%;
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,0.3) 50%, transparent 70%);
  transform: skewX(-15deg); opacity: 0;
}
.btn-op2-solid:hover::before {
  animation: btn-shine 0.6s ease forwards;
}
.btn-op2-solid:hover {
  background: 
#024a5a !important;
  transform: translateY(-4px) !important;
  box-shadow: 0 14px 36px rgba(3,88,106,0.45);
}
.btn-op2-solid:active { transform: translateY(-1px) !important; }
.btn-op2-solid svg {
  width: 16px; height: 16px; fill: none; stroke: #fff;
  stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round;
  transition: transform 0.25s cubic-bezier(0.23,1,0.32,1);
  flex-shrink: 0;
}
.btn-op2-solid:hover svg { transform: translateX(5px); }
/* ── Keyframes ── */
@keyframes btn-shine {
  0%  { opacity: 0; transform: skewX(-15deg) translateX(0); }
  15% { opacity: 1; }
  100%{ opacity: 0; transform: skewX(-15deg) translateX(450%); }
}
/* ── Responsive ── */
@media (max-width: 600px) {
  .vic-cta h2 { font-size: 1.8rem; }
  .vic-cta p  { font-size: 0.85rem; }
  .btn-op2-solid { width: 100%; max-width: 320px; justify-content: center; }
}/* End custom CSS */