.elementor-1855 .elementor-element.elementor-element-1bed854{--display:flex;--min-height:381px;--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;--gap:21px 0px;--row-gap:21px;--column-gap:0px;--overlay-opacity:0.18;--overlay-mix-blend-mode:luminosity;--margin-top:-79px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:045px;--padding-bottom:30px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-1bed854:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-1bed854 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0F172A;}.elementor-1855 .elementor-element.elementor-element-1bed854::before, .elementor-1855 .elementor-element.elementor-element-1bed854 > .elementor-background-video-container::before, .elementor-1855 .elementor-element.elementor-element-1bed854 > .e-con-inner > .elementor-background-video-container::before, .elementor-1855 .elementor-element.elementor-element-1bed854 > .elementor-background-slideshow::before, .elementor-1855 .elementor-element.elementor-element-1bed854 > .e-con-inner > .elementor-background-slideshow::before, .elementor-1855 .elementor-element.elementor-element-1bed854 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-color:transparent;--background-overlay:'';background-image:linear-gradient(189deg, #0F172A 41%, #0EA6EA 81%);}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );color:var( --e-global-color-primary );}.elementor-1855 .elementor-element.elementor-element-8639e1a{text-align:center;}.elementor-1855 .elementor-element.elementor-element-8639e1a .elementor-heading-title{font-family:"Inter-Sotedev", Sans-serif;font-size:45px;font-weight:900;text-transform:uppercase;font-style:normal;color:#FFFFFF;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-1855 .elementor-element.elementor-element-3ac5e74{font-family:"Inter-Sotedev", Sans-serif;font-weight:400;}.elementor-1855 .elementor-element.elementor-element-ac08682{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-1855 .elementor-element.elementor-element-a9447c7{--display:flex;--min-height:417px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-a9447c7:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-a9447c7 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2025/10/Storage-cusco-web-1.webp");background-position:center left;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-9ee9917{--display:flex;--min-height:238px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-9ee9917:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-9ee9917 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2025/10/Enviovelozdominicana-web.webp");background-position:center center;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-b367bd3{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-1855 .elementor-element.elementor-element-d6ff63a{--display:flex;--min-height:417px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-d6ff63a:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-d6ff63a > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2025/10/Massara-logistic.webp");background-position:center left;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-1a6d6f2{--display:flex;--min-height:238px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-1a6d6f2:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-1a6d6f2 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2025/10/Envio-Veloz-Factura.webp");background-position:center center;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-75708a6{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-1855 .elementor-element.elementor-element-62a92b3{--display:flex;--min-height:417px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-62a92b3:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-62a92b3 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2025/10/perrurapa.webp");background-position:center left;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-577453f{--display:flex;--min-height:238px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-577453f:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-577453f > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2025/11/pagina-presto-shipping-2026-1.webp");background-position:center center;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-2b24f49{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-1855 .elementor-element.elementor-element-3e1f6dd{--display:flex;--min-height:417px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-3e1f6dd:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-3e1f6dd > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2025/10/Prestoshipping-php.webp");background-position:center left;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-1726fa9{--display:flex;--min-height:238px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-1726fa9:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-1726fa9 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2025/10/Multitenencia-1.webp");background-position:center center;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-a0718b0{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-1855 .elementor-element.elementor-element-fc883a2{--display:flex;--min-height:417px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-fc883a2:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-fc883a2 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2025/10/hginpro.webp");background-position:center left;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-30734fb{--display:flex;--min-height:238px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-30734fb:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-30734fb > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2025/10/PromedPeru.webp");background-position:center center;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-bf73127{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-1855 .elementor-element.elementor-element-a489655{--display:flex;--min-height:417px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-a489655:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-a489655 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2025/11/Atokongo-tech.webp");background-position:center left;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-aff0d84{--display:flex;--min-height:417px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-aff0d84:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-aff0d84 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2026/01/plaza-rental-car-1.webp");background-position:center left;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-be948c1{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-1855 .elementor-element.elementor-element-e2d2877{--display:flex;--min-height:417px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-e2d2877:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-e2d2877 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2026/01/vectiss-siioweb-1.webp");background-position:center left;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-d2c9382{--display:flex;--min-height:417px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-d2c9382:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-d2c9382 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2026/01/donaciones-1.webp");background-position:center left;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-01d590b{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-1855 .elementor-element.elementor-element-70dffe2{--display:flex;--min-height:417px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-70dffe2:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-70dffe2 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2026/01/Sitio-Web-Freddy-castillo-1.webp");background-position:center left;background-repeat:no-repeat;background-size:cover;}.elementor-1855 .elementor-element.elementor-element-f56fa9c{--display:flex;--min-height:417px;--justify-content:flex-end;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--overflow:hidden;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-f56fa9c:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-f56fa9c > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://portafolio.sotelodevweb.com/wp-content/uploads/2026/01/fastcar.webp");background-position:center left;background-repeat:no-repeat;background-size:cover;}.elementor-widget-button .elementor-button{background-color:var( --e-global-color-accent );font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-1855 .elementor-element.elementor-element-af64793 > .elementor-widget-container{margin:20px 0px 0px 0px;}.elementor-1855 .elementor-element.elementor-element-af64793 .elementor-button{border-radius:5px 5px 5px 5px;padding:20px 20px 20px 20px;}@media(min-width:768px){.elementor-1855 .elementor-element.elementor-element-a489655{--width:49%;}.elementor-1855 .elementor-element.elementor-element-aff0d84{--width:49%;}.elementor-1855 .elementor-element.elementor-element-e2d2877{--width:49%;}.elementor-1855 .elementor-element.elementor-element-d2c9382{--width:49%;}.elementor-1855 .elementor-element.elementor-element-70dffe2{--width:49%;}.elementor-1855 .elementor-element.elementor-element-f56fa9c{--width:49%;}}@media(max-width:1024px){.elementor-1855 .elementor-element.elementor-element-8639e1a .elementor-heading-title{font-size:30px;}}@media(max-width:767px){.elementor-1855 .elementor-element.elementor-element-1bed854{--gap:15px 0px;--row-gap:15px;--column-gap:0px;--margin-top:-75px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:30px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1855 .elementor-element.elementor-element-8639e1a{text-align:center;}.elementor-1855 .elementor-element.elementor-element-8639e1a .elementor-heading-title{font-size:26px;}.elementor-1855 .elementor-element.elementor-element-3ac5e74{text-align:center;font-size:15px;}.elementor-1855 .elementor-element.elementor-element-ac08682{--width:100%;}.elementor-1855 .elementor-element.elementor-element-a9447c7{--min-height:305px;--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-1855 .elementor-element.elementor-element-a9447c7:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-a9447c7 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-size:contain;}.elementor-1855 .elementor-element.elementor-element-9ee9917:not(.elementor-motion-effects-element-type-background), .elementor-1855 .elementor-element.elementor-element-9ee9917 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-size:cover;}.elementor-1855 .elementor-element.elementor-element-b367bd3{--width:100%;}.elementor-1855 .elementor-element.elementor-element-d6ff63a{--min-height:305px;--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-1855 .elementor-element.elementor-element-75708a6{--width:100%;}.elementor-1855 .elementor-element.elementor-element-62a92b3{--min-height:305px;--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-1855 .elementor-element.elementor-element-2b24f49{--width:100%;}.elementor-1855 .elementor-element.elementor-element-3e1f6dd{--min-height:305px;--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-1855 .elementor-element.elementor-element-a0718b0{--width:100%;}.elementor-1855 .elementor-element.elementor-element-fc883a2{--min-height:305px;--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-1855 .elementor-element.elementor-element-bf73127{--width:100%;}.elementor-1855 .elementor-element.elementor-element-a489655{--min-height:305px;--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-1855 .elementor-element.elementor-element-aff0d84{--min-height:305px;--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-1855 .elementor-element.elementor-element-be948c1{--width:100%;}.elementor-1855 .elementor-element.elementor-element-e2d2877{--min-height:305px;--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-1855 .elementor-element.elementor-element-d2c9382{--min-height:305px;--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-1855 .elementor-element.elementor-element-01d590b{--width:100%;}.elementor-1855 .elementor-element.elementor-element-70dffe2{--min-height:305px;--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-1855 .elementor-element.elementor-element-f56fa9c{--min-height:305px;--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;}}/* Start custom CSS for heading, class: .elementor-element-8639e1a */.sombra-encabezado {
    color: #0ea5eb;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-8e35651 *//* =========================
   Tarjeta con panel deslizante
   (fondo en el contenedor .card)
   ========================= */

/* Carga de fuente (opcional)
@font-face{
  font-family:"Inter-Sotedev";
  src:url("/ruta/inter-sotedev.woff2") format("woff2");
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}
*/

:root{
  /* Diseño */
  --pad: 18px;
  --t: .5s;
  --radius: 18px;
  --shadow: 0 12px 28px rgba(0,0,0,.18);
  --shadow-hover: 0 16px 36px rgba(0,0,0,.22);

  /* Tipografías (tus tamaños) */
  --ff: "Inter-Sotedev", Inter, system-ui, Arial, sans-serif;
  --title-size: 42px;  /* Título */
  --title-lh: 1.25;
  --text-size: 18px;   /* Texto */
  --btn-size: 16px;    /* Botón */
  --btn-grad-start: #1a9cff;   /* azul */
  --btn-grad-end:   #12e1c7;   /* turquesa */
  --btn-text:       #ffffff;   /* blanco */

  /* Colores */
  --fg: #fff;
  --cta-bg: #fff;
  --cta-fg: #111;

  /* Gradiente (oscuro pero no negro) */
  --overlay: linear-gradient(
    180deg,
    rgba(14,18,26,.30) 0%,
    rgba(14,18,26,.55) 38%,
    rgba(14,18,26,.78) 72%,
    rgba(14,18,26,.86) 100%
  );

  /* ALTURA visible cuando está cerrado (solo título)
     — Seguro: fija en px.
     — Si quieres modo dinámico: usa
       calc(var(--title-size) * var(--title-lh) + var(--pad) * 2) */
  --peek: 82px; /* <— ajusta a gusto */
}

*{ box-sizing:border-box }

.card{
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: var(--shadow);

  /* imagen de fondo: configúrala en Elementor:
     background-size: cover; background-position: center; */
  width: min(92vw, 600px);
  height: 420px;

  will-change: transform;
  transition: box-shadow .25s ease;
}

@media (min-width:1024px){
  .card{ width: 550px; height: 417px; }
}

.card:hover{ box-shadow: var(--shadow-hover); }

/* El enlace cubre toda la tarjeta */
.card__link{
  position: absolute; inset: 0;
  display: block; text-decoration: none;
  /* Pulido táctil (no afecta desktop) */
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

/* Panel deslizante */
.card__content{
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: var(--pad);
  display: grid; gap: 12px;
  color: var(--fg);

  /* Legibilidad sobre imagen */
  background: var(--overlay);
  backdrop-filter: saturate(120%) blur(3px);
  -webkit-backdrop-filter: saturate(120%) blur(3px);

  /* ESTADO CERRADO: solo franja del título visible */
  transform: translateY(calc(100% - var(--peek))) translateZ(0);
  transition: transform var(--t) ease;
  will-change: transform;
}

/* ====== TRIGGERS DE APERTURA ====== */
/* hover en la tarjeta */
.card:hover > .card__link > .card__content{
  transform: translateY(0) translateZ(0);
}
/* hover en el <a> (por si algún wrapper intercepta el hover del padre) */
.card > .card__link:hover > .card__content{
  transform: translateY(0) translateZ(0);
}
/* foco por teclado (accesibilidad) */
.card:focus-within > .card__link > .card__content{
  transform: translateY(0) translateZ(0);
}

/* Tipos */
.card__title{
  margin: 0;
  font-family: var(--ff);
  font-weight: 900;
  font-size: var(--title-size);
  line-height: var(--title-lh);
  letter-spacing: .2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  text-shadow: 0 1px 2px rgba(0,0,0,.36);
}

.card__text{
  margin: 0;
  font-family: var(--ff);
  font-weight: 400;
  font-size: var(--text-size);
  line-height: 1.45;
  opacity: .96;
  max-width: 48ch;
  text-shadow: 0 1px 2px rgba(0,0,0,.25);
}

.card__button{
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: .6ch;

  padding: 14px 20px;                /* un poco más “botón” */
  border-radius: 12px;

  background: linear-gradient(90deg, var(--btn-grad-start), var(--btn-grad-end));
  color: var(--btn-text);

  font-family: var(--ff);
  font-weight: 900;
  font-size: var(--btn-size);        /* 16px según tu config */
  line-height: 1;

  box-shadow: 0 8px 18px rgba(0,0,0,.18);
  text-shadow: 0 1px 1px rgba(0,0,0,.15);
  user-select: none;
  border: 0;
  transform: translateZ(0);          /* suaviza en GPU */
}

/* Flecha al final (opcional) */
.card__button::after{
  content: "›";                      /* o "➜" */
  font-weight: 900;
  opacity: .95;
}

/* Hover/active (escritiorio) */
.card:hover .card__button{
  filter: brightness(1.05);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
}

/* Estado "presionado" sutil */
.card:active .card__button{
  transform: translateY(1px);
  filter: brightness(0.98);
}

/* Si quieres que el botón sea ancho completo en móviles */
@media (max-width: 480px){
  .card__button{ width: 100%; justify-content: center; }
}

/* Focus visible */
.card__link:focus-visible{
  outline: 3px solid rgba(255,255,255,.9);
  outline-offset: -3px;   /* dentro de los bordes redondeados */
  border-radius: var(--radius);
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .card__content{ transition: none !important; transform: none !important; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-b3dded4 *//* =========================
   Tarjeta con panel deslizante
   (fondo en el contenedor .card)
   ========================= */

/* Carga de fuente (opcional)
@font-face{
  font-family:"Inter-Sotedev";
  src:url("/ruta/inter-sotedev.woff2") format("woff2");
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}
*/

:root{
  /* Diseño */
  --pad: 18px;
  --t: .5s;
  --radius: 18px;
  --shadow: 0 12px 28px rgba(0,0,0,.18);
  --shadow-hover: 0 16px 36px rgba(0,0,0,.22);

  /* Tipografías (tus tamaños) */
  --ff: "Inter-Sotedev", Inter, system-ui, Arial, sans-serif;
  --title-size: 42px;  /* Título */
  --title-lh: 1.25;
  --text-size: 18px;   /* Texto */
  --btn-size: 16px;    /* Botón */
  --btn-grad-start: #1a9cff;   /* azul */
  --btn-grad-end:   #12e1c7;   /* turquesa */
  --btn-text:       #ffffff;   /* blanco */

  /* Colores */
  --fg: #fff;
  --cta-bg: #fff;
  --cta-fg: #111;

  /* Gradiente (oscuro pero no negro) */
  --overlay: linear-gradient(
    180deg,
    rgba(14,18,26,.30) 0%,
    rgba(14,18,26,.55) 38%,
    rgba(14,18,26,.78) 72%,
    rgba(14,18,26,.86) 100%
  );

  /* ALTURA visible cuando está cerrado (solo título)
     — Seguro: fija en px.
     — Si quieres modo dinámico: usa
       calc(var(--title-size) * var(--title-lh) + var(--pad) * 2) */
  --peek: 82px; /* <— ajusta a gusto */
}

*{ box-sizing:border-box }

.card{
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: var(--shadow);

  /* imagen de fondo: configúrala en Elementor:
     background-size: cover; background-position: center; */
  width: min(92vw, 600px);
  height: 420px;

  will-change: transform;
  transition: box-shadow .25s ease;
}

@media (min-width:1024px){
  .card{ width: 550px; height: 417px; }
}

.card:hover{ box-shadow: var(--shadow-hover); }

/* El enlace cubre toda la tarjeta */
.card__link{
  position: absolute; inset: 0;
  display: block; text-decoration: none;
  /* Pulido táctil (no afecta desktop) */
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

/* Panel deslizante */
.card__content{
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: var(--pad);
  display: grid; gap: 12px;
  color: var(--fg);

  /* Legibilidad sobre imagen */
  background: var(--overlay);
  backdrop-filter: saturate(120%) blur(3px);
  -webkit-backdrop-filter: saturate(120%) blur(3px);

  /* ESTADO CERRADO: solo franja del título visible */
  transform: translateY(calc(100% - var(--peek))) translateZ(0);
  transition: transform var(--t) ease;
  will-change: transform;
}

/* ====== TRIGGERS DE APERTURA ====== */
/* hover en la tarjeta */
.card:hover > .card__link > .card__content{
  transform: translateY(0) translateZ(0);
}
/* hover en el <a> (por si algún wrapper intercepta el hover del padre) */
.card > .card__link:hover > .card__content{
  transform: translateY(0) translateZ(0);
}
/* foco por teclado (accesibilidad) */
.card:focus-within > .card__link > .card__content{
  transform: translateY(0) translateZ(0);
}

/* Tipos */
.card__title{
  margin: 0;
  font-family: var(--ff);
  font-weight: 900;
  font-size: var(--title-size);
  line-height: var(--title-lh);
  letter-spacing: .2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  text-shadow: 0 1px 2px rgba(0,0,0,.36);
}

.card__text{
  margin: 0;
  font-family: var(--ff);
  font-weight: 400;
  font-size: var(--text-size);
  line-height: 1.45;
  opacity: .96;
  max-width: 48ch;
  text-shadow: 0 1px 2px rgba(0,0,0,.25);
}

.card__button{
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: .6ch;

  padding: 14px 20px;                /* un poco más “botón” */
  border-radius: 12px;

  background: linear-gradient(90deg, var(--btn-grad-start), var(--btn-grad-end));
  color: var(--btn-text);

  font-family: var(--ff);
  font-weight: 900;
  font-size: var(--btn-size);        /* 16px según tu config */
  line-height: 1;

  box-shadow: 0 8px 18px rgba(0,0,0,.18);
  text-shadow: 0 1px 1px rgba(0,0,0,.15);
  user-select: none;
  border: 0;
  transform: translateZ(0);          /* suaviza en GPU */
}

/* Flecha al final (opcional) */
.card__button::after{
  content: "›";                      /* o "➜" */
  font-weight: 900;
  opacity: .95;
}

/* Hover/active (escritiorio) */
.card:hover .card__button{
  filter: brightness(1.05);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
}

/* Estado "presionado" sutil */
.card:active .card__button{
  transform: translateY(1px);
  filter: brightness(0.98);
}

/* Si quieres que el botón sea ancho completo en móviles */
@media (max-width: 480px){
  .card__button{ width: 100%; justify-content: center; }
}

/* Focus visible */
.card__link:focus-visible{
  outline: 3px solid rgba(255,255,255,.9);
  outline-offset: -3px;   /* dentro de los bordes redondeados */
  border-radius: var(--radius);
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .card__content{ transition: none !important; transform: none !important; }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-ac08682 *//* Padre */
.card-wrapper{
  position: relative;
  overflow: hidden;
  cursor: pointer;                     /* ayuda a iOS a tratarlo como interactivo */
  touch-action: manipulation;          /* reduce la latencia del tap */
  -webkit-tap-highlight-color: transparent; /* quita el flash azul en iOS */
  -webkit-user-select: none;           /* evita selección accidental */
  -webkit-touch-callout: none;         /* evita menú de toque mantenido */
}

/* Hijo que sube */
.card-content{
  transition: transform .5s ease, height .5s ease, margin-bottom .5s ease, opacity .5s ease;
  will-change: transform, height;
}

/* Desktop (igual que tenías) */
@media (min-width:1024px) and (hover:hover){
  .card-content{ height:55%; margin-bottom:-150px; transform:none; }
  .card-wrapper:hover .card-content{ height:70%; margin-bottom:0; }
  .card-wrapper:hover .card-content .e-con-inner{ justify-content:end; }
}

/* Móvil / tablet (sin hover) */
@media (max-width:1023.98px), (hover:none){
  /* Estado base: “abajo” con translate, no con margin, para no romper layout */
  .card-content{
    height: auto;
    margin-bottom: 0;
    transform: translateY(150px);   /* ajusta la distancia */
  }

  /* Sube mientras se toca o hay foco dentro */
  .card-wrapper:active .card-content,
  .card-wrapper:focus-within .card-content{
    transform: translateY(0);
  }
}

/* Accesibilidad */
@media (prefers-reduced-motion: reduce){
  .card-content{ transition:none !important; transform:none !important; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-2dd80ed *//* =========================
   Tarjeta con panel deslizante
   (fondo en el contenedor .card)
   ========================= */

/* Carga de fuente (opcional)
@font-face{
  font-family:"Inter-Sotedev";
  src:url("/ruta/inter-sotedev.woff2") format("woff2");
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}
*/

:root{
  /* Diseño */
  --pad: 18px;
  --t: .5s;
  --radius: 18px;
  --shadow: 0 12px 28px rgba(0,0,0,.18);
  --shadow-hover: 0 16px 36px rgba(0,0,0,.22);

  /* Tipografías (tus tamaños) */
  --ff: "Inter-Sotedev", Inter, system-ui, Arial, sans-serif;
  --title-size: 42px;  /* Título */
  --title-lh: 1.25;
  --text-size: 18px;   /* Texto */
  --btn-size: 16px;    /* Botón */
  --btn-grad-start: #1a9cff;   /* azul */
  --btn-grad-end:   #12e1c7;   /* turquesa */
  --btn-text:       #ffffff;   /* blanco */

  /* Colores */
  --fg: #fff;
  --cta-bg: #fff;
  --cta-fg: #111;

  /* Gradiente (oscuro pero no negro) */
  --overlay: linear-gradient(
    180deg,
    rgba(14,18,26,.30) 0%,
    rgba(14,18,26,.55) 38%,
    rgba(14,18,26,.78) 72%,
    rgba(14,18,26,.86) 100%
  );

  /* ALTURA visible cuando está cerrado (solo título)
     — Seguro: fija en px.
     — Si quieres modo dinámico: usa
       calc(var(--title-size) * var(--title-lh) + var(--pad) * 2) */
  --peek: 82px; /* <— ajusta a gusto */
}

*{ box-sizing:border-box }

.card{
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: var(--shadow);

  /* imagen de fondo: configúrala en Elementor:
     background-size: cover; background-position: center; */
  width: min(92vw, 600px);
  height: 420px;

  will-change: transform;
  transition: box-shadow .25s ease;
}

@media (min-width:1024px){
  .card{ width: 550px; height: 417px; }
}

.card:hover{ box-shadow: var(--shadow-hover); }

/* El enlace cubre toda la tarjeta */
.card__link{
  position: absolute; inset: 0;
  display: block; text-decoration: none;
  /* Pulido táctil (no afecta desktop) */
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

/* Panel deslizante */
.card__content{
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: var(--pad);
  display: grid; gap: 12px;
  color: var(--fg);

  /* Legibilidad sobre imagen */
  background: var(--overlay);
  backdrop-filter: saturate(120%) blur(3px);
  -webkit-backdrop-filter: saturate(120%) blur(3px);

  /* ESTADO CERRADO: solo franja del título visible */
  transform: translateY(calc(100% - var(--peek))) translateZ(0);
  transition: transform var(--t) ease;
  will-change: transform;
}

/* ====== TRIGGERS DE APERTURA ====== */
/* hover en la tarjeta */
.card:hover > .card__link > .card__content{
  transform: translateY(0) translateZ(0);
}
/* hover en el <a> (por si algún wrapper intercepta el hover del padre) */
.card > .card__link:hover > .card__content{
  transform: translateY(0) translateZ(0);
}
/* foco por teclado (accesibilidad) */
.card:focus-within > .card__link > .card__content{
  transform: translateY(0) translateZ(0);
}

/* Tipos */
.card__title{
  margin: 0;
  font-family: var(--ff);
  font-weight: 900;
  font-size: var(--title-size);
  line-height: var(--title-lh);
  letter-spacing: .2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  text-shadow: 0 1px 2px rgba(0,0,0,.36);
}

.card__text{
  margin: 0;
  font-family: var(--ff);
  font-weight: 400;
  font-size: var(--text-size);
  line-height: 1.45;
  opacity: .96;
  max-width: 48ch;
  text-shadow: 0 1px 2px rgba(0,0,0,.25);
}

.card__button{
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: .6ch;

  padding: 14px 20px;                /* un poco más “botón” */
  border-radius: 12px;

  background: linear-gradient(90deg, var(--btn-grad-start), var(--btn-grad-end));
  color: var(--btn-text);

  font-family: var(--ff);
  font-weight: 900;
  font-size: var(--btn-size);        /* 16px según tu config */
  line-height: 1;

  box-shadow: 0 8px 18px rgba(0,0,0,.18);
  text-shadow: 0 1px 1px rgba(0,0,0,.15);
  user-select: none;
  border: 0;
  transform: translateZ(0);          /* suaviza en GPU */
}

/* Flecha al final (opcional) */
.card__button::after{
  content: "›";                      /* o "➜" */
  font-weight: 900;
  opacity: .95;
}

/* Hover/active (escritiorio) */
.card:hover .card__button{
  filter: brightness(1.05);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
}

/* Estado "presionado" sutil */
.card:active .card__button{
  transform: translateY(1px);
  filter: brightness(0.98);
}

/* Si quieres que el botón sea ancho completo en móviles */
@media (max-width: 480px){
  .card__button{ width: 100%; justify-content: center; }
}

/* Focus visible */
.card__link:focus-visible{
  outline: 3px solid rgba(255,255,255,.9);
  outline-offset: -3px;   /* dentro de los bordes redondeados */
  border-radius: var(--radius);
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .card__content{ transition: none !important; transform: none !important; }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-b367bd3 *//* Padre */
.card-wrapper{
  position: relative;
  overflow: hidden;
  cursor: pointer;                     /* ayuda a iOS a tratarlo como interactivo */
  touch-action: manipulation;          /* reduce la latencia del tap */
  -webkit-tap-highlight-color: transparent; /* quita el flash azul en iOS */
  -webkit-user-select: none;           /* evita selección accidental */
  -webkit-touch-callout: none;         /* evita menú de toque mantenido */
}

/* Hijo que sube */
.card-content{
  transition: transform .5s ease, height .5s ease, margin-bottom .5s ease, opacity .5s ease;
  will-change: transform, height;
}

/* Desktop (igual que tenías) */
@media (min-width:1024px) and (hover:hover){
  .card-content{ height:55%; margin-bottom:-150px; transform:none; }
  .card-wrapper:hover .card-content{ height:70%; margin-bottom:0; }
  .card-wrapper:hover .card-content .e-con-inner{ justify-content:end; }
}

/* Móvil / tablet (sin hover) */
@media (max-width:1023.98px), (hover:none){
  /* Estado base: “abajo” con translate, no con margin, para no romper layout */
  .card-content{
    height: auto;
    margin-bottom: 0;
    transform: translateY(150px);   /* ajusta la distancia */
  }

  /* Sube mientras se toca o hay foco dentro */
  .card-wrapper:active .card-content,
  .card-wrapper:focus-within .card-content{
    transform: translateY(0);
  }
}

/* Accesibilidad */
@media (prefers-reduced-motion: reduce){
  .card-content{ transition:none !important; transform:none !important; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-02f8333 *//* =========================
   Tarjeta con panel deslizante
   (fondo en el contenedor .card)
   ========================= */

/* Carga de fuente (opcional)
@font-face{
  font-family:"Inter-Sotedev";
  src:url("/ruta/inter-sotedev.woff2") format("woff2");
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}
*/

:root{
  /* Diseño */
  --pad: 18px;
  --t: .5s;
  --radius: 18px;
  --shadow: 0 12px 28px rgba(0,0,0,.18);
  --shadow-hover: 0 16px 36px rgba(0,0,0,.22);

  /* Tipografías (tus tamaños) */
  --ff: "Inter-Sotedev", Inter, system-ui, Arial, sans-serif;
  --title-size: 42px;  /* Título */
  --title-lh: 1.25;
  --text-size: 18px;   /* Texto */
  --btn-size: 16px;    /* Botón */
  --btn-grad-start: #1a9cff;   /* azul */
  --btn-grad-end:   #12e1c7;   /* turquesa */
  --btn-text:       #ffffff;   /* blanco */

  /* Colores */
  --fg: #fff;
  --cta-bg: #fff;
  --cta-fg: #111;

  /* Gradiente (oscuro pero no negro) */
  --overlay: linear-gradient(
    180deg,
    rgba(14,18,26,.30) 0%,
    rgba(14,18,26,.55) 38%,
    rgba(14,18,26,.78) 72%,
    rgba(14,18,26,.86) 100%
  );

  /* ALTURA visible cuando está cerrado (solo título)
     — Seguro: fija en px.
     — Si quieres modo dinámico: usa
       calc(var(--title-size) * var(--title-lh) + var(--pad) * 2) */
  --peek: 82px; /* <— ajusta a gusto */
}

*{ box-sizing:border-box }

.card{
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: var(--shadow);

  /* imagen de fondo: configúrala en Elementor:
     background-size: cover; background-position: center; */
  width: min(92vw, 600px);
  height: 420px;

  will-change: transform;
  transition: box-shadow .25s ease;
}

@media (min-width:1024px){
  .card{ width: 550px; height: 417px; }
}

.card:hover{ box-shadow: var(--shadow-hover); }

/* El enlace cubre toda la tarjeta */
.card__link{
  position: absolute; inset: 0;
  display: block; text-decoration: none;
  /* Pulido táctil (no afecta desktop) */
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

/* Panel deslizante */
.card__content{
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: var(--pad);
  display: grid; gap: 12px;
  color: var(--fg);

  /* Legibilidad sobre imagen */
  background: var(--overlay);
  backdrop-filter: saturate(120%) blur(3px);
  -webkit-backdrop-filter: saturate(120%) blur(3px);

  /* ESTADO CERRADO: solo franja del título visible */
  transform: translateY(calc(100% - var(--peek))) translateZ(0);
  transition: transform var(--t) ease;
  will-change: transform;
}

/* ====== TRIGGERS DE APERTURA ====== */
/* hover en la tarjeta */
.card:hover > .card__link > .card__content{
  transform: translateY(0) translateZ(0);
}
/* hover en el <a> (por si algún wrapper intercepta el hover del padre) */
.card > .card__link:hover > .card__content{
  transform: translateY(0) translateZ(0);
}
/* foco por teclado (accesibilidad) */
.card:focus-within > .card__link > .card__content{
  transform: translateY(0) translateZ(0);
}

/* Tipos */
.card__title{
  margin: 0;
  font-family: var(--ff);
  font-weight: 900;
  font-size: var(--title-size);
  line-height: var(--title-lh);
  letter-spacing: .2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  text-shadow: 0 1px 2px rgba(0,0,0,.36);
}

.card__text{
  margin: 0;
  font-family: var(--ff);
  font-weight: 400;
  font-size: var(--text-size);
  line-height: 1.45;
  opacity: .96;
  max-width: 48ch;
  text-shadow: 0 1px 2px rgba(0,0,0,.25);
}

.card__button{
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: .6ch;

  padding: 14px 20px;                /* un poco más “botón” */
  border-radius: 12px;

  background: linear-gradient(90deg, var(--btn-grad-start), var(--btn-grad-end));
  color: var(--btn-text);

  font-family: var(--ff);
  font-weight: 900;
  font-size: var(--btn-size);        /* 16px según tu config */
  line-height: 1;

  box-shadow: 0 8px 18px rgba(0,0,0,.18);
  text-shadow: 0 1px 1px rgba(0,0,0,.15);
  user-select: none;
  border: 0;
  transform: translateZ(0);          /* suaviza en GPU */
}

/* Flecha al final (opcional) */
.card__button::after{
  content: "›";                      /* o "➜" */
  font-weight: 900;
  opacity: .95;
}

/* Hover/active (escritiorio) */
.card:hover .card__button{
  filter: brightness(1.05);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
}

/* Estado "presionado" sutil */
.card:active .card__button{
  transform: translateY(1px);
  filter: brightness(0.98);
}

/* Si quieres que el botón sea ancho completo en móviles */
@media (max-width: 480px){
  .card__button{ width: 100%; justify-content: center; }
}

/* Focus visible */
.card__link:focus-visible{
  outline: 3px solid rgba(255,255,255,.9);
  outline-offset: -3px;   /* dentro de los bordes redondeados */
  border-radius: var(--radius);
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .card__content{ transition: none !important; transform: none !important; }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-75708a6 *//* Padre */
.card-wrapper{
  position: relative;
  overflow: hidden;
  cursor: pointer;                     /* ayuda a iOS a tratarlo como interactivo */
  touch-action: manipulation;          /* reduce la latencia del tap */
  -webkit-tap-highlight-color: transparent; /* quita el flash azul en iOS */
  -webkit-user-select: none;           /* evita selección accidental */
  -webkit-touch-callout: none;         /* evita menú de toque mantenido */
}

/* Hijo que sube */
.card-content{
  transition: transform .5s ease, height .5s ease, margin-bottom .5s ease, opacity .5s ease;
  will-change: transform, height;
}

/* Desktop (igual que tenías) */
@media (min-width:1024px) and (hover:hover){
  .card-content{ height:55%; margin-bottom:-150px; transform:none; }
  .card-wrapper:hover .card-content{ height:70%; margin-bottom:0; }
  .card-wrapper:hover .card-content .e-con-inner{ justify-content:end; }
}

/* Móvil / tablet (sin hover) */
@media (max-width:1023.98px), (hover:none){
  /* Estado base: “abajo” con translate, no con margin, para no romper layout */
  .card-content{
    height: auto;
    margin-bottom: 0;
    transform: translateY(150px);   /* ajusta la distancia */
  }

  /* Sube mientras se toca o hay foco dentro */
  .card-wrapper:active .card-content,
  .card-wrapper:focus-within .card-content{
    transform: translateY(0);
  }
}

/* Accesibilidad */
@media (prefers-reduced-motion: reduce){
  .card-content{ transition:none !important; transform:none !important; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-f973011 *//* =========================
   Tarjeta con panel deslizante
   (fondo en el contenedor .card)
   ========================= */

/* Carga de fuente (opcional)
@font-face{
  font-family:"Inter-Sotedev";
  src:url("/ruta/inter-sotedev.woff2") format("woff2");
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}
*/

:root{
  /* Diseño */
  --pad: 18px;
  --t: .5s;
  --radius: 18px;
  --shadow: 0 12px 28px rgba(0,0,0,.18);
  --shadow-hover: 0 16px 36px rgba(0,0,0,.22);

  /* Tipografías (tus tamaños) */
  --ff: "Inter-Sotedev", Inter, system-ui, Arial, sans-serif;
  --title-size: 42px;  /* Título */
  --title-lh: 1.25;
  --text-size: 18px;   /* Texto */
  --btn-size: 16px;    /* Botón */
  --btn-grad-start: #1a9cff;   /* azul */
  --btn-grad-end:   #12e1c7;   /* turquesa */
  --btn-text:       #ffffff;   /* blanco */

  /* Colores */
  --fg: #fff;
  --cta-bg: #fff;
  --cta-fg: #111;

  /* Gradiente (oscuro pero no negro) */
  --overlay: linear-gradient(
    180deg,
    rgba(14,18,26,.30) 0%,
    rgba(14,18,26,.55) 38%,
    rgba(14,18,26,.78) 72%,
    rgba(14,18,26,.86) 100%
  );

  /* ALTURA visible cuando está cerrado (solo título)
     — Seguro: fija en px.
     — Si quieres modo dinámico: usa
       calc(var(--title-size) * var(--title-lh) + var(--pad) * 2) */
  --peek: 82px; /* <— ajusta a gusto */
}

*{ box-sizing:border-box }

.card{
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: var(--shadow);

  /* imagen de fondo: configúrala en Elementor:
     background-size: cover; background-position: center; */
  width: min(92vw, 600px);
  height: 420px;

  will-change: transform;
  transition: box-shadow .25s ease;
}

@media (min-width:1024px){
  .card{ width: 550px; height: 417px; }
}

.card:hover{ box-shadow: var(--shadow-hover); }

/* El enlace cubre toda la tarjeta */
.card__link{
  position: absolute; inset: 0;
  display: block; text-decoration: none;
  /* Pulido táctil (no afecta desktop) */
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

/* Panel deslizante */
.card__content{
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: var(--pad);
  display: grid; gap: 12px;
  color: var(--fg);

  /* Legibilidad sobre imagen */
  background: var(--overlay);
  backdrop-filter: saturate(120%) blur(3px);
  -webkit-backdrop-filter: saturate(120%) blur(3px);

  /* ESTADO CERRADO: solo franja del título visible */
  transform: translateY(calc(100% - var(--peek))) translateZ(0);
  transition: transform var(--t) ease;
  will-change: transform;
}

/* ====== TRIGGERS DE APERTURA ====== */
/* hover en la tarjeta */
.card:hover > .card__link > .card__content{
  transform: translateY(0) translateZ(0);
}
/* hover en el <a> (por si algún wrapper intercepta el hover del padre) */
.card > .card__link:hover > .card__content{
  transform: translateY(0) translateZ(0);
}
/* foco por teclado (accesibilidad) */
.card:focus-within > .card__link > .card__content{
  transform: translateY(0) translateZ(0);
}

/* Tipos */
.card__title{
  margin: 0;
  font-family: var(--ff);
  font-weight: 900;
  font-size: var(--title-size);
  line-height: var(--title-lh);
  letter-spacing: .2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  text-shadow: 0 1px 2px rgba(0,0,0,.36);
}

.card__text{
  margin: 0;
  font-family: var(--ff);
  font-weight: 400;
  font-size: var(--text-size);
  line-height: 1.45;
  opacity: .96;
  max-width: 48ch;
  text-shadow: 0 1px 2px rgba(0,0,0,.25);
}

.card__button{
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: .6ch;

  padding: 14px 20px;                /* un poco más “botón” */
  border-radius: 12px;

  background: linear-gradient(90deg, var(--btn-grad-start), var(--btn-grad-end));
  color: var(--btn-text);

  font-family: var(--ff);
  font-weight: 900;
  font-size: var(--btn-size);        /* 16px según tu config */
  line-height: 1;

  box-shadow: 0 8px 18px rgba(0,0,0,.18);
  text-shadow: 0 1px 1px rgba(0,0,0,.15);
  user-select: none;
  border: 0;
  transform: translateZ(0);          /* suaviza en GPU */
}

/* Flecha al final (opcional) */
.card__button::after{
  content: "›";                      /* o "➜" */
  font-weight: 900;
  opacity: .95;
}

/* Hover/active (escritiorio) */
.card:hover .card__button{
  filter: brightness(1.05);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
}

/* Estado "presionado" sutil */
.card:active .card__button{
  transform: translateY(1px);
  filter: brightness(0.98);
}

/* Si quieres que el botón sea ancho completo en móviles */
@media (max-width: 480px){
  .card__button{ width: 100%; justify-content: center; }
}

/* Focus visible */
.card__link:focus-visible{
  outline: 3px solid rgba(255,255,255,.9);
  outline-offset: -3px;   /* dentro de los bordes redondeados */
  border-radius: var(--radius);
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .card__content{ transition: none !important; transform: none !important; }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-2b24f49 *//* Padre */
.card-wrapper{
  position: relative;
  overflow: hidden;
  cursor: pointer;                     /* ayuda a iOS a tratarlo como interactivo */
  touch-action: manipulation;          /* reduce la latencia del tap */
  -webkit-tap-highlight-color: transparent; /* quita el flash azul en iOS */
  -webkit-user-select: none;           /* evita selección accidental */
  -webkit-touch-callout: none;         /* evita menú de toque mantenido */
}

/* Hijo que sube */
.card-content{
  transition: transform .5s ease, height .5s ease, margin-bottom .5s ease, opacity .5s ease;
  will-change: transform, height;
}

/* Desktop (igual que tenías) */
@media (min-width:1024px) and (hover:hover){
  .card-content{ height:55%; margin-bottom:-150px; transform:none; }
  .card-wrapper:hover .card-content{ height:70%; margin-bottom:0; }
  .card-wrapper:hover .card-content .e-con-inner{ justify-content:end; }
}

/* Móvil / tablet (sin hover) */
@media (max-width:1023.98px), (hover:none){
  /* Estado base: “abajo” con translate, no con margin, para no romper layout */
  .card-content{
    height: auto;
    margin-bottom: 0;
    transform: translateY(150px);   /* ajusta la distancia */
  }

  /* Sube mientras se toca o hay foco dentro */
  .card-wrapper:active .card-content,
  .card-wrapper:focus-within .card-content{
    transform: translateY(0);
  }
}

/* Accesibilidad */
@media (prefers-reduced-motion: reduce){
  .card-content{ transition:none !important; transform:none !important; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-0061564 *//* =========================
   Tarjeta con panel deslizante
   (fondo en el contenedor .card)
   ========================= */

/* Carga de fuente (opcional)
@font-face{
  font-family:"Inter-Sotedev";
  src:url("/ruta/inter-sotedev.woff2") format("woff2");
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}
*/

:root{
  /* Diseño */
  --pad: 18px;
  --t: .5s;
  --radius: 18px;
  --shadow: 0 12px 28px rgba(0,0,0,.18);
  --shadow-hover: 0 16px 36px rgba(0,0,0,.22);

  /* Tipografías (tus tamaños) */
  --ff: "Inter-Sotedev", Inter, system-ui, Arial, sans-serif;
  --title-size: 42px;  /* Título */
  --title-lh: 1.25;
  --text-size: 18px;   /* Texto */
  --btn-size: 16px;    /* Botón */
  --btn-grad-start: #1a9cff;   /* azul */
  --btn-grad-end:   #12e1c7;   /* turquesa */
  --btn-text:       #ffffff;   /* blanco */

  /* Colores */
  --fg: #fff;
  --cta-bg: #fff;
  --cta-fg: #111;

  /* Gradiente (oscuro pero no negro) */
  --overlay: linear-gradient(
    180deg,
    rgba(14,18,26,.30) 0%,
    rgba(14,18,26,.55) 38%,
    rgba(14,18,26,.78) 72%,
    rgba(14,18,26,.86) 100%
  );

  /* ALTURA visible cuando está cerrado (solo título)
     — Seguro: fija en px.
     — Si quieres modo dinámico: usa
       calc(var(--title-size) * var(--title-lh) + var(--pad) * 2) */
  --peek: 82px; /* <— ajusta a gusto */
}

*{ box-sizing:border-box }

.card{
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: var(--shadow);

  /* imagen de fondo: configúrala en Elementor:
     background-size: cover; background-position: center; */
  width: min(92vw, 600px);
  height: 420px;

  will-change: transform;
  transition: box-shadow .25s ease;
}

@media (min-width:1024px){
  .card{ width: 550px; height: 417px; }
}

.card:hover{ box-shadow: var(--shadow-hover); }

/* El enlace cubre toda la tarjeta */
.card__link{
  position: absolute; inset: 0;
  display: block; text-decoration: none;
  /* Pulido táctil (no afecta desktop) */
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

/* Panel deslizante */
.card__content{
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: var(--pad);
  display: grid; gap: 12px;
  color: var(--fg);

  /* Legibilidad sobre imagen */
  background: var(--overlay);
  backdrop-filter: saturate(120%) blur(3px);
  -webkit-backdrop-filter: saturate(120%) blur(3px);

  /* ESTADO CERRADO: solo franja del título visible */
  transform: translateY(calc(100% - var(--peek))) translateZ(0);
  transition: transform var(--t) ease;
  will-change: transform;
}

/* ====== TRIGGERS DE APERTURA ====== */
/* hover en la tarjeta */
.card:hover > .card__link > .card__content{
  transform: translateY(0) translateZ(0);
}
/* hover en el <a> (por si algún wrapper intercepta el hover del padre) */
.card > .card__link:hover > .card__content{
  transform: translateY(0) translateZ(0);
}
/* foco por teclado (accesibilidad) */
.card:focus-within > .card__link > .card__content{
  transform: translateY(0) translateZ(0);
}

/* Tipos */
.card__title{
  margin: 0;
  font-family: var(--ff);
  font-weight: 900;
  font-size: var(--title-size);
  line-height: var(--title-lh);
  letter-spacing: .2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  text-shadow: 0 1px 2px rgba(0,0,0,.36);
}

.card__text{
  margin: 0;
  font-family: var(--ff);
  font-weight: 400;
  font-size: var(--text-size);
  line-height: 1.45;
  opacity: .96;
  max-width: 48ch;
  text-shadow: 0 1px 2px rgba(0,0,0,.25);
}

.card__button{
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: .6ch;

  padding: 14px 20px;                /* un poco más “botón” */
  border-radius: 12px;

  background: linear-gradient(90deg, var(--btn-grad-start), var(--btn-grad-end));
  color: var(--btn-text);

  font-family: var(--ff);
  font-weight: 900;
  font-size: var(--btn-size);        /* 16px según tu config */
  line-height: 1;

  box-shadow: 0 8px 18px rgba(0,0,0,.18);
  text-shadow: 0 1px 1px rgba(0,0,0,.15);
  user-select: none;
  border: 0;
  transform: translateZ(0);          /* suaviza en GPU */
}

/* Flecha al final (opcional) */
.card__button::after{
  content: "›";                      /* o "➜" */
  font-weight: 900;
  opacity: .95;
}

/* Hover/active (escritiorio) */
.card:hover .card__button{
  filter: brightness(1.05);
  box-shadow: 0 10px 22px rgba(0,0,0,.22);
}

/* Estado "presionado" sutil */
.card:active .card__button{
  transform: translateY(1px);
  filter: brightness(0.98);
}

/* Si quieres que el botón sea ancho completo en móviles */
@media (max-width: 480px){
  .card__button{ width: 100%; justify-content: center; }
}

/* Focus visible */
.card__link:focus-visible{
  outline: 3px solid rgba(255,255,255,.9);
  outline-offset: -3px;   /* dentro de los bordes redondeados */
  border-radius: var(--radius);
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .card__content{ transition: none !important; transform: none !important; }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-a0718b0 *//* Padre */
.card-wrapper{
  position: relative;
  overflow: hidden;
  cursor: pointer;                     /* ayuda a iOS a tratarlo como interactivo */
  touch-action: manipulation;          /* reduce la latencia del tap */
  -webkit-tap-highlight-color: transparent; /* quita el flash azul en iOS */
  -webkit-user-select: none;           /* evita selección accidental */
  -webkit-touch-callout: none;         /* evita menú de toque mantenido */
}

/* Hijo que sube */
.card-content{
  transition: transform .5s ease, height .5s ease, margin-bottom .5s ease, opacity .5s ease;
  will-change: transform, height;
}

/* Desktop (igual que tenías) */
@media (min-width:1024px) and (hover:hover){
  .card-content{ height:55%; margin-bottom:-150px; transform:none; }
  .card-wrapper:hover .card-content{ height:70%; margin-bottom:0; }
  .card-wrapper:hover .card-content .e-con-inner{ justify-content:end; }
}

/* Móvil / tablet (sin hover) */
@media (max-width:1023.98px), (hover:none){
  /* Estado base: “abajo” con translate, no con margin, para no romper layout */
  .card-content{
    height: auto;
    margin-bottom: 0;
    transform: translateY(150px);   /* ajusta la distancia */
  }

  /* Sube mientras se toca o hay foco dentro */
  .card-wrapper:active .card-content,
  .card-wrapper:focus-within .card-content{
    transform: translateY(0);
  }
}

/* Accesibilidad */
@media (prefers-reduced-motion: reduce){
  .card-content{ transition:none !important; transform:none !important; }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-bf73127 *//* Padre */
.card-wrapper{
  position: relative;
  overflow: hidden;
  cursor: pointer;                     /* ayuda a iOS a tratarlo como interactivo */
  touch-action: manipulation;          /* reduce la latencia del tap */
  -webkit-tap-highlight-color: transparent; /* quita el flash azul en iOS */
  -webkit-user-select: none;           /* evita selección accidental */
  -webkit-touch-callout: none;         /* evita menú de toque mantenido */
}

/* Hijo que sube */
.card-content{
  transition: transform .5s ease, height .5s ease, margin-bottom .5s ease, opacity .5s ease;
  will-change: transform, height;
}

/* Desktop (igual que tenías) */
@media (min-width:1024px) and (hover:hover){
  .card-content{ height:55%; margin-bottom:-150px; transform:none; }
  .card-wrapper:hover .card-content{ height:70%; margin-bottom:0; }
  .card-wrapper:hover .card-content .e-con-inner{ justify-content:end; }
}

/* Móvil / tablet (sin hover) */
@media (max-width:1023.98px), (hover:none){
  /* Estado base: “abajo” con translate, no con margin, para no romper layout */
  .card-content{
    height: auto;
    margin-bottom: 0;
    transform: translateY(150px);   /* ajusta la distancia */
  }

  /* Sube mientras se toca o hay foco dentro */
  .card-wrapper:active .card-content,
  .card-wrapper:focus-within .card-content{
    transform: translateY(0);
  }
}

/* Accesibilidad */
@media (prefers-reduced-motion: reduce){
  .card-content{ transition:none !important; transform:none !important; }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-be948c1 *//* Padre */
.card-wrapper{
  position: relative;
  overflow: hidden;
  cursor: pointer;                     /* ayuda a iOS a tratarlo como interactivo */
  touch-action: manipulation;          /* reduce la latencia del tap */
  -webkit-tap-highlight-color: transparent; /* quita el flash azul en iOS */
  -webkit-user-select: none;           /* evita selección accidental */
  -webkit-touch-callout: none;         /* evita menú de toque mantenido */
}

/* Hijo que sube */
.card-content{
  transition: transform .5s ease, height .5s ease, margin-bottom .5s ease, opacity .5s ease;
  will-change: transform, height;
}

/* Desktop (igual que tenías) */
@media (min-width:1024px) and (hover:hover){
  .card-content{ height:55%; margin-bottom:-150px; transform:none; }
  .card-wrapper:hover .card-content{ height:70%; margin-bottom:0; }
  .card-wrapper:hover .card-content .e-con-inner{ justify-content:end; }
}

/* Móvil / tablet (sin hover) */
@media (max-width:1023.98px), (hover:none){
  /* Estado base: “abajo” con translate, no con margin, para no romper layout */
  .card-content{
    height: auto;
    margin-bottom: 0;
    transform: translateY(150px);   /* ajusta la distancia */
  }

  /* Sube mientras se toca o hay foco dentro */
  .card-wrapper:active .card-content,
  .card-wrapper:focus-within .card-content{
    transform: translateY(0);
  }
}

/* Accesibilidad */
@media (prefers-reduced-motion: reduce){
  .card-content{ transition:none !important; transform:none !important; }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-01d590b *//* Padre */
.card-wrapper{
  position: relative;
  overflow: hidden;
  cursor: pointer;                     /* ayuda a iOS a tratarlo como interactivo */
  touch-action: manipulation;          /* reduce la latencia del tap */
  -webkit-tap-highlight-color: transparent; /* quita el flash azul en iOS */
  -webkit-user-select: none;           /* evita selección accidental */
  -webkit-touch-callout: none;         /* evita menú de toque mantenido */
}

/* Hijo que sube */
.card-content{
  transition: transform .5s ease, height .5s ease, margin-bottom .5s ease, opacity .5s ease;
  will-change: transform, height;
}

/* Desktop (igual que tenías) */
@media (min-width:1024px) and (hover:hover){
  .card-content{ height:55%; margin-bottom:-150px; transform:none; }
  .card-wrapper:hover .card-content{ height:70%; margin-bottom:0; }
  .card-wrapper:hover .card-content .e-con-inner{ justify-content:end; }
}

/* Móvil / tablet (sin hover) */
@media (max-width:1023.98px), (hover:none){
  /* Estado base: “abajo” con translate, no con margin, para no romper layout */
  .card-content{
    height: auto;
    margin-bottom: 0;
    transform: translateY(150px);   /* ajusta la distancia */
  }

  /* Sube mientras se toca o hay foco dentro */
  .card-wrapper:active .card-content,
  .card-wrapper:focus-within .card-content{
    transform: translateY(0);
  }
}

/* Accesibilidad */
@media (prefers-reduced-motion: reduce){
  .card-content{ transition:none !important; transform:none !important; }
}/* End custom CSS */
/* Start Custom Fonts CSS */@font-face {
	font-family: 'Inter-Sotedev';
	font-style: normal;
	font-weight: 900;
	font-display: auto;
	src: url('http://portafolio.sotelodevweb.com/wp-content/uploads/2025/10/InterTight-Bold.woff') format('woff');
}
@font-face {
	font-family: 'Inter-Sotedev';
	font-style: normal;
	font-weight: 600;
	font-display: auto;
	src: url('http://portafolio.sotelodevweb.com/wp-content/uploads/2025/10/InterTight-Medium.woff') format('woff');
}
@font-face {
	font-family: 'Inter-Sotedev';
	font-style: normal;
	font-weight: 400;
	font-display: auto;
	src: url('http://portafolio.sotelodevweb.com/wp-content/uploads/2025/10/InterTight-Light.woff') format('woff');
}
/* End Custom Fonts CSS */