a {
  color: inherit; }

body {
  box-sizing: border-box;
  margin: 0;
  height: 100%;
  -webkit-font-smoothing: antialiased; }

html {
  height: 100%; }

ul {
  list-style: none;
  margin: 0;
  padding: 0; }

.page {
  background-attachment: inherit, fixed;
  background-blend-mode: soft-light;
  background-color: transparent;
  background-image: url("/img/lines.png"), url("/img/signup.jpg");
  background-position: center center;
  background-repeat: repeat, no-repeat;
  background-size: auto, cover;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center; }
  @media screen and (max-width: 480px) {
    .page.signin, .page.signup, .page.forgotten-password {
      background-image: none;
      background-color: #fff; } }
  .page > .wrapper {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
        flex-direction: column;
    -ms-flex-align: center;
        align-items: center; }
    @media screen and (max-width: 480px) {
      .page > .wrapper {
        padding: 0; } }
  @media screen and (max-width: 480px) {
    .page .card {
      margin: 0;
      padding: 32px 16px;
      border-radius: 0; } }

h2, h3 {
  margin: auto;
  text-align: center; }

h2 {
  text-transform: uppercase;
  color: #2f2f2f; }
  h2.alone {
    margin: 48px auto;
    font-size: 2em; }
    @media screen and (max-width: 480px) {
      h2.alone {
        display: none; } }

h3 {
  font-weight: normal;
  line-height: 1.3;
  margin-top: 16px;
  margin-bottom: 48px;
  max-width: 864px; }

.highlight {
  background-color: rgba(255, 255, 255, 0.8); }

.floating {
  background-color: #fff;
  min-width: 480px;
  padding-top: 32px;
  margin-bottom: 48px; }
  .floating p {
    text-align: center;
    margin-bottom: 24px; }
  .floating .title {
    padding-bottom: 16px; }
    @media screen and (min-width: 480px) {
      .floating .title {
        display: none; } }
  .floating form {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
        flex-direction: column; }
    .floating form hr {
      border: none;
      height: 0;
      width: 0;
      margin: 8px auto; }
    .floating form input[type="submit"] {
      font-size: 1em;
      transition: ease-in-out .25s;
      transition-property: background-color, color; }
      .floating form input[type="submit"].facebook {
        background-color: #3b5998; }
      .floating form input[type="submit"][disabled] {
        background-color: #dcdcdc;
        color: #aeaeae;
        cursor: default; }
    .floating form .title-birthday {
      padding: 0 1.2rem; }
    .floating form .line.civility {
      display: -ms-flexbox;
      display: flex;
      -ms-flex-align: center;
          align-items: center;
      height: 40px;
      padding: 0 1.2rem;
      opacity: 1;
      -ms-flex-direction: initial;
          flex-direction: initial;
      -ms-transform: opacity ease-in-out .25s;
          transform: opacity ease-in-out .25s; }
      .floating form .line.civility.hidden {
        opacity: 0; }
      .floating form .line.civility input[type="radio"] + label {
        color: #888888;
        font-size: .9em; }

.error-reporting {
  height: 32px;
  margin-bottom: 16px;
  overflow: hidden;
  position: relative;
  transition: ease-in-out 250ms;
  transition-property: height, margin-bottom; }
  .error-reporting::after {
    background: url(/img/loader.svg) center center no-repeat;
    background-size: contain;
    content: '';
    opacity: 0;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    transition: opacity ease-in-out 250ms 0; }
  .error-reporting .message {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
        align-items: center;
    -ms-flex-pack: center;
        justify-content: center;
    font-size: .9em;
    font-weight: bold;
    opacity: 1;
    -ms-transform: translate(0);
        transform: translate(0);
    transition: ease-in-out 250ms 150ms;
    transition-property: opacity transform; }
    .error-reporting .message.hidden, .error-reporting .message.prepare-to-hide {
      opacity: 0;
      transition-delay: 0; }
    .error-reporting .message.hidden {
      -ms-transform: translateX(0.5em);
          transform: translateX(0.5em); }
    .error-reporting .message::before {
      font-family: "FontAwesome";
      font-size: 1.5em;
      margin-right: 8px; }
    .error-reporting .message[data-type='error'] {
      color: #ef4836; }
      .error-reporting .message[data-type='error']::before {
        content: '\f06a'; }
    .error-reporting .message[data-type='success'] {
      color: #30af50; }
      .error-reporting .message[data-type='success']::before {
        content: '\f058'; }
  .error-reporting.pending::after {
    opacity: 1;
    transition-delay: 150ms; }
  .error-reporting.hidden {
    height: 0;
    margin-bottom: 0;
    transition-delay: 150ms;
    transition-duration: 250ms; }

.tools {
  box-sizing: border-box;
  display: -ms-flexbox;
  display: flex;
  font-size: .8em;
  width: 100%;
  -ms-flex-pack: justify;
      justify-content: space-between;
  padding: 8px; }

form[data-action="signup"] ~ .tools {
  -ms-flex-pack: center;
      justify-content: center; }

.or {
  background-color: #d5d5d5;
  margin-right: auto;
  margin-left: auto; }

.confirmPasswordBlock {
  position: relative; }
  .confirmPasswordBlock .confirmPasswordPicto {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 25px;
    margin: auto;
    height: 20px;
    font-size: 20px;
    line-height: 1; }
    .confirmPasswordBlock .confirmPasswordPicto::before {
      content: '\f06e';
      font-family: "FontAwesome"; }
    .confirmPasswordBlock .confirmPasswordPicto:hover {
      cursor: pointer;
      color: #00a6d5; }
  .confirmPasswordBlock .confirmPasswordInput {
    display: block;
    width: calc(100% - 20px); }
  .confirmPasswordBlock.visible .confirmPasswordPicto::before {
    content: '\f070';
    font-family: "FontAwesome"; }

.forgotten-password .floating p {
  margin: 0; }

.forgotten-password hr {
  border: none;
  height: 0;
  width: 0;
  margin: 8px auto; }
