body {
	font-family: "Titillium Web", sans-serif !important;
	font-size: 14px;
	color: rgba(27, 41, 70, 0.8);
	-webkit-font-smoothing: antialiased;
	-webkit-text-shadow: rgba(0, 0, 0, 0.01) 0 0 1px;
	text-shadow: rgba(0, 0, 0, 0.01) 0 0 1px;
	margin: 0px;
	padding: 0px;
}

.logLogo {
	text-align: center;
	line-height: 70px;
}

.esLogo {
	width: 5em;
	height: 6em;
	display: inline-block;
	vertical-align: bottom;
	background-image: url(../img/es-logo.svg);
	background-repeat: no-repeat;
	background-size: contain;
}

.content {
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	height: 583px;
	display: block;
	padding: 0;
	margin: auto;
	text-align: center;
	vertical-align: middle;
	width: 100%;
	height: 100%;
}

.welcome {
	display: inline-block;
	vertical-align: middle;
}

.login-form {
	margin-left: -10px;
	width: 100%;
	height: 350px;
	max-width: 380px;
	text-align: start;
	border-radius: 0.4em;
	display: inline-block;
	background-color: #f5f8fc;
	box-shadow: 0 14px 28px rgba(0, 0, 0, 0.25), 0 10px 10px rgba(0, 0, 0, 0.22);
}

.login-form h1 {
	color: #3869b2;
	font-weight: 400;
	padding-top: 38px;
	padding-bottom: 27px;
	text-align: center;
	font-size: 24px !important;
	margin-top: 0px;
	margin-bottom: 0px;
}

.login-message {

	z-index: 2;
	width: 340px;
	height: 310px;
	top: 0px;
	padding: 20px;
	color: #ffffff;
	max-width: 100%;
	text-align: left;
	display: inline-block;
	background-color: #0d1424;
	border-top-left-radius: 0.4em;
	border-bottom-left-radius: 0.4em;
	-webkit-box-shadow: 0 14px 28px rgba(0, 0, 0, 0.25),
	0 10px 10px rgba(0, 0, 0, 0.22);
	-moz-box-shadow: 0 14px 28px rgba(0, 0, 0, 0.25),
	0 10px 10px rgba(0, 0, 0, 0.22);
	box-shadow: 0 14px 28px rgba(0, 0, 0, 0.25), 0 10px 10px rgba(0, 0, 0, 0.22);

}

@media screen and (max-width: 980px) {
	.login-message{
		height: 60%;
		top:340px;
	}
}

@media screen and (max-width: 333px)
{
	.login-message{
		height: 74%;
	}

}

.login-message h4 {
	font-weight: 600;
	font-size: 1.30769231em;
	margin-bottom: 0px;
}

.login-message a,
.login-message h4,
.login-message .login-message-content {
	line-height: 20px;
}

.login-message .login-message-content li {
	padding-left: 1.5em;
	line-height: 30px;
	position: relative;
}
.login-message .login-message-content li::before {
	top: 0;
	bottom: 0;
	left: -1em;
	width: 2em;
	height: 2em;
	content: "";
	margin: auto;
	position: absolute;
	background-size: contain;
}

.login-message .login-message-content li#gerez-contrat::before,
.login-message .login-message-content li#consultez-facture::before,
.login-message .login-message-content li#suivez-conso::before {
	content: ""; /* Ajoutez cette ligne pour s'assurer que le pseudo-élément s'affiche correctement */
	display: inline-block; /* Utilisez 'inline-block' pour appliquer la taille */
	width: 30px; /* Ajustez la largeur selon vos besoins */
	height: 30px; /* Ajustez la hauteur selon vos besoins */
	background-size: contain; /* Pour s'assurer que l'image s'ajuste correctement */
	background-repeat: no-repeat; /* Pour éviter la répétition de l'image */
}

.login-message .login-message-content li#gerez-contrat::before {
	background-image: url(../img/EspaceClientContrat.png);
}
.login-message .login-message-content li#consultez-facture::before {
	background-image: url(../img/EspaceClientFacture.png);
}
.login-message .login-message-content li#suivez-conso::before {
	background-image: url(../img/EspaceClientConso.png);
}

.login-message h4 {
	text-transform: uppercase;
	margin-top: 0px;
}

.login-message a {
	width: 17em;
	display: block;
	color: #8fca52;
	border: 1px solid #8fca52;
	border-radius: 2em;
	padding: 0.25em;
	font-size: 1.1em;
	font-weight: 400;
	text-align: center;
	margin-top: 2em;
}

.loginHelp {
	margin-top: 0.8em;
}

.loginHelp .helpIcon::before {
	font-size: 170%;
}
.logField .helpIcon {
	position: absolute;
	top: 9px;
	right: -16px;
}

.loginCreateAccount {
	margin: 0.5em auto .5em auto;
	font-weight: 600;
	background: #fff;
	font-size: 12px;
	height: 30px;
	border: 1px solid;
	border-color: none;
	-webkit-transition: box-shadow .25s;
	-webkit-transition-timing-function: ease;
	font-family: "Titillium Web", sans-serif !important;
	box-shadow: 0 3px 6px rgba(0, 0, 0, 0), 0 3px 6px rgba(0, 0, 0, 0);
	color: #3869b2;
}

/* Effet au survol */
.loginCreateAccount:hover {
	background-color: #3869b2;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
	border-color: #0a0e1a;
	cursor: pointer;
	color: #fff;
}

/* Effet lorsque l'élément est cliqué */
.loginCreateAccount:active {
	background-color: #3869b2 !important;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2) !important;
	transform: scale(0.98);
}

.loginCreateAccountSelected {
	background-color: #3869b2 !important;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2)!important;
	border-color: #0a0e1a !important;
	transform: scale(0.98);
	color: #fff !important;

}

.loginCreateAccountChoice {
	background-color: rgb(128, 194, 66);
	margin: .5em auto .5em auto;
	padding: .4em 1em;
	border-radius: 50em;
	font-size: 9px;
	font-weight: 500;
	border-color: none;
	display: none;
	height: 28px;
	font-family: "Titillium Web", sans-serif !important;
	color: #fff;
}

@media screen and (min-width: 353px) {
	.loginCreateAccountChoice{
		font-size: 11px;
	}
}

@media screen and (min-width: 980px) {
	.loginCreateAccountChoice{
		font-size: 12px;
	}
}


.pwdResetLink {
	color: #324671;
	display: block;
	font-size: 1em;
	font-weight: 500;
	text-align: left;
	padding-left: 1em;
    text-decoration: underline;
	margin-top: 15px;
	margin-left: 40px;
}

.pwdResetLink:hover {
	text-decoration: underline;
}

ul li {
	list-style: none;
}

#kc-container {
	width: 100%;
	height: 100%;
}

#kc-container-wrapper {
	width: 100%;
	height: 100%;
}

#kc-content {
	width: 100%;
	height: 100%;
}

#kc-content-wrapper {
	width: 100%;
	height: 100%;
}

#kc-form {
	width: 100%;
	height: 100%;
}

#kc-form-wrapper {
	width: 100%;
	height: 100%;
}

.logField {
	width: 90%;
	margin: auto;
	max-width: 300px;
}

.formField {
	text-align: left;
}

.formFieldContainer {
	width: 100%;
	border: none !important;
}

.formField > div {
	height: 100%;
	display: inline-block;
	width: 100%;
	vertical-align: top;
}

.formField > div label {
	top: 0.4em;

	padding: 0 9px;
	color: #3869b2;
	font-size: 14px;
	font-weight: 600;
	overflow: hidden;
	position: absolute;
	white-space: nowrap;
	text-overflow: ellipsis;
	transition: all 0.2s ease-in-out;
}
.formFieldLabel {
	left: 0;
	position: absolute !important;
	font-size: 13px !important;
	color: #3869b2 !important;
}

.formField input {
	border-left: 1px solid #d5d8f2 !important;
	border-right: 1px solid #d5d8f2 !important;
	border-top: 1px solid #d5d8f2 !important;
	border-bottom: 1px solid #d5d8f2 !important;
	width: 100%;
	height: 50px;
	border-width: 0;
	font-size: 14px;
	overflow: hidden;
	position: static;
	padding: 20px 9px 0;
	white-space: nowrap;
	-o-text-overflow: ellipsis;
	text-overflow: ellipsis;
	color: rgba(27, 41, 70, 0.6) !important;
	box-sizing: border-box;
}

.form-group {
	margin-top: 25px;
}

.aligncenter {
	text-align: center;
}

.relative {
	position: relative;
}

/** BOUTONS **/

a.ui-button.btn {
	display: inline-block;
	text-decoration: none;
}

.ui-button {
	max-width: 100%;
}

.ui-button.btn {
	color: #3869b2;
	border-radius: 50em;
	border: 1px solid #3869b2;
	transition: box-shadow 0.25s;
	transition-timing-function: ease;
	-webkit-transition: box-shadow 0.25s;
	-webkit-transition-timing-function: ease;
	font-family: "Titillium Web", sans-serif !important;
	box-shadow: 0 3px 6px rgba(0, 0, 0, 0), 0 3px 6px rgba(0, 0, 0, 0);
}

.ui-button.btn:hover,
.ui-button.btn:focus {
	outline: none;
	box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.23);
	-webkit-transition: all 0.25s ease;
	transition: all 0.25s ease;
	cursor: pointer;
}

.ui-button.btn.right {
	float: right;
}

.ui-button.btn.long {
	padding: 0.5em 4em;
}
.ui-button.btn.short {
	padding: 0.6em 0;
}
.ui-button.btn.center {
	margin: 0.5em auto 0.5em auto;
}
.ui-button.btn.medium {
	font-size: 1em;
	font-weight: 700;
	padding: 0.5em 2em;
	text-transform: uppercase;
}
.ui-button .ui-button-text {
	max-width: 100%;
	text-overflow: ellipsis;
	overflow: hidden;
}
.ui-button.btn.white {
	color: #3869b2;
	background: #fff;
	border: 1px solid #3869b2;
}

.ui-button.btn.blue {
	color: #fff;
	background: #3869b2;
	border: 1px solid #3869b2;
}

.ui-button.btn.border-blue {
	color: #3869b2;
	font-weight: 600;
	background: #fff;
	border: 1px solid #3869b2;
}

.btn.large {
	font-size: 1.3em;
	font-weight: 700;
	padding: 0.5em 4em;
	text-transform: uppercase;
}

.ui-button.btn.green {
	color: #fff;
	background: rgb(128, 194, 66);
	border: 1px solid rgb(128, 194, 66);
}

::-webkit-input-placeholder {
	/* Chrome/Opera/Safari */
	font-style: italic;
	color: rgb(198, 171, 158);
	font-size: 13px;
}
::-moz-placeholder {
	/* Firefox 19+ */
	font-style: italic;
	color: rgb(198, 171, 158);
	font-size: 13px;
}
:-ms-input-placeholder {
	/* IE 10+ */
	font-style: italic;
	color: rgb(198, 171, 158);
	font-size: 13px;
}
:-moz-placeholder {
	/* Firefox 18- */
	font-style: italic;
	color: rgb(198, 171, 158);
	font-size: 13px;
}

@media screen and (max-width: 451px) {
	.ui-button.btn.right {
		float: none;
		display: inline-block;
		margin: 0.5em auto 0.5em auto;
	}
	.button-bar {
		text-align: center;
	}
}

/** COMBOBOX */

select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none; /* remove default arrow */
	background-image: url(../img/dropdown-arrow.png); /* add custom arrow */
	background-repeat: no-repeat;
	background-position-x: 98%;
	background-position-y: center;
}

select::-ms-expand {
	display: none; /* hide the default arrow in ie10 and ie11 */
}

@media screen and (min-width: 0\0) {
	select {
		background-image: none\9;
		padding: 5px\9;
	}
}

.ui-selectonemenu label:focus {
	background: transparent !important;
}

.ui-inputfield {
	margin-bottom: 10px;
	padding: 0 10px 10px 10px;
	margin-top: 10px;
	width: 100%;
	height: 95%;
}

.loginCustomerTypeSelect {
	z-index: 99;
	position: relative;
	height: 40px;
	width: 100%;
	max-width: 355px;
	line-height: 20px;
	margin: 0px 5px 0px 2px;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
	-webkit-box-shadow: 0 0 0 30px white inset;
}
.ui-noselection-option,
.ui-selectonemenu.no-selection label,
.formField .ui-selectonemenu.ui-edited.no-selection label:hover {
	font-weight: 400;
	font-style: italic;
	color: #9b9b9b !important;
}

select.login-input {
	font-size: 12px !important;
	font-weight: 600;
	font-style: italic;
	color: rgb(155, 155, 155) !important;
	text-transform: none;
}
select:hover {
	font-weight: normal;
}
option:not(:checked) {
	font-style: normal;
}

.ui-selectonemenu-items-wrapper {
	background: #fff;
	border: 1px solid #d5d8f2;
	-webkit-box-shadow: 0 10px 20px rgba(0, 0, 0, 0.19),
	0 6px 6px rgba(0, 0, 0, 0.23);
	-moz-box-shadow: 0 10px 20px rgba(0, 0, 0, 0.19),
	0 6px 6px rgba(0, 0, 0, 0.23);
	box-shadow: 0 10px 20px rgba(0, 0, 0, 0.19), 0 6px 6px rgba(0, 0, 0, 0.23);
}

.ui-selectonemenu-items .ui-state-highlight,
.ui-autocomplete-items .ui-state-highlight {
	font-weight: 500;
}

.ui-selectonemenu-items .ui-state-hover,
.ui-autocomplete-items .ui-state-hover {
	background: transparent !important;
	font-weight: 500;
	border: none !important;
}

.ui-selectonemenu label.ui-selectonemenu-label:focus {
	background: transparent !important;
}

.ui-state-hover a,
.ui-state-hover a:hover,
.ui-state-hover a:link,
.ui-state-hover a:visited,
.ui-state-focus a,
.ui-state-focus a:hover,
.ui-state-focus a:link,
.ui-state-focus a:visited {
	color: #ffffff;
	text-decoration: none;
}

.ui-state-hover {
	border-bottom: 1px solid #3869b2 !important;
	color: #3869b2 !important;
}
/** CHECKBOX */

.ui-chkbox {
	display: inline-block;
	vertical-align: middle;
	text-align: center;
}
.ui-chkbox + label,
.ui-chkbox + span,
.ui-chkbox .ui-chkbox-label {
	vertical-align: middle;
}
.ui-icon.ui-chkbox-icon {
	display: inline-block !important;
}
.ui-chkbox-label {
	margin-left: 1em;
}
.ui-chkbox-text-l {
	margin-right: 1em;
}
.ui-chkbox-icon {
	width: 12px;
	height: 12px;
	cursor: pointer;
	text-indent: 0px;
	vertical-align: middle;
	border-radius: 2px !important;
	display: inline-block !important;
	border: 1px solid #727c8e !important;
}
.ui-chkbox-icon.ui-icon-check {
	color: #fff !important;
	border: 1px solid #3869b2 !important;
	background-color: #3869b2 !important;
	position: relative;
}

.ui-chkbox-icon.ui-icon-check::before {
	content: "\f00c";
	font-family: FontAwesome;
	font-size: 10px;
	left: 0;
	right: 0;
	margin: auto;
	position: absolute;
	line-height: 1;
	box-sizing: border-box;
}

input[type="checkbox"] ~ .custom-checkbox {
	top: 6px;
	left: -7px;
	position: absolute;
	width: 10px;
	height: 10px;
	border: 1px solid #3869b2;
	display: inline-block;
}

input[type="checkbox"]:checked ~ .custom-checkbox {
	top: 6px;
	left: -7px;
	position: absolute;
	width: 10px;
	height: 10px;
	background: #3869b2;
	display: inline-block;
}

.hidden-checkbox {
	width: 0;
	height: 0;
	overflow: hidden;
}

.centered-text {
	text-align: center;
}

.registration.content {
	padding-bottom: 10px;
	text-align: center;
}

.required {
	color: red;
}


/*animation*/
/* Animation d'apparition */
.fade-in {
	animation: fadeIn 0s ease-in-out forwards; /* forwards pour conserver l'état final */
	display: block; /* S'assurer que l'élément est visible */
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Cache la section par défaut */
.additionalOptions {
	margin-top: 0px;
	padding-top: 0px;
	text-align: center;
}

@media screen and (max-width: 333px) {

	.additionalOptions
	{
		padding-top: 45px;
	}
}

@media screen and (max-width: 980px) {
	.notClientLabel{
		padding-bottom: 8px;
	}
}

.youare-label {
	font-weight: 600;
}

.youare-buttons {
	text-align: center;
}

@media screen and (min-width: 345px) {

	.youare-buttons
	{
		display: flex; 
		gap: 10px;
	}
}