html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center, dl, dt, dd, ol, ul, li,
fieldset, form, label, legend, table, caption,
tbody, tfoot, thead, tr, th, td, article,
aside, canvas, details, embed, figure, figcaption,
footer, header, hgroup, menu, nav, output,
ruby, section, summary, time, mark, audio, video {
  border: 0;
  font: inherit;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  background: #e2e2e2;
  color: #373737;
  font: 300 15px/1.625 "Helvetica Neue", Helvetica, Arial, sans-serif;
  padding: 0 2em;
}

a {
  color: #e20404;
  text-decoration: none;
}

a:hover,
a:focus,
a:active {
  text-decoration: underline;
}

p {
  margin-bottom: 1.625em;
}

ul, ol {
  margin: 0 0 1.625em 2.5em;
}

ul {
  list-style: square;
}

ol {
  list-style-type: decimal;
}

strong {
  font-weight: 700;
}

em {
  font-style: italic;
}

table {
  border-collapse: collapse;
  margin: 0 0 1.625em;
  width: 100%;
}

th,
td {
  border-top: 1px solid #ddd;
  padding: 6px 10px 6px 0;
  text-align: left;
}

th {
  color: #666;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .1em;
  line-height: 2.6em;
  text-transform: uppercase;
}

#page {
  background: #fff;
  margin: 2em auto;
  max-width: 1000px;
}

#branding {
  padding-bottom: 10px;
  position: relative;
  z-index: 10;
}

#branding hgroup {
  margin: 0 7.6%;
  padding: 60px 40px 20px 80px;
}

.brand-link {
  align-items: center;
  color: #111;
  display: inline-flex;
  gap: 18px;
  text-decoration: none;
}

.brand-mark {
  display: grid;
  gap: 5px;
  grid-template-columns: repeat(5, 8px);
  width: 60px;
}

.brand-mark span {
  background: #e20404;
  border-radius: 999px;
  height: 8px;
  width: 8px;
}

.brand-mark span:nth-child(3n) {
  background: #0073aa;
}

.brand-name {
  color: #aaa;
  display: block;
  font: 400 39px/1 Georgia, "Times New Roman", serif;
  letter-spacing: -1px;
}

.brand-tagline {
  color: #7a7a7a;
  display: block;
  font-size: 13px;
  margin-top: 6px;
}

#branding hr {
  background-color: #ccc;
  border: 0;
  height: 1px;
  margin: 0 7.6% 1.625em;
}

#access {
  clear: both;
  display: block;
  float: left;
  margin: 0 auto 6px;
  width: 100%;
}

#access div {
  margin: 0 7.6%;
}

#access ul {
  font-size: 13px;
  list-style: none;
  margin: 0 0 0 -0.8125em;
  padding-left: 0;
}

#access li {
  float: left;
  position: relative;
}

#access a {
  color: #000;
  display: block;
  line-height: 3.333em;
  padding: 0 1.2125em;
  text-decoration: none;
}

#access li:hover > a,
#access a:focus,
#access .current-menu-item > a {
  background: #f9f9f9;
  background: linear-gradient(#f9f9f9, #e5e5e5);
  color: #373737;
}

#main {
  clear: both;
  padding: 0;
}

#primary {
  float: left;
  margin: 0 -26.4% 0 0;
  width: 100%;
}

#content {
  margin: 0 34% 0 7.6%;
  width: 58.4%;
}

#secondary {
  float: right;
  margin-right: 7.6%;
  width: 18.8%;
}

.post,
.page-article {
  border-bottom: 1px solid #ddd;
  margin: 0 0 3.25em;
  padding: 0 0 1.625em;
}

.post:last-child,
.page-article:last-child {
  border-bottom: 0;
}

.entry-title,
.entry-title a {
  color: #222;
  text-decoration: none;
}

.entry-title {
  clear: both;
  font: 700 26px/1.5 Georgia, "Times New Roman", serif;
  padding-bottom: .3em;
}

.entry-title a:hover,
.entry-title a:focus,
.entry-title a:active {
  color: #e20404;
}

.entry-content,
.entry-summary {
  padding: 1.625em 0 0;
}

.entry-content h2,
.entry-content h3,
.comment-content h2,
.comment-content h3 {
  clear: both;
}

.entry-content h2 {
  color: #000;
  font-weight: 700;
  margin: 0 0 .8125em;
}

.entry-content h3 {
  color: #666;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .1em;
  line-height: 2.6em;
  margin-top: .7em;
  text-transform: uppercase;
}

.entry-meta {
  clear: both;
  color: #666;
  font-size: 12px;
  line-height: 18px;
}

.entry-meta a {
  font-weight: 700;
}

.lead {
  color: #333;
  font-size: 17px;
}

.note-box {
  background: #f9f9f9;
  border-left: 4px solid #e20404;
  color: #333;
  margin: 0 0 1.625em;
  padding: 1em 1.2em;
}

.course-table td:first-child {
  font-weight: 700;
  width: 35%;
}

.cta-line {
  background: #f7f7f7;
  border: 1px solid #ddd;
  margin: 1.625em 0;
  padding: 1em 1.2em;
}

.cta-line a {
  font-weight: 700;
}

#content nav {
  clear: both;
  overflow: hidden;
  padding: 0 0 1.625em;
}

#content nav a {
  font-size: 12px;
  font-weight: 700;
  line-height: 2.2em;
}

.nav-previous {
  float: left;
  width: 50%;
}

.nav-next {
  float: right;
  text-align: right;
  width: 50%;
}

.widget-area {
  font-size: 12px;
}

.widget {
  clear: both;
  margin: 0 0 2.2em;
}

.widget-title {
  color: #666;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .1em;
  line-height: 2.6em;
  text-transform: uppercase;
}

.widget ul {
  font-size: 15px;
  list-style: none;
  margin: 0;
}

.widget ul li {
  color: #777;
  font-size: 13px;
  line-height: 1.6;
}

.widget a {
  font-weight: 700;
  text-decoration: none;
}

.widget a:hover,
.widget a:focus,
.widget a:active {
  text-decoration: underline;
}

.widget_search form {
  margin: 0 0 1.625em;
}

.widget_search input[type="search"] {
  background: #fafafa;
  border: 1px solid #ddd;
  color: #888;
  font-size: 13px;
  padding: 6px 7px;
  width: 77%;
}

.search-results {
  background: #fff;
  border: 1px solid #ddd;
  display: none;
  margin-top: 8px;
  padding: 8px;
}

.search-results a {
  display: block;
  margin: 0 0 6px;
}

#site-generator {
  background: #f9f9f9;
  border-top: 1px solid #ddd;
  clear: both;
  color: #666;
  font-size: 12px;
  line-height: 2.2em;
  padding: 2.2em .5em;
  text-align: center;
}

#site-generator a {
  color: #555;
  font-weight: 700;
}

.clear {
  clear: both;
}

@media (max-width: 800px) {
  #main #content {
    margin: 0 7.6%;
    width: auto;
  }

  #main #secondary {
    float: none;
    margin: 0 7.6%;
    width: auto;
  }

  #primary {
    float: none;
    margin: 0;
  }
}

@media (max-width: 650px) {
  body,
  input,
  textarea {
    font-size: 13px;
  }

  body {
    padding: 0;
  }

  #page {
    margin-top: 0;
  }

  #branding hgroup {
    padding: 34px 0 18px;
  }

  .brand-name {
    font-size: 30px;
  }

  #access li {
    float: none;
  }

  #access a {
    line-height: 2.6em;
  }

  .entry-title {
    font-size: 21px;
  }
}
