html, body, main, main > div {
  margin: 0;
  padding: 0;
  height: 100%;
}

body {
  font-family: "PT Serif", "Georgia", "Helvetica Neue", Helvetica, Arial, sans-serif;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -moz-font-feature-settings: "liga" on;
  color: rgba(0, 0, 0, .84);
  font-size: 19px;
  letter-spacing: 0;
}

.container-fluid, .container {
  height: 100%;
  max-width: 750px;
  padding-left: 30px;
  padding-right: 30px;
}

.header {
  height: 240px;
}

.body {
  flex-grow: 1;
}

.footer {
  color: #999;
  font-style: italic;
  text-align: center;
  font-size: 12px;
  height: 70px;
}

.header, .body, .footer {
  flex-shrink: 0;
}

.logo {
  margin: 0 auto;
  vertical-align: middle;
  text-align: center;
  height: 85.7px;
}

.logo img {
  width: 300px;
}

.pointer {
  cursor: pointer;
}

a#copied {
  color: #333;
  text-decoration: none;
}

.addr {
  width: 186px;
}

a, a:focus, a:hover, a:visited {
  color: rgba(0, 0, 0, .84);
}

.action, .action:hover {
  cursor: pointer;
  color: #000;
  background-image: linear-gradient(to right, #333 40%, rgba(255, 255, 255, 0) 20%);
  background-position: bottom;
  background-size: 5px 1px;
  background-repeat: repeat-x;
  text-decoration: none;
}

dl {
  font-size: 18px;
}

@media (max-width: 480px) {
  body {
    font-size: 15px;
  }

  .p-3 {
    padding: .4rem !important;
  }

  .pt-4, .py-4 {
    padding-top: .75rem !important;
  }

  .pb-5, .py-5 {
    padding-bottom: 1.25rem !important;
  }

  .header {
    height: 130px;
    padding-top: 20px;
  }

  .logo img {
    width: 75%;
  }

  .body {
    align-items: start !important;
  }

  .btn {
    font-size: .85rem !important;
  }

  dl {
    font-size: 16px;
  }

  dt.col-2 {
    flex: 0 0 23%;
    max-width: 23%;
  }

  dd.col-10 {
    flex: 0 0 77%;
    max-width: 77%;
  }

  #projects > div {
    padding: .5rem !important;
  }
}
