@page { size: letter; margin: 0.45in 0.6in; }
* { box-sizing: border-box; }
body {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  color: #1a1a1a;
  font-size: 9.3pt;
  line-height: 1.28;
  margin: 0;
}
header { margin-bottom: 6px; }
h1 {
  font-size: 18pt;
  margin: 0 0 2px 0;
  letter-spacing: 0.4px;
}
.title { font-size: 10pt; color: #333; margin-bottom: 3px; }
.contact { font-size: 8.5pt; color: #444; }
.contact span { white-space: nowrap; }
.sep { color: #aaa; padding: 0 5px; }
h2 {
  font-size: 9.6pt;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  border-bottom: 1.2px solid #333;
  padding-bottom: 2px;
  margin: 9px 0 4px 0;
}
.summary { margin: 0; text-align: justify; }
.job-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 4px;
}
.role { font-weight: bold; }
.company { font-weight: bold; }
.dates { color: #555; font-size: 8.7pt; white-space: nowrap; }
.scope { margin: 2px 0 1px 0; }
.subhead { font-style: italic; color: #333; margin: 3px 0 1px 0; }
ul { margin: 1px 0 3px 0; padding-left: 16px; }
li { margin-bottom: 1.5px; }
.skills p { margin: 1px 0; }
.skills b { display: inline-block; min-width: 80px; }
.edu-line { display: flex; justify-content: space-between; align-items: baseline; }
strong { font-weight: bold; }
sup { font-size: 70%; }

@media screen {
  body {
    background: #e9e9e9;
    padding: 32px 20px;
  }

  body > * {
    background: white;
    max-width: 850px;
    margin: 0 auto;
    padding: 0.38in 0.5in;

    border: 1px solid #d6d6d6;
    box-shadow: 0 10px 28px rgba(0,0,0,0.08);
  }
}

@media screen and (max-width: 600px) {
  body {
    background: white;
    padding: 0;
  }

  body > * {
    border: none;
    box-shadow: none;
    padding: 16px;
    margin: 0;
  }
}

@media print {
  body {
    background: white;
    padding: 0;
  }

  body > * {
    border: none;
    box-shadow: none;
    margin: 0;
    padding: 0;
  }
}