@charset "UTF-8";
/*------------General------------*/
/*------------General------------*/
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  outline: 0;
  box-sizing: border-box;
  text-decoration: none;
  transition: all 1s;
  scroll-behavior: smooth;
}

* {
  scrollbar-color: #040b15 #2b2e40;
  scrollbar-width: thin;
}

*::-webkit-scrollbar {
  width: 0.4rem;
  border-radius: 0.8rem;
}

*::-webkit-scrollbar-track {
  background: #040b15;
  width: 0.4rem;
  border-radius: 0.8rem;
}

*::-webkit-scrollbar-thumb {
  background-color: #040b15;
  border-radius: 0.8rem;
  width: 0.4rem;
}

@font-face {
  font-family: LatoLight;
  src: url("../fonts/Lato-Light.ttf");
}
@font-face {
  font-family: RobotoRegular;
  src: url("../fonts/Roboto-Regular.ttf");
}
@font-face {
  font-family: RubikLight;
  src: url("../fonts/Rubik-Light.ttf");
}
@font-face {
  font-family: RubikRegular;
  src: url("../fonts/Rubik-Regular.ttf");
}
html {
  box-sizing: border-box;
  font-size: 62.5%;
  transition: all 1s;
  background-color: #f5f8fd;
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  transition: all 1s;
  background-color: #f5f8fd;
  overflow-x: hidden;
  position: relative;
  padding-left: 30rem;
  scroll-behavior: smooth;
  border: 0px solid red;
}

/*.container {
    padding: 2rem;
    width: 95%;
    max-width: 1100px;
    border: 1rem solid red;
}*/
.cont-text {
  flex-direction: column;
  text-align: left;
  font-family: LatoLight;
  width: 100%;
}

.padding {
  padding: 5rem 5rem 0rem 5rem;
}

.title {
  font-family: RubikRegular;
  font-size: 6rem;
  color: #173b6c;
}

.line {
  width: 30rem;
  height: 0.3rem;
  background-color: #129ddd;
  border: none;
  display: block;
  margin-bottom: 2rem;
}

.ad {
  display: block;
  font-family: LatoLight;
  font-size: 2rem;
  margin-bottom: 0.5rem;
  font-weight: 100;
  color: rgb(116, 114, 114);
}

.parrafo {
  font-family: RubikLight;
  font-size: 3rem;
  color: #2b2e40;
  text-align: left;
  color: #2b4c79;
  text-align: justify;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);
}

.div-sec {
  width: 60%;
  border-top: 2px solid #cfd0d1;
  margin: 0rem auto;
  display: block;
}

/*==============Loader==============
.loaderO{
    position: absolute;
    z-index: 4000;
    top: 0rem; left: 0rem; bottom: 0rem; right: 0rem;
    width: 100vw; height: 100vh;
    //background-color: $uno;
    background: #BB0039; 
    background: -webkit-linear-gradient(to right, #004E96, #BB0039);  
    background: linear-gradient(to right, #004E96, #BB0039); 
    display: flex;
    justify-content: center;
    align-items: center; 
    border: 0rem solid red;

    .cont-loader{
        padding: 1rem;
        border: 0rem solid red;
        display: block;
        width: 16rem;
        height: 16rem;
        margin: 0rem auto;
        //top: 50%;
        //transform: translateY(-50%);
        position: relative;

        .circle1{
            border: 10px solid rgba(255, 255, 255, 0.3);
            width: 100%;
            height: 100%;
            border-radius: 50%;
            border-left-color: #F4B800;
            //border-right-color: $dos;
            animation: giro1 1s ease infinite;           
        }   

        .circle2{
            border: 10px solid rgba(255, 255, 255, 0.3);
            width: 100%;
            height: 100%;
            border-radius: 50%;
            //border-left-color: $dos;
            border-right-color: #F4B800;
            animation: giro2 1s ease infinite; 

        }   

        @keyframes giro1 {
            0%{
                transform: rotate(0deg);                
            }
            100%{
                transform: rotate(360deg);
            }            
        }

        @keyframes giro2 {
            0%{
                transform: rotate(0deg);                
            }
            100%{
                transform: rotate(360deg);
            }            
        }

        img{
            position: absolute;
            width: 80%; height: 80%;
            top: 12%;
            transform: translateY(-12%);
            left: 48%;
            transform: translateX(-48%);
        }
    }
}

.loaderT{
    position: absolute;
    z-index: 4000;
    top: 0rem; left: 0rem; bottom: 0rem; right: 0rem;
    width: 100vw; height: 100vh;
    //background-color: $uno;
    background: #2D3DF9; 
    background: -webkit-linear-gradient(to right, #2D3DF9, #001F60);  
    background: linear-gradient(to right, #2D3DF9, #001F60); 
    display: none;
    justify-content: center;
    align-items: center; 
    border: 0rem solid red;

    .cont-loader{
        padding: 1rem;
        border: 0rem solid red;
        display: block;
        width: 16rem;
        height: 16rem;
        margin: 0rem auto;
        //top: 50%;
        //transform: translateY(-50%);
        position: relative;

        .circle1{
            border: 10px solid rgba(255, 255, 255, 0.3);
            width: 100%;
            height: 100%;
            border-radius: 50%;
            border-left-color: #DE1D3E;
            //border-right-color: $dos;
            animation: giro1 1s ease infinite;           
        }   

        .circle2{
            border: 10px solid rgba(255, 255, 255, 0.3);
            width: 100%;
            height: 100%;
            border-radius: 50%;
            //border-left-color: $dos;
            border-right-color: #DE1D3E;
            animation: giro2 1s ease infinite; 

        }   

        @keyframes giro1 {
            0%{
                transform: rotate(0deg);                
            }
            100%{
                transform: rotate(360deg);
            }            
        }

        @keyframes giro2 {
            0%{
                transform: rotate(0deg);                
            }
            100%{
                transform: rotate(360deg);
            }            
        }

        img{
            position: absolute;
            width: 40%; height: 40%;
            top: 30%;
            transform: translateY(-30%);
            left: 50%;
            transform: translateX(-50%);
        }
    }
}
==============Loader==============*/
/*==============Loader==============*/
.loader {
  z-index: 6000;
  position: fixed;
  top: 0;
  left: 0;
  width: 100dvw;
  height: 100vh;
  background-color: #040b15;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0rem;
}
.loader.loader-hidden {
  opacity: 0;
  visibility: hidden;
  display: none;
}
.loader .cont-loader {
  padding: 1rem;
  border: 0px solid red;
  display: block;
  width: 16rem;
  height: 16rem;
  margin: 0rem auto;
  position: fixed;
  top: 35%;
  transform: translateY(-35%);
  left: 50%;
  transform: translateX(-50%);
}
.loader .cont-loader .circle1 {
  border: 10px solid rgba(255, 255, 255, 0.3);
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border-left-color: #fecb00;
  animation: giro1 1s ease infinite;
}
.loader .cont-loader .circle2 {
  border: 10px solid rgba(255, 255, 255, 0.3);
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border-right-color: #fecb00;
  animation: giro2 1s ease infinite;
}
@keyframes giro1 {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes giro2 {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.loader .cont-loader img {
  position: absolute;
  width: 35%;
  height: 35%;
  top: 30%;
  transform: translateY(-30%);
  left: 50%;
  transform: translateX(-50%);
}

/*==============Loader==============*/
/*------------General------------*/
/*------------General------------*/
/*------------menu-icon------------*/
.menu-icon {
  display: none;
  position: fixed;
  width: 4.2rem;
  height: 4.2rem;
  top: 3rem;
  right: 2rem;
  background-color: #fecb00;
  padding: 1.4rem;
  border-radius: 50%;
  z-index: 4000;
  cursor: pointer;
  border: 1px solid #ffffff;
}
.menu-icon:hover {
  background-color: #dfb300;
}
.menu-icon .img-menu {
  width: 100%;
  height: 100%;
}

/*------------menu-icon------------*/
/*------------nav------------*/
.navbar {
  position: fixed;
  top: 2.2rem;
  left: 2.6rem;
  z-index: 2000;
  background-color: #040b15;
  width: 26rem;
  height: calc(100vh - 4rem);
  border-radius: 2rem;
  padding: 3rem 3rem 1rem 3rem;
  overflow-y: auto;
  display: flex;
  align-items: center;
  flex-direction: column;
  border-right: 0px solid #ffffff;
  box-shadow: rgba(0, 0, 0, 0.6) 0px 3px 8px;
  overflow: hidden;
}
.navbar .foto {
  width: 18rem;
  height: 18rem;
  margin: 0rem auto;
  padding: 0.6rem;
  border-radius: 50%;
  background-color: #2b2e40;
}
.navbar .foto img {
  width: 100%;
  border-radius: 50%;
}
.navbar .name {
  text-align: center;
  margin: 10% auto 5% auto;
  font-family: RubikRegular;
  font-weight: bold;
  font-size: 2.5rem;
}
.navbar .name span {
  color: #fecb00;
}
.navbar .icons {
  border: 0px solid red;
  display: flex;
  justify-content: space-evenly;
  margin: 5% auto 20% auto;
}
.navbar .icons .icon {
  display: block;
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  padding: 1rem;
  margin: 0.2rem;
  background-color: #2b2e40;
  cursor: pointer;
  border: 0px solid red;
}
.navbar .icons .icon:hover {
  background-color: #129ddd;
}
.navbar .icons .icon img {
  width: 100%;
  border: 0px solid red;
}
.navbar .icons .icon .f {
  display: block;
  width: 64%;
  height: 100%;
  margin: 0rem auto;
}
.navbar ul {
  display: inline-block;
  flex-direction: column;
  list-style: none;
  height: 100%;
}
.navbar ul li {
  color: #ffffff;
  border: 0px solid #ffffff;
  display: flex;
  align-items: center;
  color: #ffffff;
  cursor: pointer;
  padding: 0rem;
  margin: 0rem;
}
.navbar ul li .active {
  color: #129ddd;
}
.navbar ul li a {
  color: #ffffff;
  text-decoration: none;
  display: flex;
  align-items: center;
  width: 100%;
  padding: 0rem;
  margin: 0rem;
}
.navbar ul li a img {
  width: 1.8rem;
  display: block;
  margin-right: 0.5rem;
}
.navbar ul li a span {
  font-family: RobotoRegular;
  font-size: 1.4rem;
  position: relative;
}
.navbar ul li a span:before {
  content: "";
  display: block;
  width: 0;
  height: 0.2rem;
  background-color: #129ddd;
  position: absolute;
  left: 0;
  bottom: 0;
  transition: all 1s;
}
.navbar ul li a span:hover:before {
  width: 100%;
}
.navbar ul .link-services {
  color: #ffffff;
  border: 0px solid #ffffff;
  display: flex;
  align-items: center;
  cursor: pointer;
  text-decoration: none;
  padding: 0rem;
  margin: 0rem;
}
.navbar ul .link-services img {
  width: 1.8rem;
  display: block;
  margin-right: 0.5rem;
}
.navbar ul .link-services span {
  font-family: RobotoRegular;
  font-size: 1.4rem;
  position: relative;
}
.navbar ul .link-services span:before {
  content: "";
  display: block;
  width: 0;
  height: 0.2rem;
  background-color: #129ddd;
  position: absolute;
  left: 0;
  bottom: 0;
  transition: all 1s;
}
.navbar ul .link-services span:hover:before {
  width: 100%;
}
.navbar .credits {
  left: 0;
  bottom: 0;
  width: 100%;
  text-align: center;
  border: 0px solid red;
  color: #ffffff;
}
.navbar .credits p {
  font-family: LatoLight;
  font-size: 1rem;
  padding: 1.2rem;
}
.navbar .credits span {
  color: #fecb00;
  font-weight: bold;
}

/*------------nav------------*/
/*------------cont (section)------------*/
.cont-main {
  width: 100%;
  height: 100%;
  border: 0px solid red;
  position: relative;
  /*------------header------------*/
  /*------------about------------*/
  /*------------about------------*/
  /*------------skills------------*/
  /*------------skills------------*/
  /*------------portafolio------------*/
  /*==============Modal Zoom==============-*/
  /* Estilo Base del Modal  */
  /*==============Modal Zoom==============*/
  /*------------portafolio------------*/
  /*------------contact------------*/
  /*------------contact------------*/
  /*------------login------------*/
  /*------------login------------*/
  /*------------login------------*/
  /*------------login------------*/
}
.cont-main .my {
  width: 100%;
  height: 100vh;
  display: flex;
  justify-content: center; /* Centra horizontalmente */
  align-items: center;
  margin-bottom: 6rem;
}
.cont-main .my .background-img {
  width: 95%;
  height: 94%;
  border-radius: 2rem;
  position: relative;
  box-shadow: rgba(0, 0, 0, 0.5) 0px 3px 8px;
}
.cont-main .my .background-img .background-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 2rem;
  z-index: 1; /* Detrás del contenido */
  object-fit: cover; /* Mantiene el ratio y asegura que cubre el área sin distorsionar */
}
.cont-main .my .background-img .opacity {
  width: 100%;
  height: 100%;
  border-radius: 2rem;
  background-color: rgba(4, 11, 21, 0.75);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 500; /* Entre el video (1) y el texto (3) */
}
.cont-main .my .background-img .opacity .cont-text {
  width: 100%;
  height: 100%;
  display: flex; /* 1. Habilitar Flexbox */
  flex-direction: column; /* 2. Establecer la dirección vertical (los elementos se apilan) */
  justify-content: center; /* 3. Centrado Vertical (ahora es el eje principal) */
  align-items: center; /* Opcional: Centrado Horizontal (eje secundario) */
}
.cont-main .my .background-img .opacity .cont-text img {
  width: 15rem;
  margin: 2rem;
}
.cont-main .my .background-img .opacity .cont-text .title-ash {
  font-size: 4rem;
  font-weight: bold;
  font-family: RubikRegular;
  color: #ffffff;
  text-shadow: 1px 1px 2px black;
  margin-bottom: 1rem;
}
.cont-main .my .background-img .opacity .cont-text .title-msj {
  font-size: 2.5rem;
  font-weight: bold;
  font-family: RubikRegular;
  color: #ffffff;
  text-shadow: 1px 1px 2px black;
}
.cont-main .my .background-img .opacity .cont-text span {
  display: block;
  font-size: 1.6rem;
  color: #fecb00;
  font-weight: bold;
  text-shadow: 1px 1px 2px black;
}
.cont-main .my .background-img .opacity .cont-text p {
  font-size: 2rem;
  margin: 0rem;
  font-weight: 100;
  color: #ffffff;
  font-weight: bold;
  line-height: 3rem;
  text-shadow: 1px 1px 2px black;
}
.cont-main .my .background-img .opacity .cont-text hr {
  margin: 2rem auto;
  width: 18rem;
  border: none;
  height: 0.3rem;
  background-color: #129ddd;
}
.cont-main .my .background-img .opacity .cont-text .btn-cta {
  /* Apariencia base */
  display: inline-block;
  margin-top: 1.5rem;
  border: 1px groove #808080;
  padding: 0.8rem 2.2rem;
  border-radius: 0.7rem;
  cursor: pointer;
  text-decoration: none;
  /* Tipografía */
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.1rem;
  line-height: 2;
  text-transform: uppercase;
  text-decoration: none;
  font-family: RubikRegular;
  /* Colores */
  color: #1a1a1a; /* Texto oscuro */
  background-color: #ffcc00; /* Fondo amarillo principal */
  /* Transición suave */
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  /* El truco del brillo sutil */
  box-shadow: 0 4px 15px rgba(255, 215, 0, 0.4);
}
.cont-main .my .background-img .opacity .cont-text .btn-cta:hover {
  /* Ligeramente más claro al pasar el ratón (usando lighten de SCSS) */
  background-color: #ffd700;
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(255, 204, 0, 0.5), 0 6px 6px rgba(0, 0, 0, 0.1);
}
.cont-main .my .background-img .opacity .cont-text .btn-cta:active {
  background-color: #ffd700;
  transform: translateY(0);
  box-shadow: none;
}
.cont-main .my .background-img .opacity .cont-text .btn-cta:focus {
  outline: 3px solid rgba(255, 215, 0, 0.7);
  outline-offset: 4px;
}
.cont-main .my .background-img .opacity .cont-text .divIcons {
  margin: 1rem auto;
  display: flex;
  width: 20rem;
  justify-content: space-between;
  align-items: center;
  padding: 1rem;
  flex-wrap: wrap;
  border: 0px solid #ffffff;
}
.cont-main .my .background-img .opacity .cont-text .divIcons .iconmy {
  display: block;
  position: relative;
  text-decoration: none;
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  padding: 1rem;
  margin: 0rem;
  background-color: transparent;
  cursor: pointer;
  border: 2px solid #3b3b3b; /* Eliminado el borde innecesario */
}
.cont-main .my .background-img .opacity .cont-text .divIcons .iconmy:hover {
  background-color: #129ddd;
}
.cont-main .my .background-img .opacity .cont-text .divIcons .iconmy img {
  display: flex;
  width: 100%;
  margin: 0 auto;
  border: none; /* Eliminado el borde innecesario */
}
.cont-main .my .background-img .opacity .cont-text .divIcons .iconmy .fa {
  display: flex;
  width: 64%;
  height: 100%;
  margin: 0 auto;
}
.cont-main .about {
  width: 100%;
  height: auto;
  display: flex;
  background-color: #f5f8fd;
  position: relative;
}
.cont-main .about .cont-text .cont-about {
  width: 100%;
  height: auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  background-color: #f5f8fd;
}
.cont-main .about .cont-text .cont-about .foto {
  width: 34%;
  border: 0px solid red;
}
.cont-main .about .cont-text .cont-about .foto .contorno {
  padding: 0.8rem 1.1rem;
  border-radius: 50%;
  background-color: #2b2e40;
  border: 0px solid yellow;
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
  transition: all 1s;
}
.cont-main .about .cont-text .cont-about .foto .contorno:hover {
  box-shadow: rgba(0, 0, 0, 0.35) 0px 20px 30px;
  transition: all 1s;
}
.cont-main .about .cont-text .cont-about .foto .contorno img {
  width: 100%;
  height: 100%;
  border-radius: 50%;
}
.cont-main .about .cont-text .cont-about .text {
  width: 65%;
  display: flex;
  align-items: center;
  padding: 0rem 0rem 0rem 3rem;
}
.cont-main .about .cont-text .info-about {
  width: 100%;
  margin-top: 4rem;
  border: 0px solid blueviolet;
}
.cont-main .about .cont-text .info-about h1 {
  font-size: 2rem;
  color: #149ddd;
}
.cont-main .about .cont-text .info-about .items {
  width: 100%;
  margin-top: 2rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.cont-main .about .cont-text .info-about .items .item {
  width: 46%;
  display: flex;
  height: auto;
  justify-content: flex-start;
  margin-bottom: 4rem;
  padding: 2rem;
  border-radius: 0.7rem;
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
  transition: all 1s;
}
.cont-main .about .cont-text .info-about .items .item:hover {
  box-shadow: rgba(0, 0, 0, 0.35) 0px 10px 20px;
  transition: all 1s;
}
.cont-main .about .cont-text .info-about .items .item .img {
  width: 7rem;
  height: 6rem;
  padding: 1rem;
  border-radius: 50%;
  display: block;
  background-color: #dff3fc;
}
.cont-main .about .cont-text .info-about .items .item .img img {
  width: 100%;
  height: 100%;
}
.cont-main .about .cont-text .info-about .items .item .text {
  font-family: RubikRegular;
  margin-left: 1rem;
  color: #2b4c79;
}
.cont-main .about .cont-text .info-about .items .item .text span {
  font-size: 1.8rem;
  color: #000000;
}
.cont-main .about .cont-text .info-about .items .item .text p {
  font-size: 1.6rem;
  margin-bottom: 1rem;
  position: relative;
  padding: 0rem 1.5rem;
}
.cont-main .about .cont-text .info-about .items .item .text p::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: #1e88e5;
  font-size: 1.1rem;
  font-weight: bold;
  line-height: 1.5;
}
.cont-main .about .cont-text .info-about .items .item .text p:hover {
  margin-left: 0.5rem;
  color: #1e88e5;
}
.cont-main .about .cont-text .info-about .items .item .text p a {
  text-decoration: none;
  font-family: RubikRegular;
  color: #173b6c;
  display: flex;
  align-items: center;
  padding: 0.5rem;
  border-bottom: 1px solid #129ddd;
  transition: all 1s;
}
.cont-main .about .cont-text .info-about .items .item .text p a:hover {
  margin-left: 1rem;
  transition: all 1s;
}
.cont-main .about .cont-text .info-about .items .item .text p a img {
  width: 2rem;
  margin-right: 1rem;
}
.cont-main .skills {
  width: 100%;
  height: auto;
  display: flex;
  background-color: #f5f8fd;
  position: relative;
}
.cont-main .skills .cont-text .cont-pri {
  width: 100%;
  height: auto;
}
.cont-main .skills .cont-text .cont-pri .cont-skills {
  width: 100%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill {
  width: 45%;
  height: auto;
  margin-bottom: 5rem;
  padding: 2rem 2rem 6rem 4rem;
  display: inline-flex;
  flex-direction: column; /* ordena en columna */
  justify-content: flex-start; /* los coloca arriba */
  align-items: flex-start; /* centra horizontalmente */
  border-radius: 1rem;
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
  position: relative;
  transition: all 1s;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill:hover {
  box-shadow: rgba(0, 0, 0, 0.35) 0px 10px 20px;
  transition: all 1s;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill .img {
  width: 6rem;
  height: 6rem;
  border: 1px solid #f5f8fd;
  padding: 1rem;
  border-radius: 50%;
  display: block;
  background-color: #dff3fc;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill .img img {
  display: block;
  width: 100%;
  height: 100%;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill .text {
  width: auto;
  font-family: RubikRegular;
  color: #2b4c79;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill .text span {
  font-size: 2rem;
  color: #000000;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill .text p {
  font-size: 1.6rem;
  border: 0px solid red;
  margin-bottom: 1rem;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  text-align: left;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill .text p span {
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  background-color: #173b6c;
  display: inline-block;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill .text .list-skills {
  list-style: none;
  padding-left: 0;
  margin-bottom: 2rem;
  font-size: 1.6rem;
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill .text .list-skills li {
  margin-bottom: 0.6rem;
  padding-left: 1.4rem;
  position: relative;
  line-height: 1.5;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill .text .list-skills li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: #1e88e5;
  font-size: 1.1rem;
  font-weight: bold;
  line-height: 1.5;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill .text .list-skills li:hover {
  color: #1e88e5;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill .text .btn-general {
  display: inline-block;
  text-decoration: none;
  position: absolute;
  left: 2rem;
  bottom: 2rem;
  font-family: RubikRegular;
  color: #ffffff;
  font-size: 1.4rem;
  background-color: #129ddd;
  padding: 1rem 2rem;
  border-radius: 0.7rem;
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
  transition: all 1s;
}
.cont-main .skills .cont-text .cont-pri .cont-skills .skill .text .btn-general:hover {
  box-shadow: rgba(0, 0, 0, 0.35) 0px 30px 40px;
  transition: all 1s;
  background-color: #46c4ff;
  cursor: pointer;
}
.cont-main .portafolio {
  width: 100%;
  height: auto;
  display: flex;
  background-color: #f5f8fd;
  position: relative;
}
.cont-main .portafolio .cont-text .cont-portafolio {
  width: 100%;
  height: auto;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  align-items: center;
}
.cont-main .portafolio .cont-text .cont-portafolio .categorias {
  background-color: #ffffff;
  border: 1px solid #129ddd;
  display: inline-block;
  margin: 0rem auto;
  padding: 0rem 2rem;
  border-radius: 3rem;
}
.cont-main .portafolio .cont-text .cont-portafolio .categorias button {
  font-size: 2rem;
  color: #173b6c;
  font-family: RubikRegular;
  margin: 1rem;
  background: none;
  border: 0;
  border-bottom: 2px solid #ffffff;
  cursor: pointer;
}
.cont-main .portafolio .cont-text .cont-portafolio .categorias button.bb {
  border-bottom: 2px solid #129ddd;
  color: #129ddd;
}
.cont-main .portafolio .cont-text .cont-portafolio .items {
  width: 100%;
  border: 0px solid green;
  display: flex;
  justify-content: space-evenly;
  flex-wrap: wrap;
  align-items: center;
  padding: 2rem 0rem;
  transition: all 2s;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item {
  margin-bottom: 6rem;
  border: 0px solid red;
  cursor: pointer;
  overflow: hidden;
  position: relative;
  border-radius: 1rem;
  box-shadow: rgba(0, 0, 0, 0.25) 0px 11px 35px 2px;
  transition: all 3s;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item:hover {
  box-shadow: rgba(0, 0, 0, 0.56) 0px 22px 70px 4px;
  transition: all 1s;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item:hover .enlace {
  transition: all 1s;
  bottom: 50%;
  left: 50%;
  transform: translate(-50%, 50%);
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item:hover img {
  transform: scale(1.1);
  filter: brightness(50%);
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .item-contenido {
  border: 0px solid red;
  width: 100%;
  height: 100%;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .item-contenido img {
  width: 100%;
  height: 100%;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace {
  position: absolute;
  width: 70%;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 1rem;
  bottom: -20rem;
  z-index: 500;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: all 3s;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link1 {
  align-items: center;
  justify-content: space-between;
  border: 0px solid black;
  flex-direction: column;
  text-align: left;
  color: #173b6c;
  font-family: LatoLight;
  background-color: #ffffff;
  padding: 1rem 2rem;
  border-radius: 1rem;
  width: 60%;
  border: 0px solid red;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link1 .title-link-p {
  font-size: 1.8rem;
  margin-bottom: 0.2rem;
  color: #fecb00;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link1 .span-link-p {
  font-size: 1.4rem;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 0px solid red;
  transition: all 300ms;
  width: 10rem;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 .mas {
  cursor: pointer;
  display: block;
  width: 5rem;
  height: 4rem;
  background-color: #ffffff;
  padding: 0.5rem;
  border-radius: 50%;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 .mas:hover {
  background-color: #fecb00;
  transition: all 1s;
  transform: scale(1.05);
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 .mas .a {
  display: inline-block;
  width: 100%;
  height: 100%;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 .mas .a:hover {
  transition: all 1s;
  filter: brightness(0) invert(1);
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 .link_p {
  cursor: pointer;
  display: flex;
  width: 5rem;
  height: 4rem;
  background-color: #ffffff;
  padding: 0.5rem;
  border-radius: 50%;
  align-items: center;
  justify-content: center;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 .link_p:hover {
  background-color: #fecb00;
  transition: all 1s;
  transform: scale(1.05);
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 .link_p .c {
  display: inline-block;
  margin: 0rem auto;
  width: 100%;
  height: 55%;
}
.cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 .link_p .c:hover {
  transition: all 1s;
  filter: brightness(0) invert(1);
}
.cont-main #modal-zoom {
  position: fixed; /* Cubre toda la pantalla */
  z-index: 5000; /* Asegura que esté por encima de todo z-index: 6000*/
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgba(0, 0, 0, 0.9); /* Fondo semi-transparente y oscuro */
  /*  CLAVE: La clase que JavaScript usará para ocultar "none" /mostrar "flex" */
  display: none;
  align-items: center;
  justify-content: center;
}
.cont-main #modal-zoom.modal {
  display: flex;
}
.cont-main #modal-zoom #visor-pdf-contenedor {
  width: 90%;
  max-width: 1000px;
  height: 90vh;
  background-color: white;
  position: relative;
  display: block;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.4);
  border: none;
  margin: 0rem auto;
}
.cont-main #modal-zoom .cerrar-modal {
  position: absolute;
  top: 15px;
  right: 35px;
  z-index: 5001;
  color: #ffffff;
  font-size: 3rem;
  font-weight: bold;
  cursor: pointer;
  transition: all 1s;
  padding: 0.1rem 0.9rem;
  border-radius: 50%;
  border: 0px solid red;
  color: #fecb00;
  background-color: #ffffff;
}
.cont-main #modal-zoom .cerrar-modal:hover {
  color: #ffffff;
  background-color: #fecb00;
  transform: scale(1.05);
  transition: all 1s;
}
.cont-main .contact {
  width: 100%;
  display: flex;
  background-color: #f5f8fd;
  position: relative;
}
.cont-main .contact .cont-text .cont-contact {
  width: 100%;
  height: auto;
  margin-bottom: 5rem;
  border: 0px solid pink;
}
.cont-main .contact .cont-text .cont-contact .contact-info {
  width: 100%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.cont-main .contact .cont-text .cont-contact .contact-info .info {
  width: 38%;
  background: #ffffff;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 2rem;
  border-radius: 1rem;
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
  transition: all 1s;
}
.cont-main .contact .cont-text .cont-contact .contact-info .info:hover {
  box-shadow: rgba(0, 0, 0, 0.35) 0px 20px 30px;
  transition: all 1s;
}
.cont-main .contact .cont-text .cont-contact .contact-info .info h1 {
  font-family: LatoLight;
  font-size: 2rem;
  color: #2b4c79;
}
.cont-main .contact .cont-text .cont-contact .contact-info .info .data {
  width: 100%;
  border: 0px solid red;
}
.cont-main .contact .cont-text .cont-contact .contact-info .info .data .cont-info {
  display: flex;
  justify-content: flex-start;
}
.cont-main .contact .cont-text .cont-contact .contact-info .info .data .cont-info .img {
  width: 5rem;
  height: 5rem;
  padding: 1rem;
  border-radius: 50%;
  display: block;
  background-color: #dff3fc;
}
.cont-main .contact .cont-text .cont-contact .contact-info .info .data .cont-info .img img {
  width: 100%;
  height: 100%;
}
.cont-main .contact .cont-text .cont-contact .contact-info .info .data .cont-info .text {
  font-family: RubikRegular;
  margin-left: 1rem;
  color: #2b4c79;
}
.cont-main .contact .cont-text .cont-contact .contact-info .info .data .cont-info .text span {
  font-size: 1.6rem;
  color: #000000;
}
.cont-main .contact .cont-text .cont-contact .contact-info .info .data .cont-info .text p {
  font-size: 1.4rem;
}
.cont-main .contact .cont-text .cont-contact .contact-info .info .map {
  width: 100%;
  height: 25rem;
}
.cont-main .contact .cont-text .cont-contact .contact-info .info .map iframe {
  width: 100%;
  height: 100%;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form {
  width: 58%;
  border: 0px solid green;
  background: #ffffff;
  padding: 2rem;
  border-radius: 1rem;
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
  transition: all 1s;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form:hover {
  box-shadow: rgba(0, 0, 0, 0.35) 0px 20px 30px;
  transition: all 1s;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form h1 {
  font-family: LatoLight;
  font-size: 2rem;
  color: #2b4c79;
  margin-bottom: 2rem;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form form {
  width: 100%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form form .input_form {
  width: 48%;
  padding-bottom: 3rem;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form form .input_form label {
  font-family: RobotoRegular;
  display: block;
  font-size: 1.6rem;
  color: #2b4c79;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form form .input_form input {
  display: block;
  width: 100%;
  margin-top: 1rem;
  padding: 1rem;
  border-radius: 1rem;
  border: 1px solid #728aac;
  transition: all 1s;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form form .input_form input:hover {
  transition: all 1s;
  border: 1px solid #149ddd;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form form .textarea_form {
  flex-direction: column;
  width: 100%;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form form .textarea_form label {
  font-family: RobotoRegular;
  display: block;
  font-size: 1.6rem;
  color: #2b4c79;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form form .textarea_form textarea {
  display: block;
  width: 100%;
  margin-top: 1rem;
  border: 1px solid #728aac;
  transition: all 1s;
  border-radius: 1rem;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form form .textarea_form textarea:hover {
  transition: all 1s;
  border: 1px solid #149ddd;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form form .btn_form {
  display: flex;
  justify-content: center;
  margin-top: 2rem;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form form .btn_form .btn {
  border: 0rem;
  font-family: RobotoRegular;
  display: block;
  font-size: 1.4rem;
  background-color: #149ddd;
  color: #ffffff;
  padding: 1rem 2rem;
  border-radius: 0.5rem;
  transition: all 1s;
}
.cont-main .contact .cont-text .cont-contact .contact-info .form form .btn_form .btn:hover {
  transition: all 1s;
  background-color: #46c4ff;
  cursor: pointer;
}
.cont-main .login {
  transition: all 1s;
  background-color: #f5f8fd;
  width: 100%;
  height: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-bottom: 4rem;
}
.cont-main .login .login-container {
  margin: 0rem auto;
  display: flex;
  width: 60%;
  height: 45rem;
  border-radius: 3rem;
  box-shadow: rgba(0, 0, 0, 0.24) 0px 3px 8px;
  border: 0px solid red;
}
.cont-main .login .login-container .image-container {
  width: 50%;
  border-top-right-radius: 3rem;
  border-bottom-left-radius: 3rem;
}
.cont-main .login .login-container .image-container img {
  width: 100%;
  height: 100%;
  border-top-left-radius: 3rem;
  border-bottom-left-radius: 3rem;
}
.cont-main .login .login-container .form-container {
  padding: 1rem;
  width: 60%;
  background-color: #f1f7fe;
  border-top-right-radius: 3rem;
  border-bottom-right-radius: 3rem;
}
.cont-main .login .login-container .form-container form {
  padding: 1rem 1.5rem;
  width: 100%;
  height: 100%;
  font-family: Lato;
  display: flex;
  align-items: flex-start;
  flex-direction: column;
}
.cont-main .login .login-container .form-container form .logo {
  width: 16rem;
  height: 7rem;
}
.cont-main .login .login-container .form-container form .logo img {
  width: 100%;
  height: 100%;
}
.cont-main .login .login-container .form-container form .title {
  font-size: 1.4rem;
  color: #717171;
  margin: auto 0rem;
}
.cont-main .login .login-container .form-container form .input-container {
  width: 100%;
  display: block;
  padding: 0.8rem 0.6rem 0.8rem 1.4rem;
  border-radius: 1rem;
  background-color: #ffffff;
  margin: auto;
  position: relative;
}
.cont-main .login .login-container .form-container form .input-container label {
  color: #717171;
  font-size: 1.5rem;
  font-weight: bold;
}
.cont-main .login .login-container .form-container form .input-container input {
  color: #717171;
  width: 100%;
  font-size: 1.4rem;
  padding: 0.4rem 4rem 0.4rem 0.4rem;
  border: 0px solid transparent;
}
.cont-main .login .login-container .form-container form .input-container .user-icon {
  width: 2rem;
  height: 2.1rem;
  right: 2rem;
  bottom: 2rem;
  position: absolute;
}
.cont-main .login .login-container .form-container form .input-container .password-icon {
  width: 2.5rem;
  height: 2.1rem;
  right: 2rem;
  bottom: 2rem;
  position: absolute;
  cursor: pointer;
  transition: all 2s;
}
.cont-main .login .login-container .form-container form .input-container .password-icon:hover {
  transform: scale(1.1);
  transition: all 2s;
}
.cont-main .login .login-container .form-container form .btn {
  display: block;
  margin: auto;
  width: 100%;
  text-decoration: none;
  color: #ffffff;
  font-size: 1.5rem;
  background-color: #3e4684;
  padding: 0.8rem 2rem;
  border: none;
  border-radius: 1rem;
  cursor: pointer;
  transition: all 1s;
}
.cont-main .login .login-container .form-container form .btn:hover {
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
  transition: all 1s;
}
.cont-main .login .login-container .form-container form .redes-title {
  font-size: 1.2rem;
  color: #717171;
  margin: auto 0rem;
}
.cont-main .login .login-container .form-container form .redes-sociales {
  width: 100%;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.cont-main .login .login-container .form-container form .redes-sociales a {
  width: 3.8rem;
  height: 3.8rem;
  border-radius: 50%;
  padding: 1.2rem;
  margin-right: 1.2rem;
  transition: all 1s;
}
.cont-main .login .login-container .form-container form .redes-sociales a:hover {
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
  transition: all 1s;
}
.cont-main .login .login-container .form-container form .redes-sociales a:nth-child(1) {
  background-color: #1877f2;
  padding: 1.2rem 1.5rem;
}
.cont-main .login .login-container .form-container form .redes-sociales a:nth-child(2) {
  background-color: #f91368;
}
.cont-main .login .login-container .form-container form .redes-sociales a:nth-child(3) {
  background-color: #64b161;
}
.cont-main .login .login-container .form-container form .redes-sociales a img {
  width: 100%;
  height: 100%;
}
.cont-main .footer {
  width: 100%;
  height: auto;
  padding: 1rem 3rem;
}
.cont-main .footer .credits {
  left: 0;
  bottom: 0;
  width: 100%;
  text-align: center;
  border-top: 2px solid #cfd0d1;
  font-size: 1.4rem;
  padding-top: 1rem;
}
.cont-main .footer .credits p {
  font-family: LatoLight;
  padding-top: 0.4rem;
  color: #173b6c;
}
.cont-main .footer .credits span {
  color: #fecb00;
  font-weight: bold;
}

/*------------cont (section)------------*/
/*==============whatsapp==============*/
.whatsapp {
  border: 0px solid red;
}
.whatsapp .ventanaWhatsapp {
  position: fixed;
  right: 5rem;
  bottom: 10rem;
  z-index: 4000;
  padding: 0rem;
  border: 0px solid red;
  width: 28rem;
  border-radius: 2rem;
  box-shadow: rgba(0, 0, 0, 0.4) 0px 5px 15px;
  transform: translateX(150%);
  transition: all 2rem;
}
.whatsapp .ventanaWhatsapp.translateXWhatsapp {
  transform: translateX(0%);
}
.whatsapp .ventanaWhatsapp:hover {
  right: 3rem;
  transition: all 2rem;
}
.whatsapp .ventanaWhatsapp .vheader {
  width: 100%;
  padding: 1rem;
  text-align: left;
  border-radius: 1rem 1rem 0rem 0rem;
  color: #ffffff;
  background-color: #173b6c;
  font-family: RobotoRegular;
  font-size: 1.5rem;
}
.whatsapp .ventanaWhatsapp .vheader img {
  width: 1.5rem;
  height: 1.5rem;
  cursor: pointer;
  float: right;
}
.whatsapp .ventanaWhatsapp .vheader img:hover {
  filter: grayscale(100%);
}
.whatsapp .ventanaWhatsapp .vbody {
  width: 100%;
}
.whatsapp .ventanaWhatsapp .vbody .vmsj {
  padding: 1rem;
  background-color: #e5ddd5;
}
.whatsapp .ventanaWhatsapp .vbody .vmsj .msj {
  background-color: #ffffff;
  border-radius: 1rem;
  width: 100%;
  padding: 1rem;
}
.whatsapp .ventanaWhatsapp .vbody .vmsj .msj p {
  color: #173b6c;
  font-family: RobotoRegular;
  font-size: 1.5rem;
}
.whatsapp .ventanaWhatsapp .vbody .vform {
  padding: 1rem;
  background-color: #ffffff;
}
.whatsapp .ventanaWhatsapp .vbody .vform form {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: RobotoRegular;
}
.whatsapp .ventanaWhatsapp .vbody .vform form textarea {
  display: block;
  width: 85%;
  border: 1.8px solid #173b6c;
  border-radius: 1rem 1rem 0rem 1rem;
  color: #173b6c;
  font-family: RobotoRegular;
  padding: 1rem;
}
.whatsapp .ventanaWhatsapp .vbody .vform form button {
  width: 10%;
  height: 2.5rem;
  border: 0px solid transparent;
  background-color: transparent;
  cursor: pointer;
}
.whatsapp .ventanaWhatsapp .vbody .vform form button img {
  width: 100%;
  height: 100%;
}
.whatsapp .ventanaWhatsapp .vfooter {
  width: 100%;
  background-color: #173b6c;
  border-radius: 0rem 0rem 2rem 2rem;
  padding: 1rem;
}
.whatsapp .ventanaWhatsapp .vfooter p {
  text-align: center;
  color: #ffffff;
  font-size: 1.2rem;
  font-family: RobotoRegular;
}
.whatsapp .ventanaWhatsapp .vfooter p span {
  color: #fecb00;
}

.whatsappcontacto {
  width: 4.5rem;
  height: 4.5rem;
  position: fixed;
  right: 4rem;
  bottom: 4rem;
  z-index: 4000;
  cursor: pointer;
  overflow: visible;
}
.whatsappcontacto::before, .whatsappcontacto::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background-color: #25d366;
  opacity: 0;
  z-index: -1;
  animation: radar-pulse 2.5s infinite cubic-bezier(0.4, 0, 0.6, 1);
}
.whatsappcontacto::after {
  animation-delay: 0.8s;
}
.whatsappcontacto #whatsapp {
  width: 100%;
  height: 100%;
  transition: all 2s;
  transform: scale(1);
  border: 0px solid red;
  margin: 0;
  object-fit: contain;
}
.whatsappcontacto #whatsapp:hover {
  transform: scale(1.1);
  transition: all 2s;
}

@keyframes radar-pulse {
  0% {
    transform: scale(1);
    opacity: 0.6;
  }
  100% {
    transform: scale(2.2);
    opacity: 0;
  }
}
/*==============whatsapp ==============*/
/*------------@media screen------------*/
/*------------@media screen------------*/
/*------------@media screen------------*/
/*------------@media screen------------*/
/*------------@media screen------------*/
/*------------@media screen------------*/
/*------------@media screen------------*/
/*------------@media screen------------*/
/*------------@media screen------------*/
/*------------@media screen------------*/
/*------------3000px------------*/
@media screen and (max-width: 3000px) {
  /*------------nav------------*/
  .navbar ul li {
    margin: 12% 0rem;
    border: 0px solid red;
  }
  .navbar ul li a img {
    width: 3rem;
  }
  .navbar ul li a span {
    padding: 0.4rem 0.5rem;
    font-size: 1.6rem;
  }
  .navbar ul .link-services {
    margin: 12% 0rem;
  }
  .navbar ul .link-services img {
    width: 3rem;
  }
  .navbar ul .link-services span {
    font-size: 1.6rem;
  }
  /*------------nav------------*/
  .cont-main {
    /*------------portafolio------------*/
    /*------------portafolio------------*/
  }
  .cont-main .portafolio .cont-text .cont-portafolio .categorias button {
    font-size: 1.5rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item {
    width: 31.5%;
    height: 40rem;
  }
}
/*------------1920px------------*/
/*------------1600px------------*/
@media screen and (max-width: 1600px) {
  /*------------General------------*/
  .title {
    font-size: 5rem;
  }
  .line {
    width: 25rem;
    height: 0.3rem;
    margin-bottom: 2rem;
  }
  .ad {
    font-size: 1.5rem;
  }
  .parrafo {
    font-size: 3rem;
  }
  /*------------General------------*/
  /*------------nav------------*/
  .navbar .foto {
    width: 13rem;
    height: 13rem;
  }
  .navbar .name {
    margin: 10% auto 5% auto;
    font-size: 2rem;
  }
  .navbar .icons {
    margin: 5% auto 12% auto;
  }
  .navbar ul li {
    margin: 11% 0rem;
  }
  .navbar ul li img {
    width: 2.5rem;
  }
  .navbar ul li span {
    padding: 0.4rem 0.5rem;
    font-size: 1.6rem;
  }
  .navbar ul a {
    margin: 11% 0rem;
  }
  .navbar ul a img {
    width: 2.2rem;
  }
  .navbar ul a span {
    font-size: 1.6rem;
  }
  .navbar .credits {
    font-size: 1.8rem;
  }
  /*------------nav------------*/
  .cont-main {
    /*------------header------------*/
    /*------------header------------*/
    /*------------portafolio------------*/
    /*------------portafolio------------*/
    /*------------Login------------*/
  }
  .cont-main .my .opacity div img {
    width: 35rem;
  }
  .cont-main .my .opacity div .title-ash {
    font-size: 3rem;
  }
  .cont-main .my .opacity div span {
    font-size: 1.4rem;
  }
  .cont-main .my .opacity div p {
    font-size: 1.9rem;
    line-height: 5rem;
  }
  .cont-main .my .opacity div hr {
    width: 10rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .categorias button {
    font-size: 1.5rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item {
    width: 31.5%;
    height: 21rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .item-contenido {
    border: 0px solid red;
    width: 100%;
    height: 100%;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .item-contenido img {
    width: 100%;
    height: 100%;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link1 h2 {
    font-size: 2rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link1 span {
    font-size: 1.5rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 .mas img {
    width: 3rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 a {
    margin-left: 2rem;
    cursor: pointer;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 a img {
    width: 3rem;
  }
  .cont-main .imgC .imgM {
    width: 40rem;
    height: 32rem;
  }
  .cont-main .imgC .imgM .closeI {
    width: 3rem;
  }
  .cont-main .login .login-container {
    width: 60%;
    height: 45rem;
  }
}
/*------------1600px------------*/
/*------------1440px------------*/
@media screen and (max-width: 1440px) {
  /*------------General------------*/
  .title {
    font-size: 4rem;
  }
  .line {
    width: 25rem;
    height: 0.3rem;
    margin-bottom: 2rem;
  }
  .ad {
    font-size: 1.5rem;
  }
  .parrafo {
    font-size: 1.6rem;
  }
  /*------------General------------*/
  /*------------nav------------*/
  .navbar .name {
    margin: 1rem auto 0rem auto;
    font-size: 1.8rem;
  }
  .navbar .icons {
    margin: 1rem auto;
  }
  .navbar ul li {
    margin: 5% 0rem;
  }
  .navbar ul li a img {
    width: 1.5rem;
  }
  .navbar ul li a span {
    font-size: 1.1em;
  }
  .navbar ul .link-services {
    margin: 5% 0rem;
  }
  .navbar ul .link-services img {
    width: 1.5rem;
  }
  .navbar ul .link-services span {
    font-size: 1.1rem;
  }
  /*------------nav------------*/
  .cont-main {
    /*------------header------------*/
    /*------------header------------*/
    /*------------skills------------*/
    /*------------skills------------*/
    /*------------portafolio------------*/
    /*------------portafolio------------*/
  }
  .cont-main .my .opacity div img {
    width: 32rem;
  }
  .cont-main .my .opacity div .title-ash {
    font-size: 2.8rem;
  }
  .cont-main .my .opacity div span {
    font-size: 1.2rem;
  }
  .cont-main .my .opacity div p {
    font-size: 1.8rem;
    line-height: 2.5rem;
  }
  .cont-main .my .opacity div hr {
    width: 10rem;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill .img {
    width: 6rem;
    height: 6rem;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill .text {
    width: 75%;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill .text span {
    font-size: 1.8rem;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill .text p {
    font-size: 1.2rem;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill .text a {
    font-size: 1.2rem;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill .text div {
    font-size: 1.2rem;
  }
  .cont-main .skills .cont-text .cont-services .cardS {
    border: 0px solid red;
    width: 44%;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .categorias button {
    font-size: 1.5rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item {
    width: 45%;
    height: 28rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .item-contenido {
    border: 0px solid red;
    width: 100%;
    height: 100%;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .item-contenido img {
    width: 100%;
    height: 100%;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link1 h2 {
    font-size: 2rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link1 span {
    font-size: 1.5rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 .mas img {
    width: 3rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 a {
    margin-left: 2rem;
    cursor: pointer;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item .enlace .link2 a img {
    width: 3rem;
  }
  .cont-main .imgC .imgM {
    width: 40rem;
    height: 32rem;
  }
  .cont-main .imgC .imgM .closeI {
    width: 3rem;
  }
}
/*------------1440px------------*/
/*------------1200px------------*/
@media screen and (max-width: 1200px) {
  .cont-main {
    /*------------skills------------*/
    /*------------skills------------*/
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill {
    width: 48%;
  }
  .cont-main .skills .cont-text .cont-services .cardS {
    border: 0px solid red;
    width: 45%;
  }
}
/*------------1200px------------*/
/*------------992px------------*/
@media screen and (max-width: 992px) {
  /*------------General------------*/
  body {
    padding: 0rem;
    margin: 0rem;
  }
  /*------------General------------*/
  /*------------menu-icon------------*/
  .menu-icon {
    display: block;
  }
  /*------------menu-icon------------*/
  /*------------menu-icon------------*/
  .navbar {
    left: -31rem;
    border: 0px solid red;
  }
  .navbar.responsive {
    left: 1.5rem;
    width: 95%;
  }
  /*------------menu-icon------------*/
  .cont-main {
    width: 100%;
    margin: 0rem 0rem;
    /*------------about------------*/
    /*------------about------------*/
    /*------------skills------------*/
    /*------------skills------------*/
    /*------------skills------------*/
    /*------------skills------------*/
    /*------------portafolio------------*/
    /*------------portafolio------------*/
    /*------------contact------------*/
    /*------------contact------------*/
  }
  .cont-main .about {
    width: 100%;
    margin: 0rem 0rem;
  }
  .cont-main .about .cont-text .cont-about .foto {
    width: 80%;
    margin: 2rem auto;
    border: 0px solid red;
  }
  .cont-main .about .cont-text .cont-about .text {
    width: 100%;
    padding: 1rem;
  }
  .cont-main .about .cont-text .info-about {
    width: 100%;
  }
  .cont-main .about .cont-text .info-about h1 {
    font-size: 2rem;
    color: #149ddd;
  }
  .cont-main .about .cont-text .info-about .items .item {
    width: 100%;
  }
  .cont-main .about .cont-text .info-about .items .item .img {
    width: 6rem;
    height: 6rem;
    padding: 1rem;
    border-radius: 50%;
    display: block;
    background-color: #dff3fc;
  }
  .cont-main .about .cont-text .info-about .items .item .text {
    font-family: RubikRegular;
    margin-left: 1rem;
    color: #2b4c79;
  }
  .cont-main .about .cont-text .info-about .items .item .text span {
    font-size: 1.3rem;
    color: #000000;
  }
  .cont-main .about .cont-text .info-about .items .item .text p {
    font-size: 1.6rem;
    margin-bottom: 1rem;
  }
  .cont-main .skills {
    width: 100%;
    margin: 0rem 0rem;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill {
    width: 100%;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill .img {
    width: 6rem;
    height: 6rem;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill .text {
    width: 75%;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill .text span {
    font-size: 1.8rem;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill .text p {
    font-size: 1.4rem;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill .text a {
    font-size: 1.2rem;
  }
  .cont-main .skills .cont-text .cont-pri .cont-skills .skill .text div {
    font-size: 1.2rem;
  }
  .cont-main .skills .cont-text .cont-services .cardS {
    border: 0px solid red;
    width: 42%;
  }
  .cont-main .portafolio {
    width: 100%;
    margin: 0rem 0rem;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item {
    width: 100%;
    height: 42rem;
  }
  .cont-main .contact {
    width: 100%;
    margin: 0rem 0rem;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .info {
    width: 100%;
    margin-bottom: 5rem;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .info h1 {
    font-size: 2.5rem;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .info .data .cont-info .img {
    width: 4rem;
    height: 4rem;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .info .data .cont-info .text span {
    font-size: 1.5rem;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .info .data .cont-info .text p {
    font-size: 1.2rem;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .info .map {
    width: 100%;
    height: 25rem;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .form {
    width: 100%;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .form h1 {
    font-size: 2.5rem;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .form form {
    width: 100%;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .form form .input_form label {
    font-size: 1.5rem;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .form form .textarea_form label {
    font-size: 1.5rem;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .form form .btn_form .btn {
    font-size: 1.5rem;
  }
}
/*------------992px------------*/
/*------------768px------------*/
@media screen and (max-width: 768px) {
  /*------------General------------*/
  .parrafo {
    font-size: 1.5rem;
  }
  /*------------General------------*/
  .cont-main {
    /*------------header------------*/
    /*------------header------------*/
    /*------------portafolio------------*/
    /*------------portafolio------------*/
    /*------------Login------------*/
    /*------------Login------------*/
  }
  .cont-main .my .opacity {
    padding: 3rem 2rem;
    border: 0px solid red;
    align-items: center;
  }
  .cont-main .my .opacity .cont-text {
    text-align: center;
  }
  .cont-main .my .opacity .cont-text img {
    width: 40rem;
  }
  .cont-main .my .opacity .cont-text .title-ash {
    font-size: 2.6rem;
  }
  .cont-main .my .opacity .cont-text .title-msj {
    font-size: 1.5rem;
    margin: 0rem;
  }
  .cont-main .my .opacity .cont-text span {
    font-size: 1rem;
    margin: 0rem;
  }
  .cont-main .my .opacity .cont-text p {
    margin: 0rem;
  }
  .cont-main .my .opacity .cont-text hr {
    display: none;
  }
  .cont-main .portafolio .cont-text .cont-portafolio .items .item {
    width: 100%;
    height: 35rem;
  }
  .cont-main .login .login-container {
    width: 84%;
  }
}
/*------------768px------------*/
/*------------600px------------*/
@media screen and (max-width: 600px) {
  /*------------General------------*/
  .parrafo {
    font-size: 1.4rem;
  }
  /*------------General------------*/
  /*------------General------------*/
  .padding {
    padding: 4rem 2rem;
  }
  /*------------General------------*/
  /*------------header------------*/
  .cont-main {
    margin: 0rem;
    /*------------header------------*/
    /*------------contact------------*/
    /*------------contact------------*/
    /*------------Login------------*/
    /*------------Login------------*/
  }
  .cont-main .my .opacity {
    padding: 2rem 4rem;
    border: 0px solid red;
    align-items: normal;
  }
  .cont-main .my .opacity .cont-text {
    text-align: center;
  }
  .cont-main .my .opacity .cont-text img {
    width: 25rem;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .info {
    width: 100%;
    margin-bottom: 4rem;
  }
  .cont-main .contact .cont-text .cont-contact .contact-info .form {
    width: 100%;
  }
  .cont-main .login .login-container {
    width: 90%;
    border-radius: 0rem;
    box-shadow: none;
    background-color: #dde5f4;
  }
  .cont-main .login .login-container .image-container {
    display: none;
  }
  .cont-main .login .login-container .form-container {
    width: 100%;
    border-radius: 3rem;
    background-color: #dde5f4;
  }
  .cont-main .login .login-container .form-container form {
    display: flex;
    align-items: center;
    text-align: center;
    background-color: #dde5f4;
  }
  .cont-main .login .login-container .form-container form .redes-sociales {
    justify-content: center;
  }
}
/*------------600px------------*/

/*# sourceMappingURL=styles.css.map */
