.schedule {
  border: 1px solid #ccc;
  width: 100%;
  margin: 0 0 20px 0;
  padding: 0;
  border-collapse: collapse;
  border-spacing: 0; }

.schedule tr {
  border: 1px solid #ddd;
  padding: 5px; }

.schedule th, .schedule td {
  padding: 10px; }

.schedule th {
  text-transform: uppercase;
  font-size: 14px;
  letter-spacing: 1px; }

.schedule td:not([align]), .schedule th:not([align]) {
  text-align: center; }

.schedule tbody th {
  width: 20%; }

@media screen and (max-width: 600px) {
  .schedule {
    border: 0; }
  .schedule thead {
    display: none; }
  .schedule tr {
    margin-bottom: 10px;
    display: block;
    border-bottom: 2px solid #ddd; }
  .schedule th {
    display: block;
    font-size: 13px; }
  .schedule td {
    display: block;
    font-size: 13px;
    border-bottom: 1px dotted #ccc; }
  .schedule td:last-child {
    border-bottom: 0; }
  .schedule td:before {
    content: attr(data-label);
    float: left;
    text-transform: uppercase;
    font-weight: bold; }
  .schedule td:not([align]) {
    text-align: right; }
  .schedule th:not([align]) {
    text-align: center; } }
