@charset "UTF-8";
/* Welcome to Compass.
 * In this file you should write your main styles. (or centralize your imports)
 * Import this file using the following HTML or equivalent:
 * <link href="/stylesheets/screen.css" media="screen, projection" rel="stylesheet" type="text/css" /> */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline; }

html {
  line-height: 1; }

ol, ul {
  list-style: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle; }

q, blockquote {
  quotes: none; }
  q:before, q:after, blockquote:before, blockquote:after {
    content: "";
    content: none; }

a img {
  border: none; }

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block; }


body {
	margin: 0;
	padding: 0;
	font-family: 'Maven Pro', sans-serif;
	height: 100%;
	width: 100%;
	-webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Partie - Informations */
.container-infos {
	width: calc(100% - 400px);
	height: auto;
	float:left;
	position: relative;
}

.container-presentation {
	float: left;
	width: 100%;
    height: 950px;
    margin: 0 auto;
    overflow: hidden;
    display: inline-block;
    position: relative;
}

.container-presentation .block-titre {
	height: auto;
	width: 75%;
	display: table;
	position: absolute;
	z-index: 2;
	top: 50%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}

.container-presentation .block-titre h2 {
	font-size: 20px;
	display: block;
	font-weight: 500;
	margin-bottom: 10px;
	text-align: left;
	color:white;
	text-transform: uppercase;
	margin-left: 40px;
}

.container-presentation .logo-keyfast {
	display: block;
	width: 434px;
	height: 75px;
	background: url(../images/login/keyfast-logo-white.svg) no-repeat 50% 50%;
	margin-left: 40px;
}

.container-presentation .separator {
	width: 100%;
	height: 1px;
	background: red;
	display: block;
	margin:20px 0;
}

.container-presentation .separator:before {
	content: "";
    width: 7px;
    height: 7px;
    background: red;
    border-radius: 50%;
    position: relative;
    display: block;
    top: -3px;
    right: 0;
    left: 0;
    float: right;
}

.container-presentation .block-titre p {
	font-size: 20px;
	line-height: 24px;
	display: block;
	font-weight: 500;
	margin-bottom: 10px;
	text-align: left;
	color:white;
	margin-left: 40px;
}

.container-presentation .block-titre .txt-link {
	font-size: 16px;
	display: block;
	font-weight: 500;
	margin-bottom: 10px;
	text-align: left;
	color:white;
	margin-left: 40px;
}

.container-presentation .link-site-keyfast {
	font-family: 'Maven Pro', sans-serif;
	width: 170px;
	display: block;
	margin:20px 0 0 40px;
	color:white;
	text-align: left;
	text-transform: uppercase;
	font-size: 14px;
	font-weight: 700;
	border:none;
	padding: 20px;
	outline:none;
	text-decoration: none;
	cursor: pointer;
	background: #AE1732 url(../images/login/icon-arrow-white.svg) no-repeat 85% 50%;
	-moz-border-radius: 5px;
  	-webkit-border-radius: 5px;
 	border-radius: 5px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	-webkit-transition-duration: 0.35s;
	-moz-transition-duration: 0.35s;
	transition-duration: 0.35s;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.container-presentation .link-site-keyfast:hover {
	background: #EA2044 url(../images/login/icon-arrow-white.svg) no-repeat 85% 50%;
}

.container-presentation img {
	position: relative;
    max-height: 100%;
    left: 100%;
    -moz-transform: translateX(-100%);
    -ms-transform: translateX(-100%);
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
}

.container-partenaires {
	float:left;
	width: 50%;
	height: 400px;
	padding: 30px;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.container-partenaires .content {
	display: block;
	height: auto;
	margin:0 auto;
	width: 100%;
	position: relative;
	top: 50%;
	transform: translateY(-50%);
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.container-partenaires h3 {
	font-weight: 700;
	color:#54606B;
	font-size: 16px;
	letter-spacing: 1px;
	text-align: center;
	display: block;
	text-transform: uppercase;
	margin-bottom: 30px;
}

.container-partenaires img {
	max-width: 427px;
	display: block;
	margin: 0 auto;
	height: auto;
	width: 100%;
}

.container-share {
	float:left;
	width: 50%;
	height: 400px;
	position: relative;
	background-image: -webkit-linear-gradient(#D72242 0%, #AE1732 100%);
	background-image: -o-linear-gradient(#D72242 0%, #AE1732 100%);
	background-image: linear-gradient(#D72242 0%, #AE1732 100%);
}

.container-share .content-texte{
	display: block;
	height: auto;
	margin:0 auto;
	width: 100%;
	padding: 30px;
	position: relative;
	top: 50%;
	transform: translateY(-50%);
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.container-share .content-texte h3 {
	font-size: 22px;
	letter-spacing: 1px;
	line-height: 26px;
	color:white;
	font-weight: 900;
	text-transform: uppercase;
	text-align: center;
	margin-bottom: 20px;
}

.container-share .content-texte p {
	font-size: 18px;
	line-height: 23px;
	font-weight: 400;
	color:white;
	text-align: center;
}

.container-share .content-texte a {
	font-weight: 700;
	text-decoration: none;
	color:white;
}

.container-footer {
	width: 100%;
	height: auto;
	background: #F6F6F6;
	display: inline-block;
	text-align: center;
}
.container-footer .helpline {
	display: inline-block;
	height: auto;
	width: auto;
	margin: 45px 0 30px 0;
}
.container-footer .helpline p{
	font-size:20px;
	line-height: 20px;
	color:#333333;
	display: inline-block;
	margin-left: 8px;
}
.container-footer .helpline h2{
	color:#AE1732;
	display: inline-block;
	font-size: 22px;
}
.container-footer .contact-mail {
	text-decoration: none;
	font-size: 20px;
	line-height: 20px;
	color:#333333;
	display: inline-block;
	margin-left: 20px;
	padding-left: 20px;
	background: url(../images/login/icon-mail-red.svg) no-repeat 0% 50%;
	-webkit-transition-duration: 0.35s;
	-moz-transition-duration: 0.35s;
	transition-duration: 0.35s;
}
.container-footer .contact-mail:hover {
	color:#AE1732;
}
.container-footer .container-copyright {
	display: block;
	height: auto;
	border-top:1px solid #D6DBE0;
	padding: 30px;
	text-align: center;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
.container-footer .container-copyright p {
	font-size: 13px;
	line-height: 15px;
	color:#333333;
	text-align: center;
	margin-bottom: 15px;
}


/* Partie - Connexion */

.container-login {
	width: 400px;
	float:right;
	height: auto;
	background: white;
	position: relative;
}

.container-login .bloc-connexion {
	padding: 30px;
	position: fixed;
	width: 400px;
	top: 15%;
	right: 0;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.container-login .bloc-connexion .logo {
	width:244px;
	height: 43px;
	display: block;
	margin:0 auto 30px auto;
	background: url(../images/login/keyfast-logo-color.svg) no-repeat 50% 50%;
}

.container-login .bloc-connexion .logo-norton {
	width:158px;
	height: 85px;
	display: block;
	background: url(../images/login/logo-norton.png) no-repeat 50% 50%;
	background-size:158px 85px;
	margin:35px auto 0 auto;
}

/* Partie - Connexion - Input - Login */
.input-login {
	width: 100%;
	border-radius: 5px;
	border: 1px solid #D6DBE0;
	height: 45px;
	margin-bottom: 20px;
	margin-top: 20px;
    padding: 10px;
    outline:none;
    font-size: 14px;
    color:#333333;
    background: url(../images/login/icon-user.svg) no-repeat 95% 50%;
	-webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    -moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition-duration: 0.35s;
	-moz-transition-duration: 0.35s;
	transition-duration: 0.35s;
}
.input-login:focus {
	border: 1px solid #A71329;
	color: #A71329;
	background: url(../images/login/icon-user-red.svg) no-repeat 95% 50%;
}

.input-login::-webkit-input-placeholder {color: #54606B;}
.input-login::-moz-placeholder {color: #54606B;}
.input-login::-ms-input-placeholder {color: #54606B;}
.input-login:-moz-placeholder {color: #54606B;}

/* Partie - Connexion - Input - Mot de passe */
.input-mdp {
	width: 100%;
	border-radius: 5px;
	border: 1px solid #D6DBE0;
	height: 45px;
	margin-bottom: 20px;
    padding: 10px;
    outline:none;
    font-size: 14px;
    color:#333333;
    background: url(../images/login/icon-mdp.svg) no-repeat 95% 50%;
	-webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    -moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition-duration: 0.35s;
	-moz-transition-duration: 0.35s;
	transition-duration: 0.35s;
}
.input-mdp:focus {
	border: 1px solid #A71329;
	color: #A71329;
	background: url(../images/login/icon-mdp-red.svg) no-repeat 95% 50%;
}

.input-mdp::-webkit-input-placeholder {color: #54606B;}
.input-mdp::-moz-placeholder {color: #54606B;}
.input-mdp::-ms-input-placeholder {color: #54606B;}
.input-mdp:-moz-placeholder {color: #54606B;}

.input-email {
	width: 100%;
	border-radius: 5px;
	border: 1px solid #D6DBE0;
	height: 45px;
	margin-bottom: 20px;
	margin-top: 20px;
    padding: 10px;
    outline:none;
    font-size: 14px;
    color:#333333;
    background: url(../images/login/icon-mail.svg) no-repeat 95% 50%;
	-webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    -moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition-duration: 0.35s;
	-moz-transition-duration: 0.35s;
	transition-duration: 0.35s;
}
.input-email:focus {
	border: 1px solid #A71329;
	color: #A71329;
	background: url(../images/login/icon-mail-red.svg) no-repeat 95% 50%;
}

.input-email::-webkit-input-placeholder {color: #54606B;}
.input-email::-moz-placeholder {color: #54606B;}
.input-email::-ms-input-placeholder {color: #54606B;}
.input-email:-moz-placeholder {color: #54606B;}

/* Partie - Connexion - Input - Checkbox */
.input-row {
    float:left;
    width: 100%;
    margin-bottom: 20px;
    margin-top: 5px;
}
.input-helper {
  position: relative;
  display: inline-block;
  margin-bottom: 5px;
  cursor: pointer;
}
.input-helper:before {
  content: '';
  display: block;
  position: absolute;
}
.input-helper--checkbox {
  padding-left: 30px;
  color:#333333;
  line-height: 28px;
  font-size: 13px;
}
.input-helper--checkbox:before {
  top: 2px;
  left: 0;
  width: 20px;
  height: 20px;
  border: 1px solid #D6DBE0;
  -moz-border-radius: 3px;
  -webkit-border-radius: 3px;
  border-radius: 3px;
  background-position: 50% 50%;
  -webkit-transition-duration: 0.35s;
  -moz-transition-duration: 0.35s;
  transition-duration: 0.35s;
}
input[type="checkbox"] {
  display: none;
}
input[type="checkbox"]:checked + label:before {
  background: #EA2044 url(../images/login/icon-check-white.svg) no-repeat 50% 50%;
  border:1px solid #EA2044;
}

/* Partie - Connexion - Lien - Mot de passe oublié */
#link-forgot {
    float: right;
    margin-top: -7px;
}
.link-forgot-mdp {
	float:right;
	color:#A71329;
	font-size: 13px;
	padding-right: 30px;
	background: url(../images/login/icon-arrow-red.svg) no-repeat 100% 50%;	
	text-decoration: none;
	outline: none;
	position: relative;
	top: 7px;
	-webkit-transition-duration: 0.35s;
	-moz-transition-duration: 0.35s;
	transition-duration: 0.35s;
}
.link-forgot-mdp:hover {
	padding-right: 35px;
}

.link-forgot-id {
	float:right;
	color:#A71329;
	font-size: 13px;
	padding-right: 30px;
	background: url(../images/login/icon-arrow-red.svg) no-repeat 100% 50%;	
	text-decoration: none;
	outline: none;
	position: relative;
	top: 7px;
	-webkit-transition-duration: 0.35s;
	-moz-transition-duration: 0.35s;
	transition-duration: 0.35s;
}
.link-forgot-id:hover {
	padding-right: 35px;
}

/* Partie - Connexion - Input - Submit */
.input-connexion {
	font-family: 'Maven Pro', sans-serif;
	display: block;
	margin: 0 auto;
	color:white;
	background: #AE1732;
	text-align: center;
	text-transform: uppercase;
	font-size: 14px;
	font-weight: 700;
	border:none;
	padding: 20px;
	outline:none;
	text-decoration: none;
	cursor: pointer;
	-moz-border-radius: 5px;
  	-webkit-border-radius: 5px;
 	border-radius: 5px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	-webkit-transition-duration: 0.35s;
	-moz-transition-duration: 0.35s;
	transition-duration: 0.35s;
}
.input-connexion:hover {
	background: #EA2044;
}

/* RESPONSIVE */
@media screen and (max-width: 1150px) {
	.container-partenaires {
		width: 100%;
		border-right: 1px solid #D6DBE0;
	}
	.container-share {
		width: 100%;
	}
	.container-footer .helpline {
		padding: 20px 20px 20px 0;
		margin: 15px 0 15px 0;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}
	.container-footer .helpline {
		margin-left: 0;
		margin-bottom: 0;
	}
	.container-footer .helpline p {
		font-size: 16px;
	}
	.container-footer .helpline h2 {
		font-size: 20px;
	}
	.container-footer .contact-mail {
		margin-bottom: 30px;
		font-size: 18px;
	}
}
@media screen and (max-width: 950px) {
	.container-share .content-texte h3 {
		font-size: 18px;
	}
	.container-presentation .block-titre {
		width: 95%;
	}
	.container-presentation .logo-keyfast {
		background-size:280px 50px;
		width: 280px;
		height: 50px;
	}
}
@media screen and (max-width: 768px) {
	.container-infos {
		display: none;
	}
	.container-login {
		float:none;
		width: 100%;
		height: auto;
	}
	.container-login .bloc-connexion {
		position: initial;
		margin:  10px auto;
		width: 100%;
		max-width: 400px;
	}
	.container-login .bloc-connexion .logo {
		margin: 0 auto 15px auto;
	}
}

#login-mc {
    text-align: center;
    background-color: #B9364D;
	color: white;
	padding: 10px 25px;
	font-size: 13px;
	animation: shake 0.4s cubic-bezier(0.36, 0.07, 0.19, 0.97) both;
}

#login-title {
    text-align: center;
    color: #B9364D;
    font-size: 1.5em;
}

/* ------------------------------------------- ANIMATION ------------------------------------------- */

@keyframes shake {
	10%, 90% {
		transform: translate3d(-1px, 0, 0);
	}

	20%, 80% {
		transform: translate3d(2px, 0, 0);
	}

	30%, 50%, 70% {
		transform: translate3d(-4px, 0, 0);
	}

	40%, 60% {
		transform: translate3d(4px, 0, 0);
	}
}
