html, body {
  margin: 0;
  -webkit-tap-highlight-color: transparent;
  font-family: "ORF ON Condensed", Helvetica, Arial, sans-serif; }

.header {
  width: 100%;
  z-index: 999;
  background-color: #fff;
  position: absolute;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none; }
  .header .title {
    float: left;
    cursor: pointer;
    padding: 11px 3px;
    width: 230px; }
  .header .logo {
    padding: 8px;
    height: 30px;
    cursor: pointer;
    float: left; }
  .header .location {
    float: right;
    cursor: pointer;
    margin: 9px 8px 4px 4px;
    padding: 4px;
    height: 20px; }
    .header .location:hover {
      background-color: #e5e5e5;
      box-shadow: 0 0 3px 2px rgba(0, 0, 0, 0.22); }
  .header .stats {
    display: none;
    margin-top: 3px;
    margin-right: 3px;
    font-size: 1.2em; }
    .header .stats .stat {
      font-weight: bold; }
    .header .stats .button {
      margin: 5px;
      float: right;
      cursor: pointer;
      background-color: #002350;
      padding: 6px 10px 4px;
      color: #fff; }
      .header .stats .button:not(.selected) {
        color: #000;
        margin-top: 6px;
        padding: 5px 10px 3px;
        box-shadow: 0 0 3px 2px rgba(0, 0, 0, 0.15);
        background-color: #fff; }
        .header .stats .button:not(.selected):hover {
          background-color: #e5e5e5;
          box-shadow: 0 0 3px 2px rgba(0, 0, 0, 0.22); }

.info {
  top: 56px;
  z-index: 499;
  display: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  position: absolute;
  background-color: #fff;
  max-height: 470px;
  width: 412px;
  left: 8px; }
  .info img {
    float: left;
    width: 40px;
    height: 40px;
    padding: 14px 0 0 15px;
    display: none; }
  .info p {
    margin: 0;
    cursor: default;
    line-height: 1.2em;
    padding: 12px 10px 9px 67px;
    font-weight: 500;
    font-size: 1.1em; }
  .info iframe {
    height: 470px;
    width: 412px; }
  .info .short {
    padding-top: 11px; }
  .info .frame {
    display: none;
    text-align: center; }

.selected {
  box-shadow: inset 0 0 3px 2px rgba(0, 0, 0, 0.6); }

.header, .info, .location,
#trafficMap .leaflet-control-zoom {
  box-shadow: 0 0 3px 2px rgba(0, 0, 0, 0.15); }

#trafficMap {
  height: 100vh; }
  #trafficMap.leaflet-container {
    background: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAMAAABhEH5lAAAAD1BMVEX////8/Pz19ffx8vTx8fJcCtovAAAAIUlEQVQY02NgYGJhZmQgQDJgijNgqmTA1MvAQJT5w81GAGoZAh2K4VhsAAAAAElFTkSuQmCC"); }
  #trafficMap .traffic {
    z-index: 99999 !important; }
  #trafficMap .leaflet-control-zoom {
    border: 0;
    border-radius: 0;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    margin: 56px 8px 0 0; }
    #trafficMap .leaflet-control-zoom .leaflet-control-zoom-in,
    #trafficMap .leaflet-control-zoom .leaflet-control-zoom-out {
      line-height: 28px;
      border-radius: 0;
      height: 28px;
      width: 28px; }
      #trafficMap .leaflet-control-zoom .leaflet-control-zoom-in:hover,
      #trafficMap .leaflet-control-zoom .leaflet-control-zoom-out:hover {
        background-color: #e5e5e5; }
  #trafficMap .leaflet-control-attribution a {
    color: #333; }

.banner {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  padding: 6px 8px 0;
  border-top-right-radius: 5px;
  background-color: rgba(255, 255, 255, 0.7);
  position: absolute;
  z-index: 999;
  bottom: 0; }
  .banner img {
    width: 150px;
    height: 22px; }

@media (max-width: 469px) {
  #trafficMap .leaflet-control-zoom {
    display: none !important; }
  .info {
    left: 0;
    top: 45px;
    width: 100%; }
    .info img {
      width: 35px;
      height: 35px;
      padding-left: 10px; }
    .info p {
      padding-bottom: 7px;
      padding-left: 55px;
      font-size: 1em; }
    .info .short {
      padding: 13px 0 12px 10px; } }

@media (max-width: 729px) {
  .stats {
    display: none !important; } }

@media (max-width: 335px) {
  .header .title {
    display: none; } }
