#msform {
    text-align: center;
    position: relative;
    margin-top: 20px
}

#msform fieldset {
    background: white;
    border: 0 none;
    border-radius: 0.5rem;
    box-sizing: border-box;
    width: 100%;
    margin: 0;
    padding-bottom: 20px;
    position: relative
}

.form-card {
    text-align: left
}

#msform fieldset:not(:first-of-type) {
    display: none
}

.panel input:not([type='checkbox']),
.panel textarea {
    padding: 8px 15px 8px 30px;
    border: 1px solid #ccc;
    border-radius: 0px;
    margin-bottom: 25px;
    margin-top: 2px;
    width: 100%;
    box-sizing: border-box;
    font-family: montserrat;
    color: #2C3E50;
    background-color: #ECEFF1;
    font-size: 16px;
    letter-spacing: 1px
}

#msform .input-login-password{
    margin: 0;
}

#msform .input-placeholder-icon {
	width: 30px;
	height: 38px;
	line-height: 48px;
}

#msform .msform-link {
	color: #673AB7;
}

#msform input:focus,
#msform textarea:focus {
    -moz-box-shadow: none !important;
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
    border: 1px solid #673AB7;
    outline-width: 0
}

.action-button {
    max-width: 180px;
    background: #673AB7;
    font-weight: bold;
    color: white;
    border: 0 none;
    border-radius: 4px;
    cursor: pointer;
    padding: 8px;
    margin: 10px 0px 10px 5px;
    float: right
}

#msform .action-button:hover,
#msform .action-button:focus {
    background-color: #311B92
}

#msform .action-button-previous {
    max-width: 180px;
    background: #616161;
    font-weight: bold;
    color: white;
    border: 0 none;
    border-radius: 4px;
    cursor: pointer;
    padding: 8px;
    margin: 10px 5px 10px 0px;
    float: right
}

#msform .action-button-previous:hover,
#msform .action-button-previous:focus {
    background-color: #000000
}

.input-group .form-control:focus{
    z-index: 0;
}

.card {
    z-index: 0;
    border: none;
    position: relative
}

.fs-title {
    font-size: 25px;
    color: #673AB7;
    margin-bottom: 15px;
    font-weight: normal;
    text-align: left
}

.purple-text {
    color: #673AB7;
    font-weight: normal
}

.steps {
    font-size: 20px;
    color: gray;
    margin-bottom: 10px;
    font-weight: normal;
    text-align: right;
    margin-top: 0px;
}

.fieldlabels {
    color: gray;
    text-align: left
}

#progressbar {
	padding-left: 0px;
    margin-bottom: 30px;
    overflow: hidden;
    color: lightgrey
}

#progressbar .active {
    color: #673AB7
}

#progressbar li {
    list-style-type: none;
    font-size: 15px;
    width: 25%;
    float: left;
    position: relative;
    font-weight: 400;
    z-index: 1;
}

#progressbar #authentication:before {
    font-family: FontAwesome;
    content: "\f007"
}

#progressbar #authorization:before {
    font-family: FontAwesome;
    content: "\f13e"
}

#progressbar #envelope:before {
    font-family: FontAwesome;
    content: "\f0e0"
}

#progressbar #agent:before {
    font-family: FontAwesome;
    content: "\f019"
}

#progressbar #confirm:before {
    font-family: FontAwesome;
    content: "\f00c"
}

#progressbar li:before {
    width: 50px;
    height: 50px;
    line-height: 45px;
    display: block;
    font-size: 20px;
    color: #ffffff;
    background: lightgray;
    border-radius: 50%;
    margin: 0 auto 10px auto;
    padding: 2px
}

#progressbar li:after {
    content: '';
    width: 100%;
    height: 2px;
    background: lightgray;
    position: absolute;
    left: 0;
    top: 25px;
    z-index: -1 !important;
}

#progressbar li.active:before,
#progressbar li.active:after {
    background: #673AB7
}

.progress {
    height: 20px
}

.progress-bar {
    background-color: #673AB7
}

.fit-image {
    width: 100%;
    object-fit: cover
}

#content-select-workflow {
	margin-top: 10%;
}

#content-select-workflow div.col-md-6, #content-select-workflow div.col-md-4 {
	padding: 25px 40px;
}

.panel-footer-init{
    margin-top: 15px;
}

@media (min-width: 1400px){
    .col-xl-3 {
        width: 25%;
    }
    .col-xl-9 {
        width: 75%;
    }
}

.workflow-panel-title {
	font-size: 22px;
	text-overflow: ellipsis; 
	overflow: hidden;
	font-weight: bold;
    color: white;
    background-color:#454e59 !important;
	border-color:#454e59 !important;
}

@media (max-width: 992px) {
    .title-init {
        font-size: 22px;
    }
}
@media (min-width: 992px) and (max-width: 1200px){
    .title-init {
        font-size: 18px;
    }
}
@media (min-width: 1200px){
    .title-init {
        font-size: 22px;
    }
}

.upper-agent-panel{
    margin-bottom: 100px;
}
@media (max-width: 992px) {
    .upper-agent-panel{
        margin-bottom: 40px;
    }
}

.agent-panel-init{
    border-radius:4px;
    padding-right:5px;
    height: 130px;
}

@media (max-width: 992px) {
    .agent-panel-init{
        border-radius:4px;
        padding-right:5px;
        margin-bottom: 40px;
        height: 130px;
    }
}

.agent-icon-init{
    font-size:80px;
    text-align:center;
    color:white;
    padding: 0 0 0 15px;
    background:#454e59;
    height:100%;
    border-radius: 5px 0 0 5px;
    padding-top: 8px;
}

.agent-content-init{
    padding:25px 0 0 10px;
    background:#454e59;
    border-radius: 0 5px 5px 0;
    height:100%;
}

.select-worfklow-description {
	width: 100%;
	min-height: 40px;
	max-height: 40px;
	margin-bottom: 20px;
	text-overflow: ellipsis;  
	overflow: hidden;
	font-family: montserrat;
    font-size: 16px;
}


.row-2-default-view {
	margin:0px 65px;
}

@media (max-width: 375px) {
    .download-agent-icon {
        font-size:35px;
        float:left;
        margin-right:12px;
        cursor:pointer;
    }
}
@media (min-width: 375px){
    .download-agent-icon {
        font-size:35px;
        float:left;
        margin-right:15px;
        cursor:pointer;
    }
}

.row-default-view {
	margin:80px 60px 0 5px;
}

@media (max-width: 992px){
    .row-default-view {
		margin:100px 50px 0 50px;
	}
}

@media (max-width: 800px) {

	.row-2-default-view {
		margin:0px 50px;
	}
	
	#content-select-workflow div.col-xs-12 {
		padding: 15px 20px;
	}

	#progresssbar {
		margin-bottom: 0px;
	}
	
	 #progressbar li strong {
		display: none;
	}
	
	.progress {
		margin-bottom: 0px;
	}
	
	#progressbar li:before {
	    width: 40px;
	    height: 40px;
	    line-height: 36px;
	    display: block;
	    font-size: 18px;
	    color: #ffffff;
	    background: lightgray;
	    border-radius: 50%;
	    margin: 0 auto 0px auto;
	    padding: 2px;
	}
	
	#progressbar li:after {
	    content: '';
	    width: 100%;
	    height: 2px;
	    background: lightgray;
	    position: absolute;
	    left: 0;
	    top: 20px;
	    z-index: -1 !important;
	}
}

@media (max-width: 450px) {
	
	.row-default-view {
		margin:50px 10px 0 10px;
	}
	
	.row-2-default-view {
		margin:0px 10px;
	}

	.workflow-panel-title {
		font-size: 17px;
	}
	
	.select-worfklow-description {
	    font-size: 14px;
	}
	
	
	#progressbar li:before {
	    width: 31px;
	    height: 31px;
	    line-height: 26px;
	    display: block;
	    font-size: 16px;
	    color: #ffffff;
	    background: lightgray;
	    border-radius: 50%;
	    margin: 0 auto 0px auto;
	    padding: 2px;
	}
	
	#progressbar li:after {
	    content: '';
	    width: 100%;
	    height: 2px;
	    background: lightgray;
	    position: absolute;
	    left: 0;
	    top: 15px;
	    z-index: -1 !important;
	}
	
	.fs-title {
	    font-size: 20px;
	    margin-top: 5px;
	}
	
	.steps {
	    font-size: 15px;
	    margin-top: 0px;
	}
		
}



/**
 * CSS VPN SAML styles
 */
@media (max-width: 768px) {
    .box-vpn-saml{
        text-align: center;
        position: relative;
        float: left;
        padding-right: 8px;
        padding-left: 8px;
    }
}
@media (min-width: 768px) {
    .box-vpn-saml{
        text-align: center;
        position: relative;
        float: left;
    }
}


.steps-vpn-saml{
    position: absolute;
    top: -26px;
    z-index: 10;
    left: 0;
    right: 0;
}

.steps-vpn-saml span{
    background-color: #673AB7;
    border: 3px solid white;
    font-size: 26px;
    color: #ffffff;
    display: inline-block;
    border-radius: 50%;
    line-height: 49px;
    height: 52px;
    width: 52px;
}

.box-inside-vpn-saml{
    text-align: center;
    border: 1px solid #e7e7ef;
    background: #FFFFFF;
    padding: 25px 10px 5px 10px;
    position: relative;
    min-height: 320px;
}

.row-vpn-saml{
    padding-top: 48px;
    margin-right: -40px;
    margin-left: -40px;
}

@media (max-width: 768px) {
    .download-link-vpn-saml{
        border: 1px solid #E5E5E5;
        color: gray;
        display: inline-block;
        border-radius: 5px;
        padding: 5px 8px;
        margin-left: -24px;
        margin-right: -24px;
    }
}
@media (min-width: 768px) {
    .download-link-vpn-saml{
        border: 1px solid #E5E5E5;
        color: gray;
        display: inline-block;
        border-radius: 5px;
        padding: 5px 8px;
    }
}