:root {
    --blue: #0e76b7;
    --indigo: #6610f2;
    --purple: #6f42c1;
    --pink: #d51067;
    --red: #9b0c4b;
    --orange: #e36a49;
    --yellow: #ffc107;
    --green: #266232;
    --teal: #6cc04a;
    --cyan: #0e76b7;
    --white: #fff;
    --gray: #666;
    --gray-dark: #333;
    --primary: #0e76b7;
    --secondary: #eee;
    --success: #348644;
    --info: #0e76b7;
    --warning: #ffc107;
    --danger: #d51067;
    --light: #f8f8f8;
    --dark: #333;
    --breakpoint-xs: 0;
    --breakpoint-sm: 576px;
    --breakpoint-md: 768px;
    --breakpoint-lg: 992px;
    --breakpoint-xl: 1200px;
    --font-family-sans-serif: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
    --font-family-monospace: SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
}

*, *::before, *::after {
    box-sizing: border-box;
}

html {
  font-size: 0.625rem;
  font-family: sans-serif;
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

body {
    background: url('images/bg_2560_1440.jpg') no-repeat center center fixed;
    background-size: cover;
    font-family: "Open Sans", Arial, Helvetica, sans-serif;
	margin: 0;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.5;
    color: #333;
}

main, .container {
    display: flex;
    flex-direction: column;
    margin: 1rem;    
}

.top {
	margin: 2rem 1rem 0 1rem;
	display: flex;
    justify-content: space-between;
}

@media (min-width: 768px) { 
    main, .container {
        margin: 30px 0 60px 0;
        align-items: center;
    }
	.top {
		margin: 2rem;
	}
 }

input, button, select, optgroup, textarea {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
}

.card {
    background-color: #FFF;
    padding: 2rem;
    border-radius: 8px;    
    flex-shrink: 0;
}
 @media (min-width: 768px) { 
    .card {
        padding: 3rem 4.5rem 4.5rem 4.5rem;
        border-radius: 1.5rem;
        width: 450px;
    }
 }

.info-header {
    display: flex;
    justify-content: center;
    align-items: center;
    padding-bottom: 38px;
}

    .info-icon-header {
        max-width: 125px;
        max-height: 125px;
    }

.info-title, .info h1 {
	font-weight: 700;
    font-size: 1.8rem;
    margin-bottom: 1.5rem;
}

.info-text {
    display: none;
}

.selector-container + .selector-container { 
    margin-top: 8px;
}

.selector-container {
    background-color: #EEEEEE;
    border: 1px solid #CFCFCF;
    border-radius: 6px;
}

.select-button:hover, .selector-container:hover {
    background-color: #EEEEEE;
    border: 1px solid #8EAFE7;
    border-radius: 6px;
}
.selector-container a {
    display: flex;
	align-items: center;
	font-size: 14px;
    text-decoration: none;
    color: #333;
    font-weight: 700;
    padding: 12px 20px;

}

a:focus {
	border-color: #62b3e5;
}

.ion-ios-arrow-forward {
	font-size: 16px;
}
.selector-container img {
	padding-right: 12px;
    width: 48px;
}

.selector-container .content {
	height: 36px;
}

.pull-right {
	margin-left: auto;
}

.tieto-logo-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-bottom: 50px;
} 

.tieto-logo {
    align-self: center;
    width: 80px;
    margin: 40px 0;
}

/* Test of sub page*/

.hidden {
    display: none;
}


.tietoevry-logo {
    width: 115px;
    height: 28px;
    fill: #fff!important;
}

ol, ul {
    list-style: none;
}

/* This CSS is generated by PhenixID Framework version 2.8 in February 2019. */
.dropdown {
  line-height: 24px;
  font-family: "Open Sans", sans-serif;
  font-size: 16px;
  letter-spacing: 0.2px;
  color: #55646F;
  -webkit-font-smoothing: antialiased;
  text-decoration: none;
  display: inline-block;
  margin: auto;
  position: relative;
}
.dropdown a {
  color: #FFFFFF;
}

.dropdown-toggle {
  -webkit-font-smoothing: antialiased;
  /* padding: 0.5rem 1rem; */
}

.dropdown-toggle::after {
  display: inline-block;
  width: 0;
  height: 0;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid;
  border-right: 0.3em solid transparent;
  border-bottom: 0;
  border-left: 0.3em solid transparent;
}

.dropdown-menu {
  position: absolute;
  top: 100%;
  float: left;
  min-width: 10rem;
  margin: 0.125rem 0 0;
  font-size: 16px;
  color: #444444;
  background-color: #FFFFFF;
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.15);
  border-radius: 0.25rem;
}
.dropdown-menu li a {
  display: block;
  -webkit-font-smoothing: antialiased;
  padding: 10px 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.15);
  font-weight: 400;
  margin: 0;
  color: #444444;
}
.dropdown-menu li a:hover, .dropdown-menu li a:focus, .dropdown-menu li a:active {
  background: #285a8a;
  color: #FFFFFF;
}

.dropdown-toggle {
  cursor: pointer;
}

.dropdown-menu {
  position: absolute;
  background: #FFFFFF;
  padding: 20px 75px 20px 25px;
  margin-top: 12px;
  right: 0;
}
.dropdown-menu.show {
  display: block;
}

.dropdown-menu a {
  text-decoration: none;
  cursor: pointer;
  color: #444444;
  margin-bottom: 5px;
  display: inline-block;
  padding: 5px 0;
}

div.custom-dropdown {
  position: relative;
  border: 1px solid #ededed;
  background: #FFFFFF;
  line-height: 45px;
  font-family: "Open Sans", sans-serif;
  font-size: 16px;
  text-decoration: none;
  font-weight: 400;
  padding: 5px 10px;
  margin: 20px 0;
  display: flex;
  justify-content: space-between;
}

div.custom-dropdown:hover {
  color: black;
  background: #eaeaea;
  cursor: pointer;
}

.custom-dropdown-text {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

div.custom-dropdown .custom-list {
  width: 100%;
  position: absolute;
  left: 10px;
  overflow-y: auto;
  max-height: 250px;
  background: #FFFFFF;
}

div.custom-dropdown .custom-list .custom-list-item {
  border: 1px solid #ededed;
  font-family: "Open Sans";
  font-size: 13px;
  line-height: normal;
  letter-spacing: 0.33px;
  color: #444444;
  text-decoration: none;
  font-weight: 400;
  padding: 5px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 36px;
}

div.custom-dropdown .custom-list.hidden {
  display: none !important;
}

div.custom-dropdown .custom-list .custom-list-item:not(:first-child) {
  border-top: 0px;
}

.custom-list-item:hover {
  background: #4183c4;
  color: #FFFFFF;
}

.custom-list-item:hover .arrow, .custom-list-item:hover .label {
  color: #FFFFFF;
}

.custom-list-item .methodimage,
.custom-list-item .placeholder {
  width: 30px;
  height: 30px;
  display: inline-block;
  margin-right: 20px;
  background-repeat: no-repeat;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  background: #285a8a;
}

.custom-list-item .label {
  display: flex;
  width: 100%;
  align-items: center;
}
.custom-list-item .label span {
  margin: 0px 18px;
}

.custom-dropdown-text {
  width: 100%;
}
.custom-dropdown-text span.caret {
  float: right;
}

.dropdown-menu {
  z-index: 100000;
  padding: 0px;
}
.dropdown-menu li a {
  padding-left: 16px;
  margin: 0;
}

.inputWithButton {
  display: flex;
  align-items: flex-end;
}

.inputWithButton fieldset {
	 flex-grow: 1;
	 margin-right: 6px;
}
.inputWithButton > fieldset > .actions-dropdown > .custom-dropdown {
  border-bottom-left-radius: 0px;
  border-top-left-radius: 0px;
  max-height: 60px;
  margin: 5px 0;
  border: 1px solid #f5f5f6;
}
.inputWithButton > fieldset:not(:first-child) > .actions-dropdown > .custom-dropdown, .inputWithButton > fieldset:not(:first-of-type) > .actions-dropdown > .custom-dropdown {
  border-left: 0px;
}
.inputWithButton > fieldset:first-child > .actions-dropdown > .custom-dropdown {
  border-radius: 4px;
  border-top-right-radius: 0px;
  border-bottom-right-radius: 0px;
}
.inputWithButton > fieldset:last-child > .actions-dropdown > .custom-dropdown {
  border-radius: 4px;
  border-top-left-radius: 0px;
  border-bottom-left-radius: 0px;
}
.inputWithButton > fieldset:only-child > .actions-dropdown > .custom-dropdown {
  border-radius: 4px !important;
}
.inputWithButton > fieldset:not(:first-child),
.inputWithButton > fieldset:not(:first-of-type) {
  border-left: 0px;
}

@media (max-width: 600px) {
  .dropdown-menu {
    margin-top: 3px;
  }

  div.custom-dropdown {
    line-height: normal;
    padding: 10px 20px;
  }
}
div.custom-dropdown {
  height: 48px;
}

div.custom-dropdown {
  border: 1px solid #ededed;
  background: #ffffff;
  position: relative;
  font-family: "Open Sans";
  font-size: 13px;
  line-height: 45px;
  color: #444444;
  text-decoration: none;
  font-weight: 400;
  padding: 5px 10px;
  margin: 20px 0;
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 600px) {
  div.custom-dropdown {
    line-height: normal;
    padding: 20px 10px;
  }

  .select-button .label {
    line-height: normal;
    font-family: "Open Sans", sans-serif;
  }
}
div.custom-dropdown:hover {
  color: black;
  background: #eaeaea;
  cursor: pointer;
}

.custom-dropdown-text {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

div.custom-dropdown .custom-list {
  width: 100%;
  position: absolute;
  left: 10px;
  overflow-y: auto;
  max-height: 250px;
  font-family: "Open Sans", sans-serif !important;
  background: #ffffff;
  z-index: 1;
}

div.custom-dropdown .custom-list .custom-list-item {
  border: 1px solid #ededed;
  font-family: "Open Sans";
  font-size: 16px;
  line-height: normal;
  letter-spacing: 0.33px;
  color: #444444;
  text-decoration: none;
  font-weight: 400;
  padding: 5px 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 36px;
}

div.custom-dropdown .custom-list.hidden {
  display: none !important;
}

div.custom-dropdown .custom-list .custom-list-item:not(:first-child) {
  border-top: 0px;
}

.custom-list-item:hover {
  background: #4183c4;
  color: #ffffff !important;
}

.custom-list-item:hover .arrow, .custom-list-item:hover .label {
  color: #ffffff !important;
}

.custom-list-item .methodimage,
.custom-list-item .placeholder {
  width: 30px;
  height: 30px;
  display: inline-block;
  margin-right: 20px;
  background-repeat: no-repeat;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  background: #285a8a;
}

.custom-list-item .label {
  display: flex;
  font-family: "Open Sans", sans-serif;
  width: 100%;
  align-items: center;
}

.custom-list-item .label span {
  margin: 0px 18px;
}

.custom-dropdown-text {
  width: 100%;
  font-family: "Open Sans", sans-serif;
}

.custom-dropdown-text span.caret {
  float: right;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

@media screen and (max-width: 600px) {
  div.custom-dropdown {
    padding-left: 20px;
    padding-right: 20px;
  }

  .select-button .label {
    line-height: normal;
  }
}

/* For login.css */

fieldset {
    padding: 0;
    border: 0;
}

label {
    font-weight: 700;
}

label {
    display: inline-block;
    margin-bottom: .5rem;
}

label.disabled, label.disabled:after {
    color: #999;
}

.mb-0 {
	margin-bottom: 0 !important;
}

.mt-0 {
	margin-top: 0 !important;
}

.pb-4, .py-4 {
    padding-bottom: 1.6rem !important;
}

.mt-4, .my-4 {
    margin-top: 1.6rem !important;
}

.mt-5, .my-5 {
    margin-top: 3.2rem !important;
}

.form-control {
    display: block;
	width: 100%;
    height: calc(1.5em + 1.6rem + 2px);
    padding: .8rem 1.6rem;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.5;
    color: #333;
	/* Removed important */
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #ddd;
    border-radius: .6rem;
    transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}

.form-control:disabled, .form-control[readonly] {
    cursor: not-allowed;
    border-color: #eee;
    color: #999;
}

.form-control:disabled, .form-control[readonly] {
    background-color: #eee;
    opacity: 1;
}

.form-control:hover:not(:disabled):not([read-only]) {
    border: 1px solid #62b3e5;
}

.form-control:focus {
    color: #333;
    background-color: #fff;
    border-color: #62b3e5;
    outline: 0;
    box-shadow: 0 0 0 .2rem rgba(14,118,183,.25);
}

/* Button */
button {
    border-radius: 0;
}

    button:focus {
        outline: 1px dotted;
        outline: 5px auto -webkit-focus-ring-color;
    }

input, button, select, optgroup, textarea {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
}

button, input {
    overflow: visible;
}

button, select {
    text-transform: none;
}

select {
    word-wrap: normal;
}

button, [type="button"], [type="reset"], [type="submit"] {
    -webkit-appearance: button;
}

    button:not(:disabled), [type="button"]:not(:disabled), [type="reset"]:not(:disabled), [type="submit"]:not(:disabled) {
        cursor: pointer;
    }

    button::-moz-focus-inner, [type="button"]::-moz-focus-inner, [type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner {
        padding: 0;
        border-style: none;
    }
	
.btn {
    display: inline-block;
    font-weight: 600;
    color: #333;
    text-align: center;
    vertical-align: middle;
    user-select: none;
    background-color: transparent;
    border: 1px solid transparent;
    padding: 1.1rem 1.6rem;
    font-size: 1.4rem;
    line-height: 1.5;
    border-radius: .6rem;
    transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}

.btn.disabled, .btn:disabled {
    opacity: .65;
}

.btn-primary {
    color: #fff;
    background-color: #0e76b7;
    border-color: #0e76b7;
}

.btn-primary:hover {
    color: #fff;
    background-color: #0b5f93;
    border-color: #0a5788;
}

.btn-primary:focus, .btn-primary.focus {
    box-shadow: 0 0 0 0.2rem rgba(50,139,194,.5);
}

.btn-secondary {
    color: #111;
    background-color: #eee;
    border: 1px solid #ccc;
}

.btn-secondary:hover {
	color: #111;
	background-color: #dbdbdb;
	border-color: #d5d5d5;
}

.btn-secondary:focus, .btn-secondary.focus {
	box-shadow: 0 0 0 .2rem rgba(205,205,205,.5);
}

.btn-secondary.disabled, .btn-secondary:disabled {
	color: #111;
	background-color: #eee;
	border-color: #eee;
}
	
.btn-success {
    color: #fff;
    background-color: #348644;
    border-color: #348644;
}

.btn-success:hover {
	color: #fff;
	background-color: #296a36;
	border-color: #266131;
}

.btn-success:focus, .btn-success.focus {
	box-shadow: 0 0 0 .2rem rgba(82,152,96,.5);
}

.btn-success.disabled, .btn-success:disabled {
	color: #fff;
	background-color: #348644;
	border-color: #348644;
}
	
.btn-block {
    display: block;
    width: 100%;
}

.w-25 {
    width: 25% !important;
}

.w-50 {
    width: 50% !important;
}

.w-75 {
    width: 75% !important;
}

.w-100 {
    width: 100% !important;
}

.d-flex {
	display: flex !important;
}

.justify-content-center {
    justify-content: center !important;
}

.justify-content-space-between {
	justify-content: space-between;
}

.alert {
    position: relative;
    padding: 1.2rem 1.2rem;
    margin-bottom: 1rem;
    border: 1px solid transparent;
    border-radius: .6rem;
	color: #fff;
}

.alert-warning, .alert-danger {
    background-color: #d51067;
    border-color: #d51067;
}

/* FREJA */

.login-progress-area {
	border-top: 1px solid #ddd;
	padding: 16px 0 0 0;
}

.error-holder.hidden {
  display: none;
}

.alert-danger.hidden {
  display: none;
}

.validator {
  /* margin: 5px; */
  display: flex;
  align-items: center;
}

.validator.hidden {
	color: #ddd;
}

.validator:not(:last-child) {
    margin-bottom: 8px;
}

.validator.hidden.invalid {
  display: none;
}


.validator .indicator,
.validator.valid.hidden .indicator {
  height: 20px;
  width: 20px;
  margin-right: 10px;
  display: flex;
  border-radius: 50%;
  background-color: #DDD;
  /* background: url("../../images/uncheck.png") no-repeat; */
  /* background: url("images/uncheck.png") no-repeat; */
  justify-content: center;
  align-items: center;
  font-size: 11px;
  color: #FFF;
}
/*
.validator.invalid .indicator {
  background: url("../../images/changepwd/disapprove.svg") no-repeat;
}*/ 

.validator.valid .indicator {
  /* background: url("../../images/changepwd/approve.svg") no-repeat; */
  /* background: url("images/approve.svg") no-repeat; */
  border-radius: 50%;
  background-color: #6CC04A;  
}

/*
.possibleCaptcha {
  display: flex;
  justify-content: center;
}
*/
.possibleCaptcha { 
	background-color: #f8f8f8;
	padding: 12px;
	margin-top: 4px;
}
.possibleCaptcha label {
	margin-bottom: 0;
}

.possibleCaptcha .checkbox {
  padding: 0;
}

.polling .waiting {
  /* background-image: url("../../images/uncheck.png"); */
  background-image: url("/images/uncheck.png");
}

.polling .waiting-done {
  /* background-image: url("../../images/check.png"); */
  background-image: url("/images/check.png");
}

.progress {
  display: flex;
  align-items: center;
  margin: 20px auto;
}

.waiting {
  display: inline-block;
  /* background-image: url("../../images/uncheck_blue.png"); */
  background-image: url("/images/check_blue.png");
  background-repeat: no-repeat;
  height: 25px;
  width: 25px;
  -webkit-background-size: contain;
  -moz-background-size: contain;
  -o-background-size: contain;
  background-size: contain;
}

.validator .text {
  display: inline-block;
  width: 70%;
  margin-left: 18px;
}

.waiting-done {
  /* background-image: url("../../images/check_blue.png"); */
  background-image: url("/images/check_blue.png");
  background-repeat: no-repeat;
}

.toggle-visibility {
  position: absolute;
  top: 25px;
  right: 25px;
  height: 20px;
  width: 20px;
  display: inline-block;
  background: url("../../images/changepwd/show.svg") no-repeat;
  cursor: pointer;
}

.toggle-visibility.showing {
  background: url("../../images/changepwd/hide.svg") no-repeat;
  top: 22px;
}

/* Changepwd */
.select-button {
	display: flex;
	justify-content: space-between;
    font-size: 14px;
    text-decoration: none;
    color: #333;
    font-weight: 700;
    padding: 20px 20px;
	background-color: #EEEEEE;
    border: 1px solid #CFCFCF;
    border-radius: 6px;
}

.select-button + .select-button {
	margin-top: 8px;
}

.select-button > .label { 
    align-items: center;
    display: flex;
}

img.methodimage {
    display: none;
}

/* template-stage2 */
.form-group + .form-group {
	margin-top: 1.6rem;	
}

.btn a {
	text-decoration: none;
	color: inherit;
}

/* 
	changepwdpwd 
*/
.form-control:hover:not(:disabled):not([read-only]) {
    border: 1px solid #62b3e5;
}

.form-control:disabled, .form-control[readonly] {
	background-color: #eee;
    cursor: not-allowed;
    border-color: #eee;
    color: #999;
}
/*
.checkbox {
    margin-left: -15px;
    padding: 20px 0;
}*/
input[type="checkbox"] + label {
    background-image: url("images/uncheck_blue.png");
    background-repeat: no-repeat;
    height: 25px;
    display: inline-block;
    color: #285a8a;
    padding-left: 40px;
    padding-right: 25px;
    line-height: 25px;
    cursor: pointer;
}
input[type="checkbox"]:checked + label {
    background-image: url("images/check_blue.png");
    background-repeat: no-repeat;
}
input[type="checkbox"] {
    opacity: 0;
}
input[type="checkbox"]:hover + label,
input[type="checkbox"]:active + label,
input[type="checkbox"]:focus + label {
    text-decoration: underline;
}

.btn--verify {
    height: 39px;
    display: flex;
    align-items: center;
}

.d-inline-flex {
	display: inline-flex;	
}

.password-validator {
	background-color: #f8f8f8;
    padding: 24px;
    margin-top: 12px;	
}