.event-calendar__controls {
  display: flex;
  justify-content: center;
}
.event-calendar__controls h1 {
  margin-top: 20px;
}
.event-calendar__controls a {
  height: 10px;
  margin: 25px;
  color: black;
  display: flex;
}
.event-calendar__controls a svg {
  margin: 0 10px;
}
.event-calendar .calendar {
  /* Grid Fallback */
  display: flex;
  flex-wrap: wrap;
  /* Supports Grid */
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  grid-auto-rows: minmax(150px, auto);
  grid-gap: 0.1em;
  /* If Grid is supported, remove the margin we set for the fallback */
}
.event-calendar .calendar .day {
  background: #eaeaea;
  height: 200px;
  padding: 5px;
  margin-left: 5px;
  margin-right: 5px;
  flex: 1 1 200px;
}
.event-calendar .calendar .day ul {
  background: #D32F27;
  color: white;
}
.event-calendar .calendar .day li {
  padding: 5px;
}
@supports (display: grid) {
  .event-calendar .calendar .day {
    margin: 0;
  }
}

:root {
  box-sizing: border-box;
  font-family: sans-serif;
  font-size: 1em;
}

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

body, h1, h2, h3, h4, h5, h6, p, ol, ul {
  margin: 0;
  padding: 0;
  font-weight: normal;
}

ul {
  list-style: none;
}