html {
  font-size: 12pt;
}

body {
  font-family: "Lato", sans-serif;
  padding: 0;
  margin: 1rem 1.5rem;
  min-height: 100%;
  background-color: #ddd;
}

a {
  color: #b31b1b;
  font-weight: bold;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

.key_point {
  font-weight: bold;
}

.note {
  font-style: italic;
}

.small {
  font-size: 0.9em;
}

#canvas {
  background-color: #fff;
  max-width: 52rem;
  min-width: 40rem;
  margin: auto;
  border: 1px solid #aaa;
}

#redirect_banner {
  font-size: 1.5rem;
  max-width: 52rem;
  min-width: 40rem;
  margin: 1rem auto;
  padding: 1em 0;
  text-align: center;
  font-weight: bold;
  background-color: #b31b1b;
  color: white;
}

#redirect_banner a {
  color: white;
  text-decoration: underline;
}

#header_table {
  font-size: 1.15em;
  padding: 1.25em;
  margin: 0;
  vertical-align: middle;
  border-spacing: 0;
  white-space: nowrap;
  width: 100%;
}

#header_table td {
  width: 50%;
  padding: 0;
}

#header_table h1 {
  font-size: 1.3em;
  margin: 0;
  padding: 0;
  font-family: "Righteous", cursive;
  font-weight: normal;
}

#header_table #header_img {
  display: inline-block;
  height: 75px;
  width: 400px;
  background: url(cu-cs-logo-highrez.png) no-repeat right;
  background-size: contain;
}

div.divider {
  height: 0.75em;
  background-color: #b31b1b;
}

h3 {
  font-size: 1.25em;
  padding: 0;
  margin: 0;
  line-height: 1em;
}

.info_area {
  margin: 1.25em 1.5em;
}

#overview_and_links {
  border-spacing: 0;
  width: 100%;
}

#overview_and_links td {
  padding: 0;
}

#overview p {
  margin: 0.75em 0.5em;
  line-height: 1.25em;
  text-align: justify;
}

#schedule_table {
  border-spacing: 0;
  margin: 1em 0.5em 0.3em 0.5em;
}

#past_semesters_td {
  font-size: 0.9em;
  border-left: solid 1px #999;
  color: #333;
  margin-left: 1em;
  margin-bottom: 1em;
  background-color: #d8d2c9;
  white-space: nowrap;
  vertical-align: top;
  text-align: center;
  width: 10em;
}

h4 {
  font-size: 1.1em;
  padding: 0;
  margin: 0.75em 0 0.5em 0;
  line-height: 1em;
}

#past_semesters_ul {
  text-align: left;
  list-style: none;
  padding: 0;
  margin: 0;
  line-height: 1.5em;
  display: inline-block;
}

#past_semesters_ul li.this_sem {
  font-weight: bold;
  opacity: 0.4;
}

#schedule_table th {
  color: #fff;
  background-color: #b31b1b;
  font-weight: bold;
}

#schedule_table > tbody > tr:nth-child(even) {
  background-color: #d8d2c9;
}

#schedule_table > tbody > tr.crosslist {
  background-color: #afc1d0;
}

#schedule_table td, #schedule_table th {
  white-space: nowrap;
  text-align: center;
  padding: 0.4em 0.6em;
}

#schedule_table td.date {
  width: 15%;
}

#schedule_table td.room {
  white-space: normal;
  width: 12%;
  font-size: 0.9em;
}

#schedule_table td.topic {
  width: 75%;
  white-space: normal;
  text-align: left;
}

#schedule_table tr.cancelled:nth-child(odd) {
  background-color: #ddd;
}

#schedule_table tr.cancelled:nth-child(even) {
  background-color: #bebbb5;
}

#schedule_table tr.cancelled td {
  opacity: 0.4;
}

div.authors {
  font-size: 0.9em;
}

div.venue {
  font-size: 0.85em;
}

.sup {
  font-size: 0.75em;
  vertical-align: super;
}

#footnotes {
  font-size: 0.8em;
  list-style: none;
  padding: 0;
  margin: 0;
}

