:root {
    --white: #f8f1eb;
    --pistachio: #d5e1d1;
    --green: #546438;
    --black: #333333;
    --green-font: #697b40;
  }

* {
    font-family: Helvetica, sans-serif;
    font-weight: lighter;
    letter-spacing: 2px;
    word-spacing: 1.5px;
    line-height: 1.5;
    font-size: 16px;
}

body {
    background-color: black;
    padding: 0;
    margin: 0;
}

main {
    background-color: var(--white);
    margin: 0 auto;
    color: var(--green-font);
    padding: 2em;
}

.green {
    background-color: var(--green);
    padding: 2em;
    color: var(--white);
}

#header {
    margin: -2em -2em 0 -2em;
}

#footer {
    margin: 0 -2em -2em -2em;
}

.green > strong {
    font-weight: 500;
    font-size: 1.2em;
}

h1 {
    font-size: 1.4em;
    font-style: italic;
    letter-spacing: 2.4px;
    margin-top: 2em;
}

b {
    font-weight: 400;
}

#address-wrapper {
  margin: 0 auto 0 auto;
}

.address, .contact {
  display: block;
  width: 50%;
  text-decoration: none;
  float: left;
}

.contact span, .contact a, a {
  color: var(--green-font);
}

.contact a:hover {
  background-color: var(--pistachio);
}

@media only screen and (max-width: 980px) and (orientation: portrait) {
  .address, .contact {
    width: 100%;
  }
}

.address a p, .contact p {
  margin: 0;
  padding: 2em;
  color: var(--green-font);
}

.address a strong, .contact strong {
  font-weight: 400;
  line-height: 1;
}

.address a, .contact > a {
  display: block;
  width: 100%;
  text-decoration: none;
}

.address a:hover, .contact > a:hover {
  background-color: var(--pistachio);
}

#timelineblock, #geschenkblock {
    clear: both;
}

#footer {
    padding-bottom: 10em;
}

#footer img {
    width: 60%;
    max-width: 25em;
}

#header img {
  width: 30%;
  max-width: 15em;
}

/* Beginn timeline */

*,
*::before,
*::after {
  box-sizing: border-box;
}

.timeline {
  position: relative;
  width: 100%;
  max-width: 1140px;
  margin: 0 auto;
  padding: 15px 0;
}

.timeline::after {
  content: '';
  position: absolute;
  width: 2px;
  background: var(--green-font);
  top: 0;
  bottom: 0;
  left: 50%;
  margin-left: -1px;
}

.container {
  padding: 15px 30px;
  position: relative;
  background: inherit;
  width: 50%;
}

.container.left {
  left: 0;
}

.container.right {
  left: 50%;
}

.container::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  top: calc(50% - 8px);
  right: -8px;
  background: var(--white);
  border: 2px solid var(--green-font);
  border-radius: 16px;
  z-index: 1;
}

.container.right::after {
  left: -8px;
}

.container::before {
  content: '';
  position: absolute;
  width: 50px;
  height: 2px;
  top: calc(50% - 1px);
  right: 8px;
  background: var(--green-font);
  z-index: 1;
}

.container.right::before {
  left: 8px;
}

.container .date {
  height: 50%;
  position: absolute;
  display: inline-block;
  top: 25%;
  text-align: center;
  font-size: 14px;
  font-weight: bold;
  color: blue;
  text-transform: uppercase;
  letter-spacing: 1px;
  z-index: 1;
}
  
.container.left .date {
  right: calc(-75px - 3em);
}
  
.container.right .date {
  left: calc(-75px - 3em);
}

.container .icon {
  position: absolute;
  display: inline-block;
  width: 40px;
  height: 40px;
  padding: 9px 0;
  top: calc(50% - 20px);
  background: var(--pistachio);
  border: 2px solid var(--green-font);
  border-radius: 40px;
  text-align: center;
  font-size: 18px;
  color: black;
  z-index: 1;
}

.container.left .icon {
  right: 56px;
}

.container.right .icon {
  left: 56px;
}

.container .content {
  padding: 30px 90px 30px 30px;
  background: var(--pistachio);
  position: relative;
  border-radius: 0 500px 500px 0;
}

.container.right .content {
  padding: 30px 30px 30px 90px;
  border-radius: 500px 0 0 500px;
}

.container .content h2 {
  margin: 0 0 10px 0;
  font-size: 1em;
  color: var(--black);
}
  
.container .content p {
  margin: 0;
  font-size: 1.2em;
  color: var(--black);
}

@media (max-width: 767.98px) {
  .timeline::after {
    left: 90px;
  }

  .container {
    width: 100%;
    padding-left: 120px;
    padding-right: 30px;
  }

  .container.right {
    left: 0%;
  }

  .container.left::after, 
  .container.right::after {
    left: 82px;
  }

  .container.left::before,
  .container.right::before {
    left: 100px;
    border-color: transparent #006E51 transparent transparent;
  }

  .container.left .date,
  .container.right .date {
    right: auto;
    left: 15px;
  }

  .container.left .icon,
  .container.right .icon {
    right: auto;
    left: 146px;
  }

  .container.left .content,
  .container.right .content {
    padding: 30px 30px 30px 90px;
    border-radius: 500px 0 0 500px;
  }
}

/* Ende timeline */

#telefon_HB::after {
    content: "+49 173 9236330";
  }
#email_HB::after {
    content: "hannah-becker@t-online.de";
  }

#telefon_MD::after {
    content: "+49 173 8439349";
  }
#email_MD::after {
    content: "malteduis@gmx.de";
  }

#telefon_EL::after {
    content: "+49 172 8267043";
  }
#email_EL::after {
    content: "e.leonardy@gmx.de";
  }

#fotoblock {
  background-color: var(--pistachio) !important;
  padding: 1em 2em;
  font-weight: bold;
  border: 1px solid var(--pistachio);
}