/* CSS Vars */
:root {
  --primary-blue: #0087ca;
  --highlight-green: #D2F190;
  --warning-red: #DA1C5C;
  --general-spacing: 3rem;
}

main {
  max-width: 100%;
}

/* Solution banner */
.solution__banner {
  position: relative;
}

.solution__banner-image {
  max-width: 100%;
}

.solution__banner h1 {
  position: absolute;
  line-height: var(--general-spacing);
  top: calc(50% - (var(--general-spacing)/2));
  left: calc(var(--general-spacing)*2);
  margin: 0;
  color: var(--highlight-green);
  text-shadow: -1px 3px 1px rgba(0, 0, 0, 1);
}

/* Solution lead */
.solution__lead {
  margin-top: calc(var(--general-spacing)*2);
  margin-bottom: calc(var(--general-spacing)*2);
}

.solution-lead__title {
  color: var(--primary-blue);
  text-align: center;
}

.solution-lead__description {
  font-size: 18px;
}

/* Solution item */
.solution-item {
  display: flex;
  margin-top: var(--general-spacing);
}

.solution-item__text {
  flex-basis: 60%;
  flex-shrink: 0;
}

.solution-item__image {
  max-width: 50%;
}

.solution-item__image img {
  max-width: 100%;
  margin: 0;
}

.solution-item.text--left {
  flex-direction: column-reverse;
}

@media only screen and (min-width: 768px) {
  .solution-item.text--left {
    flex-direction: row;
  }
}

.solution-item.text--right {
  flex-direction: column-reverse;
}

@media only screen and (min-width: 768px) {
  .solution-item.text--right {
    flex-direction: row-reverse;
  }
  .solution-item.text--left .solution-item__text {
    margin-right: var(--general-spacing);
  }
  
  .solution-item.text--right .solution-item__text {
    margin-left: var(--general-spacing);
  }
}


.solution-item__title, 
.solution-item__summary {
  color: var(--primary-blue);
}

.solution-item__title {
  margin-top: 0;
}

.solution-item__summary {
  font-style: italic;
}

/* Solution quote */
.solution-quote {
  margin-top: var(--general-spacing);
  border-left-width: 0px;
}

.solution-quote__body,
.solution-quote__author {
  color: var(--warning-red);
  text-align: center;
  font-style: italic;
}

/* Solution list page */
.solution__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-evenly;
  margin-top: calc(var(--general-spacing)*2);
}

/* Solution card */
.solution-card {
  border: 1px solid var(--primary-blue);
  border-radius: 2px;
  padding: var(--general-spacing);
  margin: var(--general-spacing);
}

.solution-card__title {
  margin: 0;
}
