.elementor-4449 .elementor-element.elementor-element-8ca8a56{--display:flex;}:root{--page-title-display:none;}@media(min-width:768px){.elementor-4449 .elementor-element.elementor-element-8ca8a56{--width:100vw;}}/* Start custom CSS for html, class: .elementor-element-1defa80 *//* ══════════════════════════════════════════════
   PASAPORTE TECH SHOW ECUADOR 2026 — v4
   → Apariencia → Personalizar → CSS Adicional
══════════════════════════════════════════════ */

.psp-section {
  position: relative;
  background: #04050f;
  padding: 70px 32px 80px;
  overflow: hidden;
  font-family: 'Barlow', sans-serif;
  min-height: 100vh;
}

/* Imagen de fondo con Ken Burns */
.psp-bg {
  position: absolute;
  inset: -6%;
  z-index: 0;
  background-image: url('https://techshowecuador.com/wp-content/uploads/2026/02/BANNER-ULTIMO-FERIA.jpg.jpeg');
  background-size: cover;
  background-position: center center;
  animation: pspKenBurnsB 24s ease-in-out infinite alternate;
  will-change: transform;
  pointer-events: none;
}
@keyframes pspKenBurnsB {
  0%   { transform: scale(1.0)  translate(0%,    0%   ); }
  50%  { transform: scale(1.07) translate(-1%,  -0.5% ); }
  100% { transform: scale(1.0)  translate( 1%,   0.5% ); }
}

/* Overlay oscuro + dot grid */
.psp-grid-bg {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(to bottom, rgba(3,4,16,0.88), rgba(3,4,16,0.82)),
    linear-gradient(135deg, rgba(155,93,229,0.06) 0%, transparent 60%);
  pointer-events: none;
}
.psp-grid-bg::after {
  content: ''; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(58,181,255,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(58,181,255,.022) 1px, transparent 1px);
  background-size: 56px 56px;
}
.psp-inner {
  position: relative; z-index: 2;
  max-width: 1200px;
  margin: 0 auto;
}

/* ── Encabezado ── */
.psp-header { text-align: center; margin-bottom: 52px; }
.psp-eyebrow {
  display: flex; align-items: center; justify-content: center; gap: 14px;
  font-family: 'Barlow Condensed', sans-serif;
  font-size: .6rem; font-weight: 700; letter-spacing: .26em; text-transform: uppercase;
  color: rgba(58,181,255,.5); margin-bottom: 10px;
}
.psp-line {
  display: inline-block; width: 28px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(58,181,255,.45));
}
.psp-eyebrow .psp-line:last-child {
  background: linear-gradient(270deg, transparent, rgba(58,181,255,.45));
}
.psp-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(2rem, 4.5vw, 3.4rem);
  font-weight: 900; text-transform: uppercase;
  color: #fff; line-height: 1.04; margin-bottom: 10px;
}
.psp-title em {
  font-style: normal;
  background: linear-gradient(90deg, #3ab5ff, #9b5de5);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.psp-subtitle {
  font-size: .85rem; font-weight: 300;
  color: rgba(160,185,230,.5);
  max-width: 460px; margin: 0 auto;
}

/* ══════════════════════════════
   LAYOUT
══════════════════════════════ */
.psp-layout {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 60px;
  align-items: center;
}

/* ══════════════════════════════
   COLUMNA IMAGEN
══════════════════════════════ */
.psp-col-img {
  position: sticky;
  top: 100px;
}

/* Marco contenedor — define el tamaño; la imagen se adapta */
.psp-img-frame {
  position: relative;
  width: 100%;
  border-radius: 12px;
  overflow: hidden;
  box-shadow:
    0 0 0 1px rgba(58,181,255,.1),
    0 24px 64px rgba(0,0,0,.6),
    0 0 80px rgba(155,93,229,.08);
}

/* La imagen ocupa el 100% del frame y tiene el zoom Ken Burns */
.psp-passport-img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  transform-origin: center center;
  animation: pspKenBurns 12s ease-in-out infinite alternate;
  will-change: transform;
  transition: none;
}

@keyframes pspKenBurns {
  0%   { transform: scale(1.00) translate(0%,    0%   ); }
  33%  { transform: scale(1.04) translate(-1%,  -0.5% ); }
  66%  { transform: scale(1.06) translate( 0.8%, 0.8% ); }
  100% { transform: scale(1.03) translate(-0.5%, 0.3% ); }
}

/* Overlay sutil — bordes quemados */
.psp-img-overlay {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at center, transparent 55%, rgba(4,5,15,.55) 100%);
  pointer-events: none;
}

/* Badge esquina inferior izquierda */
.psp-img-badge {
  position: absolute; bottom: 16px; left: 16px;
  display: flex; align-items: center; gap: 7px;
  padding: 6px 14px;
  background: rgba(4,5,15,.75);
  border: 1px solid rgba(240,192,96,.25);
  border-radius: 3px;
  backdrop-filter: blur(8px);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: .58rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: rgba(240,192,96,.7);
  pointer-events: none;
}

/* ══════════════════════════════
   COLUMNA PASOS
══════════════════════════════ */
.psp-col-steps {
  display: flex; flex-direction: column; gap: 0;
}

.psp-steps-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: .58rem; font-weight: 700; letter-spacing: .26em; text-transform: uppercase;
  color: rgba(58,181,255,.5); margin-bottom: 18px;
  display: flex; align-items: center; gap: 10px;
}
.psp-steps-title::before {
  content: ''; display: inline-block; width: 18px; height: 1px;
  background: rgba(58,181,255,.4);
}

/* Paso */
.psp-step { display: flex; align-items: stretch; }
.psp-step-left {
  display: flex; flex-direction: column; align-items: center;
  width: 38px; flex-shrink: 0;
}
.psp-step-num {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: .5rem; font-weight: 700; letter-spacing: .18em;
  color: #3ab5ff; line-height: 1; padding-top: 16px; padding-bottom: 3px;
}
.psp-step-num--gold { color: #f0c060; }
.psp-step-track {
  flex: 1; width: 1px;
  background: linear-gradient(to bottom, rgba(58,181,255,.25), rgba(58,181,255,.03));
  margin: 2px auto 0;
}

.psp-step-card {
  flex: 1; display: flex; gap: 14px; align-items: center;
  padding: 16px 18px 16px 14px;
  margin-bottom: 10px;
  background: rgba(8,10,28,.88);
  border: 1px solid rgba(58,181,255,.1);
  border-left: 2px solid rgba(58,181,255,.3);
  border-radius: 0 6px 6px 0;
  transition: border-color .25s, background .25s;
}
.psp-step-card:hover {
  background: rgba(12,16,44,.95);
  border-color: rgba(58,181,255,.22);
  border-left-color: #3ab5ff;
}
.psp-step-card--gold {
  border-color: rgba(240,192,96,.13);
  border-left-color: rgba(240,192,96,.48);
}
.psp-step-card--gold:hover {
  border-color: rgba(240,192,96,.26);
  border-left-color: #f0c060;
}

.psp-step-icon {
  width: 42px; height: 42px; flex-shrink: 0;
  border: 1px solid rgba(58,181,255,.22); border-radius: 50%;
  background: rgba(58,181,255,.07);
  display: flex; align-items: center; justify-content: center;
  transition: .25s;
}
.psp-step-icon svg { width: 18px; height: 18px; stroke: #3ab5ff; }
.psp-step-card:hover .psp-step-icon {
  background: rgba(58,181,255,.14); border-color: rgba(58,181,255,.45);
}
.psp-step-icon--gold { border-color: rgba(240,192,96,.3); background: rgba(240,192,96,.08); }
.psp-step-icon--gold svg { stroke: #f0c060; }
.psp-step-card--gold:hover .psp-step-icon--gold {
  background: rgba(240,192,96,.15); border-color: rgba(240,192,96,.52);
}

.psp-step-body h3 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: .95rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: .05em; color: #fff; line-height: 1.1; margin-bottom: 4px;
}
.psp-step-body p {
  font-size: .78rem; font-weight: 300;
  color: rgba(185,205,255,.7); line-height: 1.5; margin: 0;
}
.psp-step-body p strong { color: rgba(220,235,255,.92); font-weight: 600; }

.psp-legal {
  display: flex; align-items: center; gap: 7px;
  font-size: .58rem; color: rgba(120,145,195,.42);
  letter-spacing: .04em; padding: 10px 0 0 38px;
}
.psp-legal svg { stroke: rgba(120,145,195,.4); flex-shrink: 0; }

/* ── Reveal ── */
.psp-reveal { opacity: 0; transform: translateY(18px); transition: opacity .7s ease, transform .7s ease; }
.psp-reveal.psp-visible { opacity: 1; transform: none; }

/* ── Responsive ── */
@media (max-width: 860px) {
  .psp-layout {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .psp-col-img {
    position: static;
    max-width: 420px;
    margin: 0 auto;
    width: 100%;
  }
}
@media (max-width: 520px) {
  .psp-section { padding: 50px 18px 60px; }
  .psp-col-img { max-width: 320px; }
}/* End custom CSS */
/* Start custom CSS */.elementor-element-8ca8a56 {
  background: transparent !important;
  background-color: transparent !important;
  padding: 0 !important;
}

.elementor-element-8ca8a56 > .elementor-widget-container {
  background: transparent !important;
  padding: 0 !important;
}/* End custom CSS */