#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
}

.radio-option {
     display: block;
     margin-bottom: 5px; 
}

.card input:not([type='checkbox']):not([type='radio']),
.card 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;
    box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%);
    color: #2C3E50;
    background-color: #ECEFF1;
    font-size: 16px;
    letter-spacing: 1px
}

.card input:not([type='checkbox'])::placeholder{
    opacity: 0.6;
}

#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;
}

.form-control-feedback {
    position: absolute;
    right: 0;
    z-index: 2;
    text-align: center;
    pointer-events: none;
}

.has-feedback label ~ .form-control-feedback {
    top:25px;
}
.has-feedback label.sr-only ~ .form-control-feedback {
    top: 0;
}

.form-group {
    margin-bottom: 15px;
}

.has-feedback {
    position: relative;
}

.input-group-addon {
    padding: 6px 12px;
    font-size: 14px;
    font-weight: 400;
    line-height: 1;
    color: #555;
    text-align: center;
    background-color: #eee;
    border: 1px solid #ccc;
    border-radius: 4px;
}

.input-group-addon, .input-group-btn {
    width: 1%;
    white-space: nowrap;
    vertical-align: middle;
}

.input-group {
    position: relative;
    display: table;
    border-collapse: separate;
}

.input-group .form-control, .input-group-addon, .input-group-btn {
    display: table-cell;
}

.input-group-addon:last-child {
    border-left: 0;
}

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

.fs-title {
    margin-top: 20px;
    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;
    display: inline-block;
    max-width: 100%;
    margin-bottom: 5px;
    font-weight: 700;
}

#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;
    margin-bottom: 20px;
}

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

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

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

#content-select-workflow div.col-lg-6, #content-select-workflow div.col-lg-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: 175px;
    }
}

.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-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;
    }
}

a {
    color: #337ab7;
    text-decoration: none;
}

a:focus, a:hover {
    text-decoration: underline;
}

.alert-info{
    color: #31708f;
 }
 
 .alert-danger {
    color: #a94442;
 }
 
 .alert-warning {
    color: #8a6d3b;
 }