﻿* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
*:before, *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

body {
  font-family: "Helvetica Neue", "Helvetica", "Roboto", "Arial", sans-serif;
  color: #5e5d52;
}

a {
  color: #337aa8;
}
a:hover, a:focus {
  color: #4b8ab2;
}

.container {
  margin: 5% 3%;
}
@media (min-width: 48em) {
  .container {
    margin: 2%;
  }
}
@media (min-width: 75em) {
  .container {
    margin: 2em auto;
    max-width: 75em;
  }
}

.responsive-table {
  width: 100%;
  margin-bottom: 1.5em;
}
@media (min-width: 48em) {
  .responsive-table {
    font-size: .9em;
  }
}
@media (min-width: 62em) {
  .responsive-table {
    font-size: 1em;
  }
}
.responsive-table thead {
  position: absolute;
  clip: rect(1px 1px 1px 1px);
  /* IE6, IE7 */
  clip: rect(1px, 1px, 1px, 1px);
  padding: 0;
  border: 0;
  height: 1px;
  width: 1px;
  overflow: hidden;
}

.responsive-table thead th {
  background-color: #1d96b2;
  border: 1px solid #1d96b2;
  font-weight: normal;
  text-align: center;
  color: white;
}
.responsive-table thead th:first-of-type {
  text-align: left;
}
.responsive-table tbody,
.responsive-table tr,
.responsive-table th,
.responsive-table td {
  display: block;
  padding: 0;
  text-align: left;
  white-space: normal;
}

.responsive-table td.no-data {
    display: none;
}

.responsive-table th,
.responsive-table td,
.responsive-table td.no-data {
  padding: .5em;
    padding-left: .5em;
  vertical-align: middle;
}
@media (min-width: 30em) {
  .responsive-table th,
  .responsive-table td {
    padding: .75em .5em;
      padding-left: .5em;
  }
}

@media (min-width: 62em) {
  .responsive-table th,
  .responsive-table td {
    padding: .75em .5em;
      padding-left: .5em;
  }
}

.responsive-table caption {
  margin-bottom: 1em;
  font-size: 1em;
  font-weight: bold;
  text-align: center;
}
@media (min-width: 48em) {
  .responsive-table caption {
    font-size: 1.5em;
  }
}
.responsive-table tfoot {
  font-size: .8em;
  font-style: italic;
}
@media (min-width: 62em) {
  .responsive-table tfoot {
    font-size: .9em;
  }
}

.responsive-table tbody tr {
  margin-bottom: 1em;    
    box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2);
    transition: 0.3s;
    background-color: #f9f6f6;
    border: none;
}

.responsive-table tbody tr.group {
    box-shadow: none;
    background: none;
}

.responsive-table tbody tr:not(.group):not(.no-hover):hover {
    outline: #1d96b2 solid 2px;
    cursor: pointer;
}


.responsive-table tbody tr:last-of-type {
  margin-bottom: 0;
}

.responsive-table tbody th[scope="row"] {
  background-color: #1d96b2;
  color: white;
    padding-left: .5em;
}

.responsive-table tr.group td {
    background-color: white;
    color: #1d96b2 !important;
    font-weight: bold;
    font-size: 1.25em;
    padding-top: 2.5em;
    text-align: left;
    padding-left: 0;
    border-top: 1px solid lightgrey;
    border-bottom: 1px solid lightgrey;
}

.responsive-table tr td,.responsive-table tr th {
    border: none;
}

/*by default td's will be 50%. 2 per row. Add more as width goes up'*/
.responsive-table tbody td,.responsive-table tbody td[data-type="Currency"] {
  text-align: center;
    display: inline-block;    
}

.responsive-table tbody td {
    width: 50%;
}

@media (min-width: 550px) {
    .responsive-table tbody td {
        width: 33.333333%
    }
}

@media (min-width: 768px) {
    .responsive-table tbody td {
        width: 25%;
    }
}

.responsive-table tbody td[data-type=currency] {
  text-align: right;
}
.responsive-table tbody td[data-title]:before {
  content: attr(data-title);
    display: block;
  font-size: .8em;
  color: rgba(94, 93, 82, 0.75);
}
@media (min-width: 30em) {
  .responsive-table tbody td[data-title]:before {
    font-size: .9em;
  }
}

/* transform table to normal layout */
@media (min-width: 1200px) {
  .responsive-table tbody td[data-title]:before {
    content: none;
  }

  .responsive-table tbody td {
    text-align: center;
  }

    .responsive-table td.no-data {
        display: table-cell;
    }

  .responsive-table tbody th[scope="row"] {
    background-color: transparent;
    color: #5e5d52;
    text-align: left;
  }

  .responsive-table tbody tr:nth-of-type(even) {
    background-color: rgba(94, 93, 82, 0.1);
  }

  .responsive-table tbody tr {
    display: table-row;
    border-width: 1px;
      border-left: none;
  }

  .responsive-table tbody tr {
    box-shadow: none;
    background: none;
}

  .responsive-table tbody {
    display: table-row-group;
  }

  .responsive-table th,
  .responsive-table td {
    display: table-cell;      
    padding: .5em;
      padding-left: .5em;
  }

  .responsive-table tbody td {
      display: table-cell;
      width: auto;
  }
  .responsive-table tr {
    display: table-row;
  }

  .responsive-table thead {
    position: relative;
    clip: auto;
    height: auto;
    width: auto;
    overflow: auto;
  }

}

@media (min-width: 1500px) {
    .responsive-table th,
      .responsive-table td {        
        padding: .75em;       
      }

    .responsive-table tbody td {
        padding: .75em;
    }
}

