html {
	font-size: 14px;
}

body {
	font-size: 1rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto",
		"Helvetica Neue", "Ubuntu";
	font-weight: 400;
}

hr {
	margin-top: 16px;
	margin-bottom: 16px;
}

.row {
	margin-right: 0px;
	margin-left: 0px;
}

.hidden {
	display: none;
}

div[class*='col-'] {
	padding-left: 0px;
	padding-right: 0px;
}

.card {
	background-color: var(--cros-card-bg);
	padding: 28px;
	color: var(--cros-card-text);
	box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.14);
	border-radius: 8px;
}

.card .logo {
	margin: 0px auto;
	text-align: center;
	margin-bottom: 20px;
	padding: 0 20px;
}

.card .logo img {
	max-width: 100%;
	max-height: 200px;
}

.card .card-title .text-center {
    text-align: center;
    padding-bottom: 1rem;
    font-size: 1.5rem;
}

.card .card-content {
	padding: 0px !important;
	display: flex;
	justify-content: center;
	flex-direction: column;
	gap: 18px;
}

/* form inputs */
.control-label-wrapper {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.input-group {
	width: 100%;
	padding-left: 0px;
}

.input-group .form-group {
	padding: 0px !important;
	margin: 0px !important;
}

.input-group a {
	color: var(--cros-href-text);
}

.input-group .form-group label.control-label {
	width: 100%;
	line-height: 1.428571429 !important;
	color: var(--cros-input-text) !important;
	font-weight: 600;
	top: 0;
	position: relative;
	margin: 0;
}

.input-group input.form-control, .form-group input.form-control {
	margin-top: 4px;
	background-image: none !important;
	border: 1px solid #ccc;
	padding: 8px 16px;
	border-radius: 4px !important;
	cursor: pointer;
	color: var(--cros-input-text);
	float: none;
	font-size: 1rem;
	box-shadow: none;
	height: 2.5rem;
}

.input-with-error {
    margin-bottom: 20px;
}

.input-with-error .pass-confirm {
	color: var(--cros-error);
	margin-top: 4px;
	position: absolute;
}

/* input checkbox style */

.checkbox-custom {
	/* width: 20px; */
	display: flex;
	align-items: center;
	justify-content: start;
	gap: 12px;
}
 
.checkbox-custom label {
    cursor: pointer;
    position: absolute;
    width: 20px;
    height: 20px;
    border-radius: 4px;
    border: 1px solid #ccc;
    background: var(--cros-card-bg);
    cursor: pointer;
    margin: 0px;
}
 
.checkbox-custom span { 
 	font-weight: 600;
}

.checkbox-custom label:after {
    opacity: 0;
    content: '';
    position: absolute;
    width: 12px;
    height: 6px;
    background: transparent;
    top: 4px;
    left: 3px;
    border: 2px solid var(--cros-primary);
    border-top: none;
    border-right: none;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
    cursor: pointer;
}
 
.checkbox-custom label:hover::after {
	filter: alpha(opacity=30);
	opacity: 0.3;
}
 
.checkbox-custom input[type=checkbox] {
	margin: 0 !important;
	width: 18px;
	height: 18px;
}

.checkbox-custom input[type=checkbox]:checked + label:after {
	filter: alpha(opacity=100);
	opacity: 1;
}

/* radio input */
.radio-custom {
	display: flex;
	align-items: center;
	justify-content: start;
	gap: 12px;
	display: flex;
	align-items: center;
	justify-content: start;
	gap: 12px;
}

.radio-custom label {
	cursor: pointer;
	position: absolute;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	border: 1px solid #ccc;
	background: var(--cros-card-bg);
	margin: 0;
}

.radio-custom span {
	font-weight: 600;
}

/* Cerc interior cand e selectat */
.radio-custom label::after {
	content: '';
	position: absolute;
	top: 4px;
	left: 4px;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background-color: var(--cros-primary);
	opacity: 0;
	transition: opacity 0.2s ease;
}

.radio-custom label:hover::after {
	opacity: 0.3;
}

.radio-custom input[type="radio"] {
	margin: 0 !important;
	width: 20px;
	height: 20px;
	opacity: 0; /* ascundem input-ul nativ */
}

/* cand e bifat, afisam marcajul */
.radio-custom input[type="radio"]:checked + label::after {
	opacity: 1;
}  
  
/* password input */    
.password .visible {
	position: absolute;
	cursor: pointer;
	z-index: 140;
	right: 16px;
	font-size: 1.5rem;
    pointer-events: auto;
    font-weight: bold;
    bottom: 0.5rem;
}

.password *[class*="btn-link"] {
	padding: 0px !important;
}

/*** footer ***/
footer {
	color: var(--cros-body-text);
}

footer .copyright {
	font-size: 0.9rem;
    margin: 0;
	font-weight: 500;
}

footer ul {
    display: flex;
    margin-bottom: 0;
    padding: 0;
    list-style: none;
    gap: 20px;
}

footer ul li {	
    text-transform: uppercase;
    font-size: 0.9rem;
    font-weight: 500;
}

footer ul li a {
    font-weight: 500;
    font-size: 0.9rem;
    text-transform: uppercase;
    text-decoration: none;
    position: relative;
    display: block;
}

.footer .pull-left a:hover, .footer .pull-right a:hover {
	color: var(--cros-info);
}

.info-text {
	font-size: 1rem;
}

/* password validator */
#validation-area #criteria {
	list-style: none;
	padding-left: 0;
}

#validation-area #criteria li {
	margin: 4px 0;
	font-size: 0.9rem;
	color: var(--cros-card-label);
}

#validation-area #strength {
	margin-top: 12px;
	font-weight: bold;
}

#validation-area #strength-bars {
	margin-top: 8px;
	display: flex;
	gap: 4px;
}

#validation-area .bar {
	flex: 1;
	height: 8px;
	border-radius: 5px;
	background-color: #e0e0e0;
	transition: background-color 0.3s ease;
}

#validation-area .bar.weak {
  	background-color: var(--cros-error);
}

#validation-area .bar.medium {
  	background-color: var(--cros-warning);
}

#validation-area .bar.strong {
  	background-color: var(--cros-success);
}

#validation-area .valid {
  	color: var(--cros-success) !important;
}

#validation-area .invalid {
  	color: var(--cros-error) !important;
}

#complexity-feedback {
	margin-top: 10px; 
	display: block;
}

#complexity-feedback ul {	
	font-weight: 500;
    padding: 0;
    font-size: 0.9rem;
}


#complexity-feedback ul li {
	padding: 6px 0px;
    display: flex;
    gap: 12px;
    align-items: center;
    color: var(--cros-card-label);
    font-style: italic;    
}

#complexity-feedback ul li i {
	font-size: 1.2rem;
    color: var(--cros-warning);
}

.message-warning {
	border-left: 4px solid var(--cros-warning);
	padding: 2px 0px 2px 8px;
}

.message-info {
	border-left: 4px solid var(--cros-info);
	padding: 2px 0px 2px 8px;
}
    
/* code validator */ 
#code-title {
	font-size: 1rem;	
}
	
#code-container {
	display: flex;
	justify-content: space-between;
}

.code-input {
	width: 40px;
	height: 50px;
	text-align: center;
	margin: 0;
	font-size: 2rem;
	border: 2px solid #ccc;
	border-radius: 8px;
	line-height: 50px;
	box-sizing: border-box;
	font-family: 'Roboto Mono', monospace;
	background: var(--cros-card-bg);
	color: var(--cros-input-text);
}

#timer {
  	text-align: center;
  	font-size: 1.5rem;
  	font-weight: bold;
  	min-height: 30px;
}
   
#timer .expired {
	font-size: 1.25rem;
}
    
/* Standard button CSS */
.btn {
    border-radius: 4px;
    position: relative;
	padding: 8px 12px !important;
	margin: 0px !important;
	font-size: 1rem;
	box-shadow: none !important;
	font-weight: 500;
    letter-spacing: 0;
    will-change: box-shadow, transform;
    transition: box-shadow 0.2s cubic-bezier(0.4, 0, 1, 1), background-color 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.btn.active.focus, .btn.active:focus, .btn.focus, .btn:active.focus, .btn:active:focus, .btn:focus {
    outline: 0;
}

.btn-full {
    width: 100%;
    font-size: 1rem;
    text-transform: uppercase;
}

.spaced-buttons {
    display: flex;
    justify-content: space-between;
    gap: 12px;
}

.spaced-buttons .btn-link-primary{
    padding: 8px 0px !important;
}

.inline-buttons {
	display: flex;
    justify-content: end;
    gap: 12px;
}

#session_info {
	display: none;
    color: var(--cros-card-label);
    font-size: 1rem;
    justify-content: center;
    font-weight: 500;
    gap: 4px;
    font-style: italic;
    margin-top: 18px;
}

/* FILL BUTTON */
.btn.btn-primary, .btn.btn-primary:hover, .btn.btn-primary:focus {
	background-color: var(--cros-primary) !important;
	border: 1px solid var(--cros-primary);
}

/* 	OUTLINE BUTTONS*/
/*All*/
*[class*="btn-outline"] {
	background-color: transparent;
	border: 1px solid;
}

/*Primary*/
.btn.btn-outline-primary {
	color: var(--cros-primary);
	border-color: var(--cros-primary);
}

.btn.btn-outline-primary:hover, .btn.btn-outline-primary:active, .btn.btn-outline-primary:focus {
	background-color: var(--cros-primary);
	color: var(--cros-button-text);
}

/*Success*/
.btn.btn-outline-success {
	color: var(--cros-success);
	border-color: var(--cros-success);
}

.btn.btn-outline-success:hover, .btn.btn-outline-success:active, .btn.btn-outline-success:focus {
	background-color: var(--cros-success);
	color: var(--cros-button-text);
}

/*Warning*/
.btn.btn-outline-warning {
	color: var(--cros-warning);
	border-color: var(--cros-warning);
}

.btn.btn-outline-warning:hover, .btn.btn-outline-warning:active, .btn.btn-outline-warning:focus	{
	background-color: var(--cros-warning);
	color: var(--cros-button-text);
}

/*Danger*/
.btn.btn-outline-danger {
	color: var(--cros-error);
	border-color: var(--cros-error);
}

.btn.btn-outline-danger:hover, .btn.btn-outline-danger:active, .btn.btn-outline-danger:focus {
	background-color: var(--cros-error);
	color: var(--cros-button-text);
}

/*Info*/
.btn.btn-outline-info {
	color: var(--cros-info);
	border-color: var(--cros-info);
}

.btn.btn-outline-info:hover, .btn.btn-outline-info:active, .btn.btn-outline-info:focus {
	background-color: var(--cros-info);
	color: var(--cros-button-text);
}

/*LINKS BUTTONS*/
/*All*/
*[class*="btn-link"] {
	background-color: transparent;
	border: 1px solid transparent;
	text-transform: none;
}

*[class*="btn-link"]:focus {
	background-color: transparent;
}

/*Primary*/
.btn.btn-link-primary {
	color: var(--cros-primary);
}

.btn.btn-link-primary:hover, .btn.btn-link-primary:active, .btn.btn-link-primary:focus {
	background-color: transparent;
	color: var(--cros-primary_darker);
	border: 1px solid transparent;
}

/*Success*/
.btn.btn-link-success {
	color: var(--cros-success);
}

.btn.btn-link-success:hover, .btn.btn-link-success:active, .btn.btn-link-success:focus {
	background-color: transparent;
	color: var(--cros-success_darker);
	border: 1px solid transparent;
}

/*Warning*/
.btn.btn-link-warning {
	color: var(--cros-warning);
}

.btn.btn-link-warning:hover, .btn.btn-link-warning:active, .btn.btn-link-warning:focus {
	background-color: transparent;
	color: var(--cros-warning_darker);
	border: 1px solid transparent;
}

/*Danger*/
.btn.btn-link-danger {
	color: var(--cros-error);
}

.btn.btn-link-danger:hover, .btn.btn-link-danger:active, .btn.btn-link-danger:focus	{
	background-color: transparent;
	color: var(--cros-error_darker);
	border: 1px solid transparent;
}

/*Info*/
.btn.btn-link-info {
	color: var(--cros-info);
}

.btn.btn-link-info:hover, .btn.btn-link-info:active, .btn.btn-link-info:focus {
	background-color: transparent;
	color: var(--cros-info_darker);
	border: 1px solid transparent;
}

/* Alert */
.alert.alert-danger {
    background-color: var(--cros-error);
    color: var(--cros-body-text);
    border-radius: 8px;
    border: none;
    box-shadow: 0 4px 20px 0px rgba(0, 0, 0, 0.14), 0 7px 10px -5px rgba(244, 67, 54, 0.4);
}

.alert.alert-danger i {
    color: var(--cros-error);
}

.alert .close {
	font-size: inherit;
    color: var(--cros-body-text);
    opacity: .9;
    text-shadow: none;
}

.alert .close i {
    color: var(--cros-body-text);
    font-size: 11px;
}

.alert span {
    display: block;
    max-width: 89%;
}

.alert.alert-with-icon {
    margin-top: 43px;
    padding-left: 66px;
}

.alert.alert-with-icon i[data-notify="icon"] {
    display: block;
    left: 15px;
    position: absolute;
    margin-top: -34px;
    font-size: 20px;
    background-color: var(--cros-body-text);
    padding: 9px;
    border-radius: 50%;
    max-width: 38px;
    box-shadow: 0 10px 30px -12px rgba(0, 0, 0, 0.42), 0 4px 25px 0px rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(0, 0, 0, 0.2);
}

.animated {
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
}

.fadeInDown {
    -webkit-animation-name: fadeInDown;
    animation-name: fadeInDown;
}

@-webkit-keyframes fadeInDown {
	from {
		opacity: 0;
		-webkit-transform: translate3d(0, -100%, 0);
		transform: translate3d(0, -100%, 0);
	}
	to {
		opacity: 1;
		-webkit-transform: none;
		transform: none;
	}
}

@keyframes fadeInDown {
	from {
		opacity: 0;
		-webkit-transform: translate3d(0, -100%, 0);
		transform: translate3d(0, -100%, 0);
	}
	to {
		opacity: 1;
		-webkit-transform: none;
		transform: none;
	}
}

.alert-with-icon>span>p {
	margin: 0px;
}

.swal2-container.swal2-center {
    z-index: 999999;
}

.swal2-container .swal2-popup {
	max-width: 40vw;
	gap: 28px;
	padding: 28px;
}

.swal2-container .swal2-popup .swal2-icon {
	font-size: 1rem;
}

.swal2-container .swal2-popup .swal2-actions {
	margin-top: 0px;
}

.swal2-container .swal2-popup .swal2-actions .btn {
	margin: 0px 6px !important;
}

.swal2-container .swal2-title {
    font-size: 2rem;
	padding: 0;
	color: var(--cros-error);
}

.swal2-container .swal2-popup .swal2-close {
    position: absolute;
    width: 40px;
    height: 40px;
    top: 0px;
    right: 0px;
    margin: 0 !important;
}

.swal2-container .swal2-html-container {
	font-size: 1.25rem;	
	margin: 0px;
}
	

@keyframes transition-popup-image {
 	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}

.transition-popup-image {
  animation: transition-popup-image 0.3s;
}

/* facebook and goolge btn section 
.input-other-login {
	margin-top: 10px;
	display: flex;
	justify-content: center;
}

.or-container {
	display: flex;
	justify-content: center;
	font-weight: 500;
	margin-top: 10px;
}

a.access-panel__social-button.access-panel__social-button-facebook.bui-button.bui-button--secondary.nw-social-btn-facebook,
	a.access-panel__social-button.access-panel__social-button-google.bui-button.bui-button--secondary.nw-social-btn-google
	{
	margin-right: 20px;
}

.access-panel__social-button-facebook svg {
	fill: #4267b2;
}*/

@media ( max-width : 767px) {
	
	.swal2-container .swal2-popup {
		width: 90vw;
        max-width: max-content;
	}
	
	.card {
		padding: 20px !important;
	}
	
	.card .logo {
		margin-bottom: 20px !important;
	}
	
	.card .card-title .text-center {
	    font-size: 1.25rem;
	}
}