/* ── Improex — ajustes locales ── */

/* CANALES sección 1: imagen de fondo con luz roja derecha generada en CSS */
.elementor-235 > .elementor-element.elementor-element-3fa143e {
    background-color: #0a0a0a !important;
    background-image:
        radial-gradient(ellipse at 95% 50%, rgba(228, 27, 45, 0.55) 0%, transparent 55%),
        linear-gradient(rgba(0, 0, 0, 0.65), rgba(0, 0, 0, 0.65)),
        url('https://improex.com.ec/wp-content/uploads/2026/07/hero_fondo_industrial_web.jpg') !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

/* CANALES sección 1: bajar texto 25px */
.elementor-235 .elementor-element-026a128 {
    margin-top: calc(25px + 3%) !important;
}

/* CANALES INDUSTRIAL: separar badge CANALES del título */
.elementor-235 .elementor-element-d7337b4 {
    margin-top: 15px !important;
    margin-bottom: 15px !important;
}

/* CANALES INDUSTRIAL: separar título INDUSTRIAL de la imagen */
.elementor-235 .elementor-element-95bed8c {
    margin-top: 15px !important;
}

/* CANALES INDUSTRIAL: separar texto del shape rojo */
.elementor-235 .elementor-element-770d37e {
    margin-top: 15px !important;
}

/* CANALES INDUSTRIAL: imagen nueva con mask redondeado 30px y mismo tamaño */
.elementor-235 .elementor-element-e9c9777 {
    border-radius: 30px !important;
    overflow: hidden !important;
    line-height: 0;
}
.elementor-235 .elementor-element-e9c9777 img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 30px !important;
}

/* CANALES HORECA: imagen nueva con bordes redondeados 30px, alineada a la derecha */
.elementor-235 .elementor-element-4fb5564 {
    justify-content: flex-end !important;
}
.elementor-235 .elementor-element-c38f3d4 {
    border-radius: 30px !important;
    overflow: hidden !important;
    line-height: 0;
    margin-left: auto !important;
    transform: translateX(10%) !important;
}
.elementor-235 .elementor-element-c38f3d4 img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    object-position: right center;
    border-radius: 30px !important;
}

/* CANALES HORECA: badge CANALES — margen, centrado, padding simétrico */
.elementor-235 .elementor-element-a076b1b {
    margin-top: 15px !important;
    margin-bottom: 15px !important;
    text-align: center !important;
    padding-bottom: 8px !important;
}
.elementor-235 .elementor-element-a076b1b p {
    text-align: center !important;
    margin: 0 !important;
}

/* CANALES HORECA: separar título HORECA de la imagen */
.elementor-235 .elementor-element-cdcc254 {
    margin-top: 15px !important;
}

/* CANALES HORECA: separar contenido post-divider */
.elementor-235 .elementor-element-008d591 {
    margin-top: 15px !important;
}

/* CANALES HORECA: HO/RE/CA — centrar texto en su fondo (padding simétrico) */
.elementor-235 .elementor-element-3547ca2,
.elementor-235 .elementor-element-587ee85,
.elementor-235 .elementor-element-626a151 {
    padding: 9px 19px 5px !important;
    text-align: center !important;
}
.elementor-235 .elementor-element-3547ca2 p,
.elementor-235 .elementor-element-587ee85 p,
.elementor-235 .elementor-element-626a151 p {
    text-align: center !important;
    margin: 0 !important;
}

/* CANALES INDUSTRIAL: ml badges — sin stroke, centrado, padding vertical */
.elementor-235 .elementor-element-c8d4cb1,
.elementor-235 .elementor-element-e13aef7,
.elementor-235 .elementor-element-5aff8f6,
.elementor-235 .elementor-element-1a8d8c4,
.elementor-235 .elementor-element-c4b177b {
    border: none !important;
    text-align: center !important;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
}
.elementor-235 .elementor-element-c8d4cb1 p,
.elementor-235 .elementor-element-e13aef7 p,
.elementor-235 .elementor-element-5aff8f6 p,
.elementor-235 .elementor-element-1a8d8c4 p,
.elementor-235 .elementor-element-c4b177b p {
    text-align: center !important;
    margin: 0 !important;
}

/* CANALES pg: marca.svg tamaño original */
.elementor-235 .elementor-element-b2f9a01 img {
    width: 10px !important;
    height: 75px !important;
}

/* CANALES pg: overflow visible para img-16-2 absoluta y para sticky */
.elementor-235 {
    overflow: visible !important;
}
.elementor-235 .elementor-element-b961171,
.elementor-235 .elementor-element-9345b68,
.elementor-235 .elementor-element-20b9bad {
    overflow: visible !important;
}
.elementor-235 .elementor-element-3fa143e > .e-con-inner,
.elementor-235 .elementor-element-c91c682 > .e-con-inner,
.elementor-235 .elementor-element-b961171 > .e-con-inner,
.elementor-235 .elementor-element-9345b68 > .e-con-inner,
.elementor-235 .elementor-element-20b9bad > .e-con-inner {
    overflow: visible !important;
}
/* FLORÍCOLAS: permitir que 1b23b19 (abs) salga de su contenedor padre */
.elementor-235 .elementor-element-81ec08c {
    overflow: visible !important;
}

/* ══════════════════════════════════════════════════
   CANALES: SCROLL STACKING — igual que home
   ══════════════════════════════════════════════════ */

.elementor-235 > .elementor-element.elementor-element-3fa143e {
    position: sticky !important;
    top: var(--sticky-top-c1, 0px) !important;
    z-index: 10 !important;
}
.elementor-235 > .elementor-element.elementor-element-c91c682 {
    position: sticky !important;
    top: var(--sticky-top-c2, 0px) !important;
    z-index: 20 !important;
    min-height: 100vh !important;
    background-color: #ffffff !important;
}
.elementor-235 > .elementor-element.elementor-element-b961171 {
    position: sticky !important;
    top: var(--sticky-top-industrial, 0px) !important;
    z-index: 30 !important;
}
.elementor-235 > .elementor-element.elementor-element-9345b68 {
    position: sticky !important;
    top: var(--sticky-top-horeca, 0px) !important;
    z-index: 40 !important;
    min-height: 100vh !important;
}
.elementor-235 > .elementor-element.elementor-element-20b9bad {
    position: sticky !important;
    top: var(--sticky-top-c5, 0px) !important;
    z-index: 50 !important;
    min-height: 100vh !important;
}

/* Secciones 2-5: sombra superior al apilar */
.elementor-235 > .elementor-element.elementor-element-c91c682,
.elementor-235 > .elementor-element.elementor-element-b961171,
.elementor-235 > .elementor-element.elementor-element-9345b68,
.elementor-235 > .elementor-element.elementor-element-20b9bad {
    box-shadow: 0 -16px 48px rgba(0, 0, 0, 0.70), 0 -4px 12px rgba(0, 0, 0, 0.45);
}
/* FLORÍCOLAS: img-15-2 sube 20px sin mover los elementos siguientes */
.elementor-235 .elementor-element-03ffd68 {
    position: relative !important;
    top: -20px !important;
}

/* FLORÍCOLAS: img-16-2 baja 3px dentro del contenedor */
.elementor-235 .elementor-element-931e618 {
    margin-top: 10px !important;
}

/* FLORÍCOLAS: img-16-2 + badge CANALES — posición calculada por JS */
.elementor-235 .elementor-element-1b23b19 {
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    transform: none !important;
    width: auto !important;
    z-index: 2 !important;
}

/* INDUSTRIAL y HORECA: imagen decorativa — posición calculada por JS */
.elementor-235 .elementor-element-6f2061a,
.elementor-235 .elementor-element-4476691 {
    position: absolute !important;
    width: auto !important;
    z-index: 2 !important;
}


/* Logo: 387px - 10% = 348px */
.elementor-15 .elementor-element.elementor-element-2b28d52 img {
    width: 348px !important;
    height: auto !important;
}

/* Cabecera: efecto blur/frosted glass en el fondo */
.elementor-15 .elementor-element.elementor-element-9731164 {
    -webkit-backdrop-filter: blur(12px) !important;
    backdrop-filter: blur(12px) !important;
}

/* Contenedor interno: quitar max-width centrado, márgenes simétricos y altura del menú */
.elementor-15 .elementor-element.elementor-element-9731164.e-con-boxed > .e-con-inner {
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 10% !important;
    padding-right: 10% !important;
    padding-top: 1% !important;
    padding-bottom: 1% !important;
}

/* Quitar el justify-content:center del sub-contenedor del logo */
.elementor-15 .elementor-element.elementor-element-f310f09 {
    --justify-content: flex-start !important;
    justify-content: flex-start !important;
}

/* ES | US: texto 30% más pequeño */
.elementor-15 .elementor-element.elementor-element-4d2d9ce {
    font-size: 0.7em !important;
}

/* ES | US: centrar vertical y horizontalmente */
.elementor-15 .elementor-element.elementor-element-7b6a952 {
    --flex-direction: row !important;
    flex-direction: row !important;
    --justify-content: center !important;
    justify-content: center !important;
    --align-items: center !important;
    align-items: center !important;
}

/* Contenedor del menú nav: centrar verticalmente también */
.elementor-15 .elementor-element.elementor-element-0d03006 {
    --align-items: center !important;
    align-items: center !important;
}

/* ── Hero home: quitar márgenes de browser en headings ── */
.elementor-6 .elementor-element.elementor-element-c4a1e92 h1,
.elementor-6 .elementor-element.elementor-element-d5b2f03 h1,
.elementor-6 .elementor-element.elementor-element-f3a9d1e h2 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}

/* ── Hero home: centrado vertical y contenido a la izquierda ── */
.elementor-6 > .elementor-element.elementor-element-d13c8c7 {
    justify-content: center !important;
}
.elementor-6 .elementor-element.elementor-element-a0d1883 {
    --align-items: flex-start !important;
    align-items: flex-start !important;
    --flex-direction: row !important;
    flex-direction: row !important;
    gap: 0 !important;
    padding-top: 0 !important;
    padding-left: 0 !important;
    margin-left: -10% !important;
    margin-top: 25vh !important;
}
.elementor-6 .elementor-element.elementor-element-b2e7f31 {
    max-width: 42% !important;
    width: 42% !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Hero home: imagen reciclable — sin padding interno, pegada al texto */
.elementor-6 .elementor-element.elementor-element-d644583 {
    transform: translateY(calc(-10% + 10px)) !important;
    text-align: center !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 0;
    width: fit-content !important;
    max-width: fit-content !important;
    flex: 0 0 auto !important;
}
.elementor-6 .elementor-element.elementor-element-d644583 img {
    width: 160px !important;
    height: auto !important;
    display: block;
}

/* ── CANALES v2: cards prototipo con scale+bounce y overlay gradiente ── */

/* Row inline dentro del HTML widget de Elementor */
.icv2-row {
    display: flex;
    gap: 24px;
    justify-content: center;
    align-items: flex-start;
    flex-wrap: nowrap;
    width: 100%;
    padding: 20px 0;
    box-sizing: border-box;
}

.icv2-card {
    width: 380px;
    height: 448px;
    background: #333333;
    border-radius: 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    cursor: pointer;
    overflow: hidden;
    flex-shrink: 0;
    transform: scale(1);
    transition: transform 0.55s cubic-bezier(0.34, 1.56, 0.64, 1);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

.icv2-card:hover {
    transform: scale(1.05);
}

/* Overlay solo en el fondo gris: z-index bajo, debajo de fotos y texto */
.icv2-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, #e41b2d, #881c25);
    opacity: 0;
    transition: opacity 0.4s ease;
    pointer-events: none;
    z-index: 1;
}

.icv2-card:hover .icv2-overlay {
    opacity: 1;
}

/* Imagen principal: z-index encima del overlay */
.icv2-img-wrap {
    width: calc(100% - 20px);
    height: 210px;
    margin: 10px 10px 0;
    border-radius: 30px;
    overflow: hidden;
    flex-shrink: 0;
    position: relative;
    z-index: 2;
}

.icv2-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Badge: z-index encima del overlay */
.icv2-badge {
    width: 122px;
    height: 122px;
    background: #5e5e5e;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: -61px;
    flex-shrink: 0;
    position: relative;
    z-index: 2;
}

.icv2-badge-inner {
    width: 110px;
    height: 110px;
    background: #ffffff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4px;
    overflow: hidden;
}

.icv2-badge-inner img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.icv2-label {
    font-family: "Archivo", sans-serif;
    font-size: 28px;
    font-weight: 800;
    color: #ffffff;
    text-align: center;
    margin-top: auto;
    padding-bottom: 87px;
    position: relative;
    z-index: 2;
    pointer-events: none;
}

/* ── EXPERIENCIA Y CALIDAD: cards recreadas en CSS ── */
.elementor-6 .elementor-element.elementor-element-c70387e {
    overflow: visible !important;
}

.eqc-row {
    display: flex;
    gap: 20px;
    justify-content: center;
    align-items: stretch;
    flex-wrap: nowrap;
    width: 100%;
    padding: 10px 0 20px;
    box-sizing: border-box;
}

.eqc-card {
    width: 360px;
    height: 600px;
    flex-shrink: 0;
    border-radius: 0;
    overflow: hidden;
    cursor: pointer;
    transform: scale(1);
    transition: transform 0.55s cubic-bezier(0.34, 1.56, 0.64, 1);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    display: flex;
    flex-direction: column;
}

.eqc-card:hover {
    transform: scale(1.05);
}

.eqc-img-wrap {
    width: 100%;
    height: 370px;
    overflow: hidden;
    flex-shrink: 0;
}

.eqc-img-wrap img {
    width: 100% !important;
    height: 100% !important;
    min-width: 100% !important;
    min-height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
    transform: scale(1.05);
    transition: transform 0.55s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.eqc-card:hover .eqc-img-wrap img {
    transform: scale(1.12);
}

.eqc-bottom {
    flex: 1;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 14px;
    padding: 28px 20px 32px;
    overflow: hidden;
}

.eqc-bottom::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, #e41b2d, #881c25);
    transition: opacity 0.4s ease;
    opacity: 1;
}

.eqc-bottom::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, #4c4c4c, #1d1d1b);
    transition: opacity 0.4s ease;
    opacity: 0;
}

.eqc-card:hover .eqc-bottom::before { opacity: 0; }
.eqc-card:hover .eqc-bottom::after  { opacity: 1; }

.eqc-icon {
    position: relative;
    z-index: 1;
    width: 64px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.eqc-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.eqc-label {
    position: relative;
    z-index: 1;
    font-family: "Archivo", sans-serif;
    font-size: 15px;
    font-weight: 800;
    color: #ffffff;
    text-align: center;
    margin: 0;
    line-height: 1.35;
    text-transform: uppercase;
}

/* ── HERO HOME: video de fondo ── */
.elementor-6 > .elementor-element.elementor-element-d13c8c7 {
    overflow: hidden !important;
    background-color: #000 !important;
}

/* Quitar imagen Elementor en ambas versiones — el ::before la reemplaza con blur */
.elementor-6 .elementor-element.elementor-element-d13c8c7:not(.elementor-motion-effects-element-type-background),
.elementor-6 .elementor-element.elementor-element-d13c8c7 > .elementor-motion-effects-container > .elementor-motion-effects-layer {
    background-image: none !important;
}

/* Imagen blureada: placeholder visible mientras el video carga (desktop y móvil) */
.elementor-6 > .elementor-element.elementor-element-d13c8c7::before {
    content: '';
    position: absolute;
    inset: 0;
    transform: scale(1.1);
    background-image: url('https://improex.com.ec/wp-content/uploads/2026/05/img-21.png');
    background-size: cover;
    background-position: center;
    filter: blur(22px);
    z-index: 0;
}

#hero-video-bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}

#hero-video-wrap {
    position: absolute;
    top: 50%; left: 50%;
    width: 177.78vh;
    height: 56.25vw;
    min-width: 100%;
    min-height: 100%;
    transform: translate(-50%, -50%);
    opacity: 0;
}

#hero-video-wrap iframe {
    position: absolute;
    inset: 0;
    width: 100%; height: 100%;
    border: none;
}

#hero-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.65);
}

#hero-red-light {
    position: absolute;
    top: 0; left: 0;
    width: 55%; height: 70%;
    background: radial-gradient(ellipse at 0% 0%, rgba(228, 27, 45, 0.52) 0%, transparent 65%);
}

.elementor-6 .elementor-element-a0d1883,
.elementor-6 .elementor-element-b2e7f31 {
    position: relative !important;
    z-index: 1 !important;
}

/* ══════════════════════════════════════════════════
   SCROLL STACKING — cada sección se apila sobre la anterior
   ══════════════════════════════════════════════════ */


/* Última sección: reducir padding-bottom 100px → 50px */
.elementor-6 .elementor-element.elementor-element-0b5fbaa {
    padding-bottom: 50px !important;
}

/* Permitir sticky en los ancestros del canvas de Elementor */
html, body,
.site, .site-content, #content, #primary,
.entry-content,
.elementor-6,
.elementor-6 > .elementor-inner,
.elementor-6 > .e-con-inner {
    overflow: visible !important;
}

/* Cada sección: sticky + z-index creciente + top dinámico por JS */
.elementor-6 > .elementor-element.elementor-element-d13c8c7 {
    position: sticky !important;
    top: var(--sticky-top-h1, 0px) !important;
    z-index: 10 !important;
    min-height: 100vh !important;
}

.elementor-6 > .elementor-element.elementor-element-924aaf1 {
    position: sticky !important;
    top: var(--sticky-top-h2, 0px) !important;
    z-index: 20 !important;
    min-height: 100vh !important;
}

.elementor-6 > .elementor-element.elementor-element-2f4f845 {
    position: sticky !important;
    top: var(--sticky-top-h3, 0px) !important;
    z-index: 30 !important;
    min-height: 100vh !important;
}

.elementor-6 > .elementor-element.elementor-element-8f04f0f {
    position: sticky !important;
    top: var(--sticky-top-h4, 0px) !important;
    z-index: 40 !important;
    min-height: 100vh !important;
}

.elementor-6 > .elementor-element.elementor-element-9908929 {
    position: sticky !important;
    top: var(--sticky-top-h5, 0px) !important;
    z-index: 50 !important;
    min-height: 100vh !important;
}

.elementor-6 > .elementor-element.elementor-element-0b5fbaa {
    position: sticky !important;
    top: var(--sticky-top-h6, 0px) !important;
    z-index: 60 !important;
    min-height: 100vh !important;
}

/* Secciones 2-6: sombra en el borde superior para profundidad al apilar */
.elementor-6 > .elementor-element.elementor-element-924aaf1,
.elementor-6 > .elementor-element.elementor-element-2f4f845,
.elementor-6 > .elementor-element.elementor-element-8f04f0f,
.elementor-6 > .elementor-element.elementor-element-9908929,
.elementor-6 > .elementor-element.elementor-element-0b5fbaa {
    box-shadow: 0 -16px 48px rgba(0, 0, 0, 0.70), 0 -4px 12px rgba(0, 0, 0, 0.45);
}

/* ── CONTACTOS: bounce/scale en las 2 imágenes ── */
.elementor-6 .elementor-element.elementor-element-a90f117,
.elementor-6 .elementor-element.elementor-element-2d4e513 {
    transform: scale(1);
    transition: transform 0.55s cubic-bezier(0.34, 1.56, 0.64, 1);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    cursor: pointer;
}

.elementor-6 .elementor-element.elementor-element-a90f117:hover,
.elementor-6 .elementor-element.elementor-element-2d4e513:hover {
    transform: scale(1.06);
}

/* ── MOSTRAMOS: espacio entre texto introductorio y carrusel ── */
.elementor-6 .elementor-element.elementor-element-f73cb65 {
    margin-bottom: 20px !important;
}

/* ── MOSTRAMOS carrusel: overlay inferior 25% con caption en hover ── */

/* Reset completo 3D: quitar perspectiva, preserve-3d y backface */
.elementor-element-a0f944d .elementor-flip-box,
.elementor-element-dff9455 .elementor-flip-box,
.elementor-element-0e48127 .elementor-flip-box {
    perspective: none !important;
    transform-style: flat !important;
    overflow: hidden !important;
}

.elementor-element-a0f944d .elementor-flip-box__layer,
.elementor-element-dff9455 .elementor-flip-box__layer,
.elementor-element-0e48127 .elementor-flip-box__layer {
    backface-visibility: visible !important;
    -webkit-backface-visibility: visible !important;
    transform-style: flat !important;
}

/* Frente: fijo, sin rotación en ningún estado */
.elementor-element-a0f944d .elementor-flip-box__front,
.elementor-element-dff9455 .elementor-flip-box__front,
.elementor-element-0e48127 .elementor-flip-box__front,
.elementor-element-a0f944d .elementor-flip-box:hover .elementor-flip-box__front,
.elementor-element-dff9455 .elementor-flip-box:hover .elementor-flip-box__front,
.elementor-element-0e48127 .elementor-flip-box:hover .elementor-flip-box__front {
    transform: none !important;
    transition: none !important;
    position: relative !important;
    z-index: 1 !important;
}

/* Reverso: 25% inferior, oculto bajo el borde, desliza al hover */
.elementor-element-a0f944d .elementor-flip-box__back,
.elementor-element-dff9455 .elementor-flip-box__back,
.elementor-element-0e48127 .elementor-flip-box__back {
    position: absolute !important;
    bottom: 0 !important;
    top: auto !important;
    left: 0 !important;
    width: 100% !important;
    height: 25% !important;
    transform: translateY(101%) !important;
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1) !important;
    z-index: 2 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.elementor-element-a0f944d .elementor-flip-box:hover .elementor-flip-box__back,
.elementor-element-dff9455 .elementor-flip-box:hover .elementor-flip-box__back,
.elementor-element-0e48127 .elementor-flip-box:hover .elementor-flip-box__back {
    transform: translateY(0) !important;
}

/* Overlay del reverso: gradiente, sin foto */
.elementor-element-a0f944d .elementor-flip-box__back .elementor-flip-box__layer__overlay,
.elementor-element-dff9455 .elementor-flip-box__back .elementor-flip-box__layer__overlay,
.elementor-element-0e48127 .elementor-flip-box__back .elementor-flip-box__layer__overlay {
    background: linear-gradient(to right, #e41b2d, #881c25) !important;
    background-image: linear-gradient(to right, #e41b2d, #881c25) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    height: 100% !important;
    padding: 0 !important;
}

/* Caption: 25px, 800w, blanco, centrado */
.elementor-element-a0f944d .elementor-flip-box__back .elementor-flip-box__layer__title,
.elementor-element-dff9455 .elementor-flip-box__back .elementor-flip-box__layer__title,
.elementor-element-0e48127 .elementor-flip-box__back .elementor-flip-box__layer__title {
    font-family: "Archivo", sans-serif !important;
    font-size: 25px !important;
    font-weight: 800 !important;
    color: #ffffff !important;
    text-align: center !important;
    margin: 0 !important;
    padding: 0 20px !important;
    line-height: 1.2 !important;
}

/* ── CANALES: flip-box → scale+bounce con overlay gradiente rojo ── */

/* 1. Deshabilitar perspectiva y giro 3D */
.elementor-element-d44de12 .elementor-flip-box,
.elementor-element-651a3eb .elementor-flip-box,
.elementor-element-fa78867 .elementor-flip-box {
    perspective: none !important;
}

/* 2. Frente: sin transform, overflow hidden para el scale */
.elementor-element-d44de12 .elementor-flip-box__front,
.elementor-element-651a3eb .elementor-flip-box__front,
.elementor-element-fa78867 .elementor-flip-box__front {
    transform: none !important;
    position: relative !important;
    overflow: hidden !important;
    background-color: #7a7a7a !important;
}

/* 3. Ocultar el reverso */
.elementor-element-d44de12 .elementor-flip-box__back,
.elementor-element-651a3eb .elementor-flip-box__back,
.elementor-element-fa78867 .elementor-flip-box__back {
    display: none !important;
}

/* 4. Imagen: scale con bounce elástico al hover */
.elementor-element-d44de12 .elementor-flip-box__front .elementor-flip-box__image img,
.elementor-element-651a3eb .elementor-flip-box__front .elementor-flip-box__image img,
.elementor-element-fa78867 .elementor-flip-box__front .elementor-flip-box__image img {
    display: block;
    width: 100%;
    transform: scale(1);
    transition: transform 0.55s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}

.elementor-element-d44de12:hover .elementor-flip-box__front .elementor-flip-box__image img,
.elementor-element-651a3eb:hover .elementor-flip-box__front .elementor-flip-box__image img,
.elementor-element-fa78867:hover .elementor-flip-box__front .elementor-flip-box__image img {
    transform: scale(1.09) !important;
}

/* 5. Overlay gradiente: aparece en hover */
.elementor-element-d44de12 .elementor-flip-box__front::after,
.elementor-element-651a3eb .elementor-flip-box__front::after,
.elementor-element-fa78867 .elementor-flip-box__front::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, #e41b2d, #881c25);
    opacity: 0;
    transition: opacity 0.4s ease;
    z-index: 2;
    pointer-events: none;
}

.elementor-element-d44de12:hover .elementor-flip-box__front::after,
.elementor-element-651a3eb:hover .elementor-flip-box__front::after,
.elementor-element-fa78867:hover .elementor-flip-box__front::after {
    opacity: 0.82;
}

/* ── CERTIFICACIONES: cards Control de Calidad ── */

/* Forzar centrado en el widget Elementor que contiene el HTML */
.elementor-194 .elementor-element-ccqproto1 {
    width: 100% !important;
}
.elementor-194 .elementor-element-ccqproto1 > .elementor-widget-container {
    display: flex !important;
    justify-content: center !important;
}

.ccq-row {
    display: flex;
    gap: 24px;
    justify-content: center;
    align-items: flex-start;
    width: 110%;
    margin: 20px auto;
    padding: 20px 0;
    box-sizing: border-box;
}

.ccq-card {
    flex: 1;
}

.ccq-img-wrap {
    width: 100%;
    position: relative;
    overflow: hidden;
    border-radius: 12px;
    aspect-ratio: 4 / 3;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ccq-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0;
    transform: scale(1.1);
    transform-origin: center center;
    transition: transform 0.55s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.ccq-img-wrap:hover .ccq-bg {
    transform: scale(1.22);
}

.ccq-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, #e41b2d, #881c25);
    opacity: 0;
    transition: opacity 0.4s ease;
    pointer-events: none;
    z-index: 1;
}

.ccq-img-wrap:hover .ccq-overlay {
    opacity: 0.85;
}

.ccq-content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    padding: 20px;
    pointer-events: none;
}

.ccq-icon {
    width: 74px;
    height: auto;
}

.ccq-label {
    font-family: "Archivo", sans-serif;
    font-size: 16px;
    font-weight: 800;
    color: #ffffff;
    text-align: center;
    margin: 0;
    line-height: 1.3;
}

/* ── CERTIFICACIONES: imagen sección 2 — bordes redondeados 30px ── */
.elementor-194 .elementor-element-65f04a3 {
    border-radius: 30px !important;
    overflow: hidden !important;
}
.elementor-194 .elementor-element-65f04a3 img {
    border-radius: 30px !important;
    display: block !important;
}

/* ── CERTIFICACIONES: img-11-2 (sección 3) e img-07-2 — esquinas redondeadas 27px ── */
.elementor-194 .elementor-element-54fdcf0 {
    border-radius: 27px !important;
    overflow: hidden !important;
    aspect-ratio: 773 / 444;
    line-height: 0;
}
.elementor-194 .elementor-element-54fdcf0 img {
    border-radius: 27px !important;
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}
.elementor-194 .elementor-element-2decf82 {
    border-radius: 27px !important;
    overflow: hidden !important;
    aspect-ratio: 773 / 443;
    line-height: 0;
}
.elementor-194 .elementor-element-2decf82 img {
    border-radius: 27px !important;
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

/* ── CERTIFICACIONES: imagen sección 4 banner — bordes redondeados 30px ── */
.elementor-194 .elementor-element-3707395 {
    border-radius: 30px !important;
    overflow: hidden !important;
    aspect-ratio: 800 / 313;
    line-height: 0;
}
.elementor-194 .elementor-element-3707395 img {
    border-radius: 30px !important;
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

/* ── CERTIFICACIONES: logos SVG mismo tamaño, alineados a la izquierda ── */
.elementor-194 .elementor-element-b5298cc img,
.elementor-194 .elementor-element-1885d83 img {
    width: 360px !important;
    height: auto !important;
    display: block !important;
    margin-right: auto !important;
    margin-left: 0 !important;
}

/* ── CERTIFICACIONES: overflow visible para sticky ── */
.elementor-194 {
    overflow: visible !important;
}
.elementor-194 > .elementor-element.elementor-element-5b8a623 > .e-con-inner,
.elementor-194 > .elementor-element.elementor-element-28da1b8 > .e-con-inner,
.elementor-194 > .elementor-element.elementor-element-330012a > .e-con-inner,
.elementor-194 > .elementor-element.elementor-element-fb91c58 > .e-con-inner {
    overflow: visible !important;
}

/* ── CERTIFICACIONES: SCROLL STACKING ── */
.elementor-194 > .elementor-element.elementor-element-5b8a623 {
    position: sticky !important;
    top: var(--sticky-top-cert1, 0px) !important;
    z-index: 10 !important;
    height: 350px !important;
}
.elementor-194 > .elementor-element.elementor-element-28da1b8 {
    position: sticky !important;
    top: var(--sticky-top-cert2, 0px) !important;
    z-index: 20 !important;
    min-height: 100vh !important;
}
.elementor-194 > .elementor-element.elementor-element-330012a {
    position: sticky !important;
    top: var(--sticky-top-cert3, 0px) !important;
    z-index: 30 !important;
    min-height: 100vh !important;
    background-color: #ffffff !important;
}
.elementor-194 > .elementor-element.elementor-element-fb91c58 {
    position: sticky !important;
    top: var(--sticky-top-cert4, 0px) !important;
    z-index: 40 !important;
    min-height: 100vh !important;
}

/* Secciones 2-4: sombra superior al apilar */
.elementor-194 > .elementor-element.elementor-element-28da1b8,
.elementor-194 > .elementor-element.elementor-element-330012a,
.elementor-194 > .elementor-element.elementor-element-fb91c58 {
    box-shadow: 0 -16px 48px rgba(0, 0, 0, 0.70), 0 -4px 12px rgba(0, 0, 0, 0.45);
}

/* ── CONTACTOS sección 1: imagen de fondo con sólido negro y luz roja derecha ── */
.elementor-324 > .elementor-element.elementor-element-d5bd503 {
    background-color: #0a0a0a !important;
    background-image:
        radial-gradient(ellipse at 100% 50%, rgba(228, 27, 45, 0.55) 0%, transparent 55%),
        linear-gradient(rgba(0, 0, 0, 0.65), rgba(0, 0, 0, 0.65)),
        url('https://improex.com.ec/wp-content/uploads/2026/07/fondo_cabeceera_banner.jpg') !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
}

/* ── CONTACTOS: SCROLL STACKING ── */
.elementor-324 {
    overflow: visible !important;
}
.elementor-324 > .elementor-element.elementor-element-d5bd503 > .e-con-inner,
.elementor-324 > .elementor-element.elementor-element-77f546f > .e-con-inner {
    overflow: visible !important;
}
.elementor-324 > .elementor-element.elementor-element-d5bd503 {
    position: sticky !important;
    top: var(--sticky-top-con1, 0px) !important;
    z-index: 10 !important;
}
.elementor-324 > .elementor-element.elementor-element-77f546f {
    position: sticky !important;
    top: var(--sticky-top-con2, 0px) !important;
    z-index: 20 !important;
    min-height: 100vh !important;
    box-shadow: 0 -16px 48px rgba(0, 0, 0, 0.70), 0 -4px 12px rgba(0, 0, 0, 0.45);
}

/* ── CONTACTOS sección 2: eliminar micro-fondo del container interno ── */
.elementor-324 .elementor-element.elementor-element-48bc8c8 {
    background: transparent !important;
}

/* ── CONTACTOS sección 1: alto +10% (250px → 275px) ── */
.elementor-324 .elementor-element.elementor-element-d5bd503 {
    min-height: 333px !important;
}

/* ── CONTACTOS pg: bounce/scale en las 2 imágenes ── */
.elementor-324 .elementor-element.elementor-element-161b280,
.elementor-324 .elementor-element.elementor-element-362ff52 {
    transform: scale(1);
    transition: transform 0.55s cubic-bezier(0.34, 1.56, 0.64, 1);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    cursor: pointer;
}

.elementor-324 .elementor-element.elementor-element-161b280:hover,
.elementor-324 .elementor-element.elementor-element-362ff52:hover {
    transform: scale(1.06);
}

/* ── Barra inferior del footer ── */
.improex-footer-bar {
    background-color: #E4192B;
    color: #ffffff;
    text-align: center;
    padding: 17px 10%;
    font-family: "Archivo", sans-serif;
    font-size: 17px;
    font-weight: 300;
    line-height: 1.4;
}
.improex-footer-bar a {
    color: #ffffff !important;
    text-decoration: none;
    font-weight: 600;
    transition: color 0.2s ease;
}
.improex-footer-bar a:hover {
    color: #000000 !important;
    text-decoration: none;
}

/* ── Footer: textos +20% (excluye barra roja) ── */

/* Títulos icon-box: 16px → 19px */
.elementor-145 .elementor-icon-box-title,
.elementor-145 .elementor-icon-box-title a {
    font-size: 19px !important;
}

/* Descripciones icon-box: 14px → 17px */
.elementor-145 .elementor-icon-box-description {
    font-size: 17px !important;
}

/* Texto copyright/subtítulo: 14px → 17px */
.elementor-145 .elementor-element.elementor-element-28b987f {
    font-size: 17px !important;
    line-height: 1.5 !important;
}

/* Menú de navegación del footer: 14px → 17px */
.elementor-145 .elementor-element.elementor-element-bad01ca .elementor-nav-menu .elementor-item {
    font-size: 17px !important;
}

/* Footer: submenu inline debajo del padre (evita flyout JS de SmartMenus) */
.elementor-145 .elementor-element.elementor-element-bad01ca .elementor-nav-menu li > ul {
    position: relative !important;
    left: 0 !important;
    right: auto !important;
    top: 0 !important;
    inset-inline-start: 0 !important;
    width: 100% !important;
    min-width: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    margin: 0 !important;
    padding-left: 14px !important;
}

/* Texto adicional derecha: 14px → 17px */
.elementor-145 .elementor-element.elementor-element-b77e82f {
    font-size: 17px !important;
}

/* img-07 (logo footer): alinear a la izquierda igual que el texto debajo */
.elementor-145 .elementor-element.elementor-element-0dd3cdc {
    align-items: flex-start !important;
}
.elementor-145 .elementor-element.elementor-element-cfa1d00 {
    text-align: left !important;
    width: 100% !important;
}
.elementor-145 .elementor-element.elementor-element-cfa1d00 img {
    display: block !important;
    margin-left: 0 !important;
    margin-right: auto !important;
}

/* ── Footer: mismos márgenes que la cabecera (10% izq y der) ── */
.elementor-145 .elementor-element.elementor-element-c78973d.e-con-boxed > .e-con-inner {
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 10% !important;
    padding-right: 10% !important;
}

/* ── Menú: subrayado rojo deslizante de izquierda a derecha ── */

/* Usar el ::after del <li> para evitar conflicto con el ::after de Elementor en el <a> */
.elementor-15 .elementor-element.elementor-element-22a9220 .elementor-nav-menu li {
    position: relative;
}
.elementor-15 .elementor-element.elementor-element-22a9220 .elementor-nav-menu li::after {
    content: '' !important;
    display: block !important;
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 2px !important;
    background-color: #E4192B !important;
    transform: scaleX(0) !important;
    transform-origin: left center !important;
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1) !important;
    opacity: 1 !important;
    z-index: 10 !important;
}
.elementor-15 .elementor-element.elementor-element-22a9220 .elementor-nav-menu li:hover::after,
.elementor-15 .elementor-element.elementor-element-22a9220 .elementor-nav-menu li.current-menu-item::after {
    transform: scaleX(1) !important;
}

/* Lupa: 25% más grande (18px → 23px) y clickeable */
.elementor-15 .elementor-element.elementor-element-c8d16b3 {
    cursor: pointer;
}
.elementor-15 .elementor-element.elementor-element-c8d16b3 .elementor-icon {
    font-size: 23px !important;
}
.elementor-15 .elementor-element.elementor-element-c8d16b3 .elementor-icon svg {
    height: 23px !important;
    width: 23px !important;
}
.elementor-15 .elementor-element.elementor-element-c8d16b3 .elementor-icon svg path {
    fill: #ffffff;
    transition: fill 0.2s ease;
}
.elementor-15 .elementor-element.elementor-element-c8d16b3:hover .elementor-icon svg path {
    fill: #E4192B;
}

/* Barra de búsqueda — desliza de derecha a izquierda */
#improex-search-bar {
    position: fixed;
    top: 0;
    right: 0;
    width: 50%;
    background: rgba(0, 0, 0, 0.92);
    z-index: 200;
    display: flex;
    align-items: center;
    padding: 0 30px;
    transform: translateX(100%);
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
    border-left: 1px solid rgba(255, 255, 255, 0.15);
    box-sizing: border-box;
}
#improex-search-bar.active {
    transform: translateX(0);
}
#improex-search-bar form {
    display: flex;
    align-items: center;
    width: 100%;
    gap: 14px;
}
#improex-search-bar input[type="search"] {
    flex: 1;
    background: transparent;
    border: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.45);
    color: #ffffff;
    font-size: 15px;
    font-family: "Archivo", sans-serif;
    font-weight: 300;
    padding: 8px 0;
    outline: none;
    -webkit-appearance: none;
}
#improex-search-bar input[type="search"]::placeholder {
    color: rgba(255, 255, 255, 0.45);
}
#improex-search-bar input[type="search"]::-webkit-search-cancel-button {
    display: none;
}
#improex-search-bar button[type="submit"] {
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    display: flex;
    align-items: center;
    flex-shrink: 0;
}
#improex-search-bar button[type="submit"] svg {
    width: 17px;
    height: 17px;
    fill: #ffffff;
    transition: fill 0.2s ease;
}
#improex-search-bar button[type="submit"]:hover svg {
    fill: #E4192B;
}

/* Header: submenu ancho +10% (base Elementor: 12em → 13.2em) */
.elementor-15 .elementor-element.elementor-element-22a9220 .elementor-nav-menu--main .elementor-nav-menu ul {
    width: 13.2em !important;
}

/* ══════════════════════════════════════════════════
   RESPONSIVE MÓVIL
   ══════════════════════════════════════════════════ */

@media (max-width: 767px) {

    /* Cabecera: reducir padding lateral */
    .elementor-15 .elementor-element.elementor-element-9731164.e-con-boxed > .e-con-inner {
        padding-left: 4% !important;
        padding-right: 4% !important;
        padding-top: 2% !important;
        padding-bottom: 2% !important;
    }

    /* Menú móvil: desactivar submenús — primer toque navega directo */
    .elementor-element-22a9220 .elementor-nav-menu--dropdown .sub-menu {
        display: none !important;
    }
    .elementor-element-22a9220 .elementor-nav-menu--dropdown li.menu-item-has-children > a::after {
        display: none !important;
    }

    /* Logo: reducir tamaño */
    .elementor-15 .elementor-element.elementor-element-2b28d52 img {
        width: 150px !important;
    }


    /* Home CANALES: cards en columna */
    .icv2-row {
        flex-direction: column !important;
        align-items: center !important;
    }
    .icv2-card {
        width: 90% !important;
    }

    /* Títulos: 50% más pequeños */
    .elementor-widget-heading .elementor-heading-title {
        zoom: 0.5;
    }

    /* Párrafos y texto: 20% más pequeños */
    .elementor-widget-text-editor p,
    .elementor-widget-text-editor {
        zoom: 0.8;
    }

    /* Home sección 5 (carrusel): reducir alto en móvil */
    .elementor-6 > .elementor-element.elementor-element-9908929 {
        min-height: auto !important;
    }
    .elementor-element-a0f944d .elementor-flip-box,
    .elementor-element-dff9455 .elementor-flip-box,
    .elementor-element-0e48127 .elementor-flip-box,
    .elementor-element-a0f944d,
    .elementor-element-dff9455,
    .elementor-element-0e48127 {
        height: 300px !important;
    }

    /* CANALES sección 5: CANALES pegado al margen izquierdo, PNG fuera del canvas */
    .elementor-235 .elementor-element-1b23b19 {
        position: relative !important;
        top: auto !important;
        left: auto !important;
        transform: none !important;
        width: 100% !important;
        display: flex !important;
        flex-direction: row !important;
        justify-content: flex-start !important;
        align-items: center !important;
        margin-top: 15px !important;
        margin-bottom: 15px !important;
        overflow: visible !important;
    }
    /* PNG posicionado absolutamente fuera del canvas a la izquierda */
    .elementor-235 .elementor-element-931e618 {
        position: absolute !important;
        left: -90px !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
    }
    .elementor-235 .elementor-element-931e618 img {
        max-height: 36px !important;
        width: auto !important;
    }
    /* CANALES texto alineado a la izquierda */
    .elementor-235 .elementor-element-f282963 {
        text-align: left !important;
        margin-left: 0 !important;
    }

    /* CANALES sección 5: bajar la imagen principal para dar espacio al badge */
    .elementor-235 .elementor-element-fc29b01 {
        margin-top: 20px !important;
    }

    /* CANALES sección 4: separar 20px los 2 bloques finales en móvil */
    .elementor-235 .elementor-element.elementor-element-572d268 {
        margin-top: 20px !important;
    }

    /* CERTIFICACIONES sección 4: cards en columna y centradas en móvil */
    .ccq-row {
        flex-direction: column !important;
        align-items: center !important;
        width: 100% !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
    .ccq-card {
        width: 90% !important;
        flex: none !important;
    }

    /* CERTIFICACIONES sección 2: reducir alto 60% en móvil (100vh → 40vh) */
    .elementor-194 > .elementor-element.elementor-element-28da1b8 {
        min-height: 40vh !important;
    }

    /* CERTIFICACIONES sección 1: reducir alto 45% en móvil (350px → 193px) */
    .elementor-194 > .elementor-element.elementor-element-5b8a623 {
        height: 193px !important;
        padding-top: 58px !important;
    }

    /* CANALES sección 2: cards en columna en móvil */
    .cv2-row {
        flex-direction: column !important;
        align-items: center !important;
    }
    .cv2-card {
        width: 90% !important;
    }

    /* CONTACTOS sección 2: fondo negro garantizado con ::before (no puede ser sobreescrito) */
    .elementor-324 > .elementor-element.elementor-element-77f546f {
        background: #000000 !important;
        background-color: #000000 !important;
        background-image: none !important;
    }
    .elementor-324 > .elementor-element.elementor-element-77f546f::before {
        content: '' !important;
        position: absolute !important;
        inset: 0 !important;
        background: #000000 !important;
        z-index: 0 !important;
        pointer-events: none !important;
    }
    .elementor-324 > .elementor-element.elementor-element-77f546f > .e-con-inner {
        position: relative !important;
        z-index: 1 !important;
        background: #000000 !important;
    }

    /* CONTACTOS sección 1: reducir alto 25% en móvil (333px → 250px) */
    .elementor-324 > .elementor-element.elementor-element-d5bd503 {
        min-height: 250px !important;
    }
    /* CONTACTOS sección 1: bajar texto 30% en móvil */
    .elementor-324 .elementor-element.elementor-element-dba70c9 {
        margin-top: 75px !important;
    }

    /* CANALES sección 1: reducir alto 30% en móvil (300px → 210px) */
    .elementor-235 > .elementor-element.elementor-element-3fa143e {
        min-height: 210px !important;
    }

    /* Footer: menú normal sin hamburguesa en móvil */
    .elementor-element-bad01ca .elementor-menu-toggle {
        display: none !important;
    }
    .elementor-element-bad01ca .elementor-nav-menu--main {
        display: flex !important;
    }

    /* Footer: reducir padding lateral 60% en móvil (10% → 4%) */
    .elementor-145 .elementor-element.elementor-element-c78973d.e-con-boxed > .e-con-inner {
        padding-left: 4% !important;
        padding-right: 4% !important;
    }

    /* EXPERIENCIA Y CALIDAD: cards en columna en móvil */
    .eqc-row {
        flex-direction: column;
        align-items: center;
    }
    .eqc-card {
        width: 90% !important;
        max-width: 360px;
        height: auto !important;
    }
    .eqc-img-wrap {
        height: 240px;
    }

    /* Home hero: centrar todo en móvil */
    .elementor-6 .elementor-element.elementor-element-a0d1883 {
        --flex-direction: column !important;
        flex-direction: column !important;
        --align-items: center !important;
        align-items: center !important;
        --justify-content: flex-start !important;
        justify-content: flex-start !important;
        --padding-left: 0% !important;
        --padding-right: 0% !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin-left: 0 !important;
        margin-top: 33vh !important;
        gap: 16px !important;
    }
    /* Imagen reciclable en móvil: centrada, tamaño reducido */
    .elementor-6 .elementor-element.elementor-element-d644583 {
        display: block !important;
        transform: none !important;
        width: auto !important;
        max-width: 100% !important;
        flex: 0 0 auto !important;
        text-align: center !important;
    }
    .elementor-6 .elementor-element.elementor-element-d644583 img {
        width: 100px !important;
        height: auto !important;
        margin: 0 auto !important;
        display: block !important;
    }
    /* Bloque de textos: ancho completo, centrado */
    .elementor-6 .elementor-element.elementor-element-b2e7f31 {
        width: 100% !important;
        max-width: 100% !important;
        --padding-left: 24px !important;
        --padding-right: 24px !important;
        padding-left: 24px !important;
        padding-right: 24px !important;
        --align-items: center !important;
        align-items: center !important;
    }
    /* Centrar cada widget de texto individualmente (Elementor pone text-align:start) */
    .elementor-6 .elementor-element.elementor-element-c4a1e92,
    .elementor-6 .elementor-element.elementor-element-d5b2f03,
    .elementor-6 .elementor-element.elementor-element-f3a9d1e {
        text-align: center !important;
        width: 100% !important;
    }
    .elementor-6 .elementor-element.elementor-element-c4a1e92 .elementor-heading-title,
    .elementor-6 .elementor-element.elementor-element-d5b2f03 .elementor-heading-title,
    .elementor-6 .elementor-element.elementor-element-f3a9d1e .elementor-heading-title {
        text-align: center !important;
    }

}

/* ══════════════════════════════════════════════════════════
   BLOG · ARCHIVO · BÚSQUEDA · POST INDIVIDUAL
   ══════════════════════════════════════════════════════════ */

body.blog,
body.archive,
body.search-results,
body.search,
body.single-post,
body.single,
body.category,
body.tag,
body.date,
body.author { background: #000 !important; }

.blog .site-main,
.archive .site-main,
.search-results .site-main,
.single-post .site-main,
.imp-archive-wrap,
.imp-single-wrap {
    background: #000;
    font-family: 'Archivo', sans-serif;
    width: 100%;
    max-width: 100%;
}

/* Cabecera de archivo / categoría / búsqueda */
.imp-archive-header {
    background: linear-gradient(180deg, #0d0d0d 0%, #000 100%);
    padding: 140px 6% 60px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
}
.imp-archive-header-inner { max-width: 1100px; margin: 0 auto; }
.imp-archive-title {
    font-family: 'Archivo', sans-serif;
    font-size: 42px;
    font-weight: 900;
    color: #fff;
    text-transform: uppercase;
    margin: 0 0 12px;
    line-height: 1.1;
}
.imp-archive-desc {
    font-size: 17px;
    font-weight: 300;
    color: rgba(255,255,255,0.55);
    margin: 0 0 24px;
}
.imp-search-query { color: #e41b2d; }
.imp-red-bar { width: 50px; height: 3px; background: #e41b2d; border-radius: 2px; }

/* Grid de cards */
.imp-posts-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 60px 6%;
}

/* Card */
.imp-post-card {
    background: #111;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.07);
    transition: transform 0.35s cubic-bezier(0.34,1.56,0.64,1), border-color 0.3s;
    display: flex;
    flex-direction: column;
}
.imp-post-card:hover { transform: translateY(-6px); border-color: rgba(228,27,45,0.4); }

/* Imagen */
.imp-post-thumb { display: block; position: relative; overflow: hidden; height: 210px; }
.imp-post-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; display: block; }
.imp-post-card:hover .imp-post-thumb img { transform: scale(1.05); }
.imp-post-thumb-overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, transparent 40%, rgba(0,0,0,0.7)); }

/* Cuerpo */
.imp-post-body { padding: 24px 24px 28px; display: flex; flex-direction: column; flex: 1; }

/* Meta */
.imp-post-meta { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.imp-post-cat { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 1.5px; color: #e41b2d; background: rgba(228,27,45,0.12); padding: 3px 10px; border-radius: 20px; }
.imp-post-date { font-size: 12px; font-weight: 300; color: rgba(255,255,255,0.35); }

/* Título card */
.imp-post-title { font-family: 'Archivo', sans-serif; font-size: 19px; font-weight: 800; line-height: 1.3; margin: 0 0 10px; }
.imp-post-title a { color: #fff; text-decoration: none; transition: color 0.2s; }
.imp-post-title a:hover { color: #e41b2d; }

/* Extracto */
.imp-post-excerpt { font-size: 14px; font-weight: 300; color: rgba(255,255,255,0.55); line-height: 1.65; margin: 0 0 20px; flex: 1; }

/* Botones */
.imp-post-btn {
    display: inline-block;
    font-family: 'Archivo', sans-serif;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #fff;
    background: #e41b2d;
    border: 2px solid #e41b2d;
    padding: 10px 24px;
    border-radius: 26px;
    text-decoration: none;
    align-self: flex-start;
    transition: background 0.2s, color 0.2s;
}
.imp-post-btn:hover { background: #c01525; border-color: #c01525; color: #fff; }
.imp-post-btn.imp-btn-outline { background: transparent; border-color: rgba(255,255,255,0.3); color: rgba(255,255,255,0.7); }
.imp-post-btn.imp-btn-outline:hover { background: #fff; border-color: #fff; color: #000; }

/* Sin resultados */
.imp-no-results { text-align: center; padding: 80px 20px; color: rgba(255,255,255,0.5); font-family: 'Archivo', sans-serif; font-size: 18px; font-weight: 300; }
.imp-no-results strong { color: #fff; }
.imp-no-results .imp-post-btn { margin-top: 24px; }

/* Paginación */
.imp-pagination { display: flex; justify-content: center; gap: 16px; padding: 0 6% 80px; }
.imp-pagination a { font-family: 'Archivo', sans-serif; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: #fff; border: 2px solid rgba(255,255,255,0.2); padding: 10px 28px; border-radius: 26px; text-decoration: none; transition: border-color 0.2s, color 0.2s; }
.imp-pagination a:hover { border-color: #e41b2d; color: #e41b2d; }

/* ══ POST INDIVIDUAL ══════════════════════════════════════ */

.imp-single-hero { background-size: cover; background-position: center; background-repeat: no-repeat; min-height: 480px; display: flex; align-items: flex-end; }
.imp-single-hero-overlay { width: 100%; background: linear-gradient(to top, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.3) 100%); padding: 60px 6% 50px; }
.imp-single-header { background: linear-gradient(180deg, #0d0d0d, #000); padding: 140px 6% 60px; border-bottom: 1px solid rgba(255,255,255,0.06); }
.imp-single-hero-inner { max-width: 860px; }
.imp-single-title { font-family: 'Archivo', sans-serif; font-size: 44px; font-weight: 900; color: #fff; line-height: 1.15; margin: 14px 0 0; text-transform: uppercase; }

.imp-single-content-wrap { background: #000; padding: 60px 6%; }
.imp-single-content { max-width: 860px; margin: 0 auto; }

.imp-single-body { color: rgba(255,255,255,0.8); font-family: 'Archivo', sans-serif; font-size: 17px; font-weight: 300; line-height: 1.8; }
.imp-single-body h2, .imp-single-body h3, .imp-single-body h4 { font-weight: 800; color: #fff; text-transform: uppercase; margin-top: 40px; }
.imp-single-body h2 { font-size: 26px; }
.imp-single-body h3 { font-size: 20px; }
.imp-single-body a { color: #e41b2d; text-decoration: none; }
.imp-single-body a:hover { text-decoration: underline; }
.imp-single-body img { border-radius: 12px; max-width: 100%; height: auto; }
.imp-single-body blockquote { border-left: 4px solid #e41b2d; margin: 30px 0; padding: 16px 24px; background: rgba(228,27,45,0.06); border-radius: 0 8px 8px 0; font-style: italic; color: rgba(255,255,255,0.6); }
.imp-single-body ul, .imp-single-body ol { padding-left: 22px; }
.imp-single-body li { margin-bottom: 8px; }

/* Tags */
.imp-post-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 40px; padding-top: 32px; border-top: 1px solid rgba(255,255,255,0.08); }
.imp-post-tags a { font-family: 'Archivo', sans-serif; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: rgba(255,255,255,0.6); border: 1px solid rgba(255,255,255,0.2); padding: 5px 14px; border-radius: 20px; text-decoration: none; transition: border-color 0.2s, color 0.2s; }
.imp-post-tags a:hover { border-color: #e41b2d; color: #e41b2d; }

.imp-single-nav { margin-top: 40px; }

/* Responsive */
@media (max-width: 1024px) {
    .imp-posts-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
    .imp-archive-title { font-size: 28px; }
    .imp-posts-grid { grid-template-columns: 1fr; padding: 40px 5%; gap: 20px; }
    .imp-single-title { font-size: 28px; }
    .imp-single-hero { min-height: 320px; }
    .imp-single-content-wrap { padding: 40px 5%; }
    .imp-archive-header { padding: 110px 5% 40px; }
    .imp-single-header { padding: 110px 5% 40px; }
}

/* ══ COMENTARIOS ═════════════════════════════════════════ */
.imp-single-wrap .comments-area {
    background: #0a0a0a;
    border-top: 1px solid rgba(255,255,255,0.07);
    padding: 60px 6%;
    font-family: 'Archivo', sans-serif;
}
.imp-single-wrap .comments-area > * { max-width: 860px; margin-left: auto; margin-right: auto; }
.imp-single-wrap .comments-title,
.imp-single-wrap .comment-reply-title {
    font-family: 'Archivo', sans-serif;
    font-size: 22px;
    font-weight: 800;
    color: #fff;
    text-transform: uppercase;
    margin-bottom: 32px;
}
.imp-single-wrap .comment-list { list-style: none; padding: 0; margin: 0 0 48px; }
.imp-single-wrap .comment-list .comment { margin-bottom: 24px; }
.imp-single-wrap .comment-body {
    background: #111;
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 12px;
    padding: 24px;
}
.imp-single-wrap .comment-author .fn { font-size: 14px; font-weight: 700; color: #fff; }
.imp-single-wrap .comment-author img { border-radius: 50%; width: 40px; height: 40px; margin-right: 12px; }
.imp-single-wrap .comment-meta { margin-bottom: 12px; display: flex; align-items: center; gap: 12px; }
.imp-single-wrap .comment-metadata a,
.imp-single-wrap .comment-metadata time { font-size: 12px; color: rgba(255,255,255,0.3); text-decoration: none; }
.imp-single-wrap .comment-content p { font-size: 15px; font-weight: 300; color: rgba(255,255,255,0.65); line-height: 1.7; margin: 0; }
.imp-single-wrap .reply a {
    font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px;
    color: #e41b2d; text-decoration: none; margin-top: 12px; display: inline-block;
}
.imp-single-wrap .reply a:hover { text-decoration: underline; }

/* Formulario de comentarios */
.imp-single-wrap #respond { margin-top: 0; }
.imp-single-wrap .comment-form label {
    display: block; font-size: 11px; font-weight: 700; text-transform: uppercase;
    letter-spacing: 1px; color: rgba(255,255,255,0.5); margin-bottom: 6px;
}
.imp-single-wrap .comment-form input[type="text"],
.imp-single-wrap .comment-form input[type="email"],
.imp-single-wrap .comment-form input[type="url"],
.imp-single-wrap .comment-form textarea {
    background: #1a1a1a !important; border: 1px solid rgba(255,255,255,0.12) !important;
    border-radius: 8px !important; color: #fff !important;
    font-family: 'Archivo', sans-serif !important; font-size: 14px !important;
    padding: 12px 14px !important; width: 100% !important; box-shadow: none !important;
    transition: border-color 0.2s !important;
}
.imp-single-wrap .comment-form input:focus,
.imp-single-wrap .comment-form textarea:focus {
    border-color: #e41b2d !important; outline: none !important;
    box-shadow: 0 0 0 2px rgba(228,27,45,0.15) !important;
}
.imp-single-wrap .comment-form textarea { min-height: 140px; resize: vertical; }
.imp-single-wrap .comment-form .form-submit { margin-top: 8px; }
.imp-single-wrap .comment-form .submit {
    background: #e41b2d !important; border: none !important; border-radius: 26px !important;
    color: #fff !important; font-family: 'Archivo', sans-serif !important;
    font-size: 13px !important; font-weight: 800 !important; text-transform: uppercase !important;
    letter-spacing: 1px !important; padding: 12px 32px !important; cursor: pointer !important;
    transition: background 0.2s !important;
}
.imp-single-wrap .comment-form .submit:hover { background: #c01525 !important; }
.imp-single-wrap .logged-in-as,
.imp-single-wrap .comment-notes { font-size: 13px; color: rgba(255,255,255,0.3); margin-bottom: 20px; }
.imp-single-wrap .logged-in-as a,
.imp-single-wrap .comment-notes a { color: #e41b2d; text-decoration: none; }
