@import url('https://fonts.googleapis.com/css?family=Alegreya+SC:400,400i');

.card {
  font-family: 'Alegreya SC', serif;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.3em;
  line-height: 2;
  color: #010101;
  background: #ffffff url("invitation-1.svg") no-repeat top center;
  background-size: cover;
  padding: 180px 0 0;
}

.host {
  width: 75%;
  margin: 0 auto;
}

.couple {
  font-size: 57px;
  margin: 0;
}

.couple__firstname,
.couple__lastname {
  display: block;
}

.couple__lastname {
  font-size: 19px;
}

.couple__delimiter {
  font-size: 38px;
}

.request,
.datetime,
.location {
  margin: 20px 0;
}

.datetime__date {
  display: block;
  font-size: 38px;
  line-height: 1;
}

.reception {
  font-style: italic;
}

.link,
.button {
  font-size: 19px;
}

.link {
  padding: 15px 0;
}

.button {
  padding: 15px 15px 15px 18px;
  background: #010101;
}

/* Variations */

.v1 .card {
  background-size: contain;
}

.v2 .card {
  background-image: url("invitation-2.svg");
  padding: 115px 0;
}

.v3 .card {
  background-image: url("invitation-3.svg");
  padding: 95px 0 115px;
}

.v4 .card {
  background-image: url("invitation-4.svg");
  padding: 110px 0 100px;
}

/* Simplified */

.is-simple .card {
  background-image: none;
  padding: 115px 0;
}

/* Responsive */

@media (min-width: 480px) {
  .v1 .card {
    padding: 180px 75px 0;
  }

  .v3 .card {
    padding: 95px 75px 115px;
  }
}