html {
  scroll-behavior: smooth;
}

body {
  color: white;
  background-color: hsl(226, 23%, 11%);
  margin: 0 auto;
  /*font-family: "Roboto Flex", -apple-system, "system-ui", sans-serif;*/
  font-family: "Montserrat", ui-sans-serif, system-ui, sans-serif;
  font-weight: 300;
  max-width: 1480px;
}

aside {
  background-color: rgb(30, 35, 50);
}

progress {
  width: 100%;
}

progress[value].green {
  accent-color: green;
}

a {
  color: unset;
  text-decoration: none;
}

p {
  font-weight: 400;
}

h1 {
  font-weight: 400;
  margin: 0;
  padding: 0;
  letter-spacing: 2px;
}

h2 {
  font-weight: 500;
  font-size: 300%;
  margin: 0;
  padding: 0;
  letter-spacing: 2px;
}

h4 {
  font-weight: 500;
  margin-bottom: 0;
}

h5 {
  font-weight: 500;
  margin-top: 0.25em;
  color: #bcbdd0;
}

.float-right {
  float: right;
}

.color-tint {
  color: #bcbdd0;
}

@media only screen and (min-width: 320px) {

  header > h3 {
    text-transform: uppercase;
    font-size: 110%;
    font-weight: 500;
    border-bottom: 1px solid #bcbdd0;
    margin: 0;
    padding: 0.5em 0;
  }

  aside .profile-picture figure {
    margin-top: 0;
    padding-top: 1em;
  }

  aside .information {
    padding: 1em 1.75em;
  }

  aside .information .icon {
    margin-right: 1em;
    font-size: 110%;
  }

  aside .information .education p {
    padding: 0.5em 0;
  }

  aside .profile-picture img {
    display: block;
    width: 80%;
    max-width: 300px;
    border-radius: 50%;
    box-shadow: 0 0 10px 3px rgba(0,0,0,0.5);
    margin: 0 auto;
  }

  aside .awards > div {
    padding: 0.25em 0;
  }

  aside .awards > div p:nth-of-type(2) {
    padding-top: 0.5em;
  }

  aside > footer {
    position: relative;
    text-align: center;
    padding: 1em;
  }

  aside > footer::before {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    width: 50%;
    left: 25%;
    border-top: 1px solid #bcbdd0;
  }

  aside > footer img {
    width: 33%;
    max-width: 125px;
  }

  main {
    padding: 0 2em;
    margin-top: 2em;
  }

  main > header p {
    margin: 0;
    padding: 0;
    font-weight: 600;
  }

  main > section > div {
    margin-top: 2em;
  }

  main .experience span.float-right {
    float: none;
    opacity: 0.5;
    font-weight: 400;
  }

  main .experience a {
    font-weight: 500;
    text-decoration: underline;
  }

  main .experience > div > div {
    margin-bottom: 1.5em;
  }

  main .experience > div.professional > div header {
    display: grid;
    grid-template-columns: 50px auto;
    place-items: end stretch;
  }

  main .experience > div > div header img {
    width: 40px;
  }

  main .experience div header h5 {
    margin-bottom: 0;
  }
}

@media only screen and (min-width: 480px) {
  main .experience span.float-right {
    float: right;
  }
}

@media only screen and (max-width: 768px) {
  main .experience span.float-right {
    display: block;
    width: 100%;
    text-align: right;
  }

  main .experience > div.professional > div header {
    display: grid;
    grid-template-columns: 50px auto;
    place-items: center stretch;
  }
}

@media all and (min-width: 480px) and (max-width: 992px) {
  aside .information .expertise-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 2em;
  }
}

@media all and (max-width: 768px) {

}

@media all and (min-width: 768px) {

}

@media all and (max-width: 992px) {
  main > header h1, main > header h2, main > header p {
    text-align: center;
  }
}

@media all and (min-width: 992px) {
  body {
    display: grid;
    grid-template-columns: minmax(350px, 1fr) 3fr;
    min-height: 100vh;
  }
  
  aside {

  }
}

@media all and (min-width: 1200px) {

}