@charset "UTF-8";
/*! normalize.css v1.1.2 | MIT License | git.io/normalize */
/* ==========================================================================
   HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined in IE 6/7/8/9 and Firefox 3.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block;
}

/**
 * Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3.
 */
audio,
canvas,
video {
  display: inline-block;
  *display: inline;
  *zoom: 1;
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address styling not present in IE 7/8/9, Firefox 3, and Safari 4.
 * Known issue: no IE 6 support.
 */
[hidden] {
  display: none;
}

/* ==========================================================================
   Base
   ========================================================================== */
/**
 * 1. Correct text resizing oddly in IE 6/7 when body `font-size` is set using
 *    `em` units.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */
html {
  font-size: 100%;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/**
 * Address `font-family` inconsistency between `textarea` and other form
 * elements.
 */
html,
button,
input,
select,
textarea {
  font-family: sans-serif;
}

/**
 * Address margins handled incorrectly in IE 6/7.
 */
body {
  margin: 0;
}

/* ==========================================================================
   Links
   ========================================================================== */
/**
 * Address `outline` inconsistency between Chrome and other browsers.
 */
a:focus {
  outline: thin dotted;
}

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
a:active,
a:hover {
  outline: 0;
}

/* ==========================================================================
   Typography
   ========================================================================== */
/**
 * Address font sizes and margins set differently in IE 6/7.
 * Address font sizes within `section` and `article` in Firefox 4+, Safari 5,
 * and Chrome.
 */
h1 {
  font-size: 1.8em;
  margin: 0.67em 0;
  line-height: 1.2em;
}

h2 {
  font-size: 1.5em;
  margin: 0.83em 0;
  line-height: 1.2em;
}

h3 {
  font-size: 1.3em;
  margin: 1em 0;
  line-height: 1.3em;
}

h4 {
  font-size: 1.2em;
  margin: 1.33em 0;
  line-height: 1.3em;
}

h5 {
  font-size: 1.1em;
  margin: 1.67em 0;
  line-height: 1.3em;
}

h6 {
  font-size: 1em;
  margin: 2.33em 0;
  line-height: 1.3em;
}

/**
 * Address styling not present in IE 7/8/9, Safari 5, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 3+, Safari 4/5, and Chrome.
 */
b,
strong {
  font-weight: bold;
}

blockquote {
  margin: 1em 40px;
}

/**
 * Address styling not present in Safari 5 and Chrome.
 */
dfn {
  font-style: italic;
}

/**
 * Address differences between Firefox and other browsers.
 * Known issue: no IE 6/7 normalization.
 */
hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
}

/**
 * Address styling not present in IE 6/7/8/9.
 */
mark {
  background: #ff0;
  color: #000;
}

/**
 * Address margins set differently in IE 6/7.
 */
p,
pre {
  margin: 1em 0;
}

/**
 * Correct font family set oddly in IE 6, Safari 4/5, and Chrome.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, serif;
  _font-family: 'courier new', monospace;
  font-size: 1em;
}

/**
 * Improve readability of pre-formatted text in all browsers.
 */
pre {
  white-space: pre;
  white-space: pre-wrap;
  word-wrap: break-word;
}

/**
 * Address CSS quotes not supported in IE 6/7.
 */
q {
  quotes: none;
}

/**
 * Address `quotes` property not supported in Safari 4.
 */
q:before,
q:after {
  content: '';
  content: none;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

/* ==========================================================================
   Lists
   ========================================================================== */
/**
 * Address margins set differently in IE 6/7.
 */
dl,
menu,
ol,
ul {
  margin: 1em 0;
}

dd {
  margin: 0 0 0 0px;
}

/**
 * Address paddings set differently in IE 6/7.
 */
menu,
ol,
ul {
  padding: 0 0 0 0px;
}

/**
 * Correct list images handled incorrectly in IE 7.
 */
nav ul,
nav ol {
  list-style: none;
  list-style-image: none;
}

/* ==========================================================================
   Embedded content
   ========================================================================== */
/**
 * 1. Remove border when inside `a` element in IE 6/7/8/9 and Firefox 3.
 * 2. Improve image quality when scaled in IE 7.
 */
img {
  border: 0;
  /* 1 */
  -ms-interpolation-mode: bicubic;
  /* 2 */
}

/**
 * Correct overflow displayed oddly in IE 9.
 */
svg:not(:root) {
  overflow: hidden;
}

/* ==========================================================================
   Figures
   ========================================================================== */
/**
 * Address margin not present in IE 6/7/8/9, Safari 5, and Opera 11.
 */
figure {
  margin: 0;
}

/* ==========================================================================
   Forms
   ========================================================================== */
/**
 * Correct margin displayed oddly in IE 6/7.
 */
form {
  margin: 0;
}

/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct color not being inherited in IE 6/7/8/9.
 * 2. Correct text not wrapping in Firefox 3.
 * 3. Correct alignment displayed oddly in IE 6/7.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  white-space: normal;
  /* 2 */
  *margin-left: -7px;
  /* 3 */
}

/**
 * 1. Correct font size not being inherited in all browsers.
 * 2. Address margins set differently in IE 6/7, Firefox 3+, Safari 5,
 *    and Chrome.
 * 3. Improve appearance and consistency in all browsers.
 */
button,
input,
select,
textarea {
  font-size: 100%;
  /* 1 */
  margin: 0;
  /* 2 */
  vertical-align: baseline;
  /* 3 */
  *vertical-align: middle;
  /* 3 */
}

/**
 * Address Firefox 3+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
button,
input {
  line-height: normal;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Chrome, Safari 5+, and IE 6+.
 * Correct `select` style inheritance in Firefox 4+ and Opera.
 */
button,
select {
  text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 * 4. Remove inner spacing in IE 7 without affecting normal text inputs.
 *    Known issue: inner spacing remains in IE 6.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
  *overflow: visible;
  /* 4 */
}

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}

/**
 * 1. Address box sizing set to content-box in IE 8/9.
 * 2. Remove excess padding in IE 8/9.
 * 3. Remove excess padding in IE 7.
 *    Known issue: excess padding remains in IE 6.
 */
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
  *height: 13px;
  /* 3 */
  *width: 13px;
  /* 3 */
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome
 *    (include `-moz` to future-proof).
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  /* 2 */
  box-sizing: content-box;
}

/**
 * Remove inner padding and search cancel button in Safari 5 and Chrome
 * on OS X.
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * Remove inner padding and border in Firefox 3+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

/**
 * 1. Remove default vertical scrollbar in IE 6/7/8/9.
 * 2. Improve readability and alignment in all browsers.
 */
textarea {
  overflow: auto;
  /* 1 */
  vertical-align: top;
  /* 2 */
}

/* ==========================================================================
   Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

html, button, input, select, textarea {
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  font-family: "Lato", "Myriad Pro", "Helvetica Neue", Arial, sans-serif;
  font-weight: normal;
  color: #485056;
}

html {
  -webkit-overflow-scrolling: touch;
  -webkit-tap-highlight-color: #f3f5f6;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

body {
  font: normal normal 16px/1.4em "Lato", "Myriad Pro", "Helvetica Neue", Arial, sans-serif;
}

::-moz-selection {
  background: #b3d4fc;
  text-shadow: none;
}

::selection {
  background: #b3d4fc;
  text-shadow: none;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #e8e8e8;
  margin: 1em 0;
  padding: 0;
}

img {
  vertical-align: middle;
}

fieldset {
  border: 0;
  margin: 0;
  padding: 0;
}

textarea {
  resize: vertical;
}

pre, code {
  font-family: monospace;
}

.chromeframe {
  margin: .2em 0;
  background: #ccc;
  color: #000;
  padding: .2em 0;
}

iframe {
  border: none;
  overflow: hidden;
  background: transparent;
}

nav > ul {
  margin: 0;
  padding: 0;
}

a, a:visited {
  color: #0191c2;
  text-decoration: none;
}

a:hover, a:focus {
  color: #015876;
}

.content-con a:hover, .content-con a:focus {
  text-decoration: underline;
}

a:hover, a:active {
  outline: 0;
}

a:focus {
  outline: thin dotted;
}

.left {
  float: left;
}

.right {
  float: right;
}

/*
 * Forms
 */
form .form-input-wrapper {
  -webkit-border-radius: 2px !important;
  -moz-border-radius: 2px !important;
  border-radius: 2px !important;
}

form .form-input {
  margin-bottom: 1.5em;
  position: relative;
  -webkit-border-radius: 2px !important;
  -moz-border-radius: 2px !important;
  border-radius: 2px !important;
  border: 1px solid rgba(0, 0, 0, 0.25);
}

form textarea.failed, form input.failed, form select.failed {
  border: 1px solid red;
  position: relative;
}

::-webkit-input-placeholder {
  color: #888;
}

::-moz-placeholder {
  color: #888;
}

/* firefox 19+ */
:-ms-input-placeholder {
  color: #888;
}

/* ie */
input:-moz-placeholder {
  color: #888;
}

form .form-input.full-width {
  clear: both;
}

form .form-input.half-width-left {
  width: 48%;
  float: left;
  margin-right: 10px;
}
form .form-input.half-width-left.last {
  margin-right: 0px;
}

.third-width-left {
  width: 75%;
  float: left;
}

.inline-input-button {
  width: 24%;
  padding: 0.6em 0.5em 0.8em;
  box-sizing: border-box;
  font-size: 1em !important;
  border-radius: 0px !important;
  -webkit-border-top-right-radius: 2px !important;
  -webkit-border-bottom-right-radius: 2px !important;
  -moz-border-radius-topright: 2px !important;
  -moz-border-radius-bottomright: 2px !important;
  border-top-right-radius: 2px !important;
  border-bottom-right-radius: 2px !important;
}

form .form-input.half-width-right {
  width: 47%;
  float: right;
  margin-left: 10px;
}

form .input-text,
form .input-select {
  box-sizing: border-box;
  font-size: 1em;
}

form .input-text {
  padding: 0.6em;
  border: none;
  width: 100%;
  border-radius: 2px;
  height: 39px;
}

form .input-text.inline-button {
  border-radius: 0px !important;
  -webkit-border-top-left-radius: 2px !important;
  -webkit-border-bottom-left-radius: 2px !important;
  -moz-border-radius-topleft: 2px !important;
  -moz-border-radius-bottomleft: 2px !important;
  border-top-left-radius: 2px !important;
  border-bottom-left-radius: 2px !important;
}

form .form-actions {
  width: 100%;
  clear: both;
}

form .form-actions.left {
  text-align: left;
}

form .form-actions.right {
  text-align: right;
}

form .form-actions.full {
  text-align: center;
}
form .form-actions.full button,
form .form-actions.full input[type=submit],
form .form-actions.full .form-submit,
form .form-actions.full .button {
  display: block;
  width: 100%;
}
form .form-actions.full .button {
  width: auto;
}

button,
input[type=submit],
.form-submit,
.form-reset,
.button,
.button:visited {
  border: 0;
  border-radius: 2px;
  color: #fff;
  background: #49a348;
  font-size: 0.875em;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-weight: bold;
  line-height: 1em;
  padding: 0.8em 1.5em 0.8em;
  -webkit-appearance: none;
  -moz-transition: all, 0.5s, ease-in;
  -o-transition: all, 0.5s, ease-in;
  -webkit-transition: all, 0.5s, ease-in;
  transition: all, 0.5s, ease-in;
}

.button {
  display: block;
  text-align: center;
}

button.form-submit {
  border-top: 2px solid #8cd686;
  border-bottom: 1px solid #177b0e;
  width: 100%;
}

button.form-reset {
  border-top: 2px solid #ffffff;
  border-bottom: 1px solid #79787b;
  background: #ccc;
  color: #333;
  width: 100%;
}

button:hover,
button:focus,
input[type=submit]:hover,
input[type=submit]:focus,
.form-submit:hover,
.form-submit:focus
.button:hover,
.button:focus {
  background: #65ba64;
  -moz-transition: all, 0.5s, ease-out;
  -o-transition: all, 0.5s, ease-out;
  -webkit-transition: all, 0.5s, ease-out;
  transition: all, 0.5s, ease-out;
}

a.button:hover,
a.button:focus {
  color: #fff;
}

.form-reset:hover, .form-reset:focus {
  background: #e6e6e6;
  -moz-transition: all, 0.5s, ease-out;
  -o-transition: all, 0.5s, ease-out;
  -webkit-transition: all, 0.5s, ease-out;
  transition: all, 0.5s, ease-out;
}

.read-more {
  font-weight: 700;
}

p {
  margin: 0 0 1em;
}

.content-block {
  overflow: hidden;
  margin: 0 0 5% 0;
}
.content-block h1, .content-block h2, .content-block h3, .content-block h4 {
  margin: 0 !important;
}
.content-block .secondary-title {
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1em;
  font-size: 1em;
  font-weight: 500;
  padding: 0;
  color: #004b8d;
  margin: 0 0 0.6em 0;
}
.content-block p {
  margin: 0.5em 0 1em !important;
}

.two-content .content-block {
  margin: 0 5% 5% 5%;
}

.content-inner > .content-block {
  margin: 0 4% 1em;
}

/* on homepage get rid of extra margin */
.home-page .content-block {
  margin: 0 0 2em;
}

.content-block .module {
  margin-left: 0;
}

.home-page .content-block .module p, .home-page .content-block .module footer {
  padding: 1em;
}

.home-page .content-block .module {
  box-shadow: 2px 2px 0px #e2e9f0;
}

.content-block.home-page {
  margin-top: 40px;
}

img {
  width: inherit;
  /* Make images fill their parent's space. Solves IE8. */
  max-width: 100%;
  /* Add !important if needed. */
  height: auto;
  /* Add !important if needed. */
  display: block;
  border: 0;
  margin: 0;
}

.one-content img, .two-content img {
  margin-bottom: 1em;
}

img.img-full,
img.img-50,
img.img-30 {
  width: 100%;
}

.img-grid {
  padding: 0;
  margin: 0;
  width: 100%;
  overflow: auto;
}

.img-grid li {
  float: left;
  list-style: none;
  margin: 0 4% 4% 0;
  width: 48%;
  box-sizing: border-box;
}

.img-grid img {
  width: 100%;
  margin: 0;
}

.img-grid li:nth-child(2n) {
  margin-right: 0;
}

.fluid-width-video-wrapper {
  margin-bottom: 1em;
}

@font-face {
  font-family: 'icons';
  src: url("../fonts/icons.eot?73279531");
  src: url("../fonts/icons.eot?73279531#iefix") format("embedded-opentype"), url("../fonts/icons.woff?73279531") format("woff"), url("../fonts/icons.ttf?73279531") format("truetype"), url("../fonts/icons.svg?73279531#icons") format("svg");
  font-weight: normal;
  font-style: normal;
}
/* Chrome hack: SVG is rendered more smooth in Windozze. 100% magic, uncomment if you need it. */
/* Note, that will break hinting! In other OS-es font will be not as sharp as it could be */
/*
@media screen and (-webkit-min-device-pixel-ratio:0) {
  @font-face {
    font-family: 'icons';
    src: url('../font/icons.svg?73279531#icons') format('svg');
  }
}
*/
[class^="icon-"]:before, [class*=" icon-"]:before {
  font-family: "icons";
  font-style: normal;
  font-weight: normal;
  speak: none;
  text-decoration: inherit;
  margin-right: .3em;
  text-align: center;
  /* opacity: .8; */
  /* For safety - reset parent styles, that can break glyph codes*/
  font-variant: normal;
  text-transform: none;
  /* fix buttons height, for twitter bootstrap */
  line-height: 1em;
  /* you can be more comfortable with increased icons size */
  /* font-size: 120%; */
  /* Uncomment for 3D effect */
  /* text-shadow: 1px 1px 1px rgba(127, 127, 127, 0.3); */
}

.icon-wheelchair:before {
  content: '\e80a';
}

/* '¯áè' */
.icon-facebook:before {
  content: '\e800';
}

/* '¯áÇ' */
.icon-help:before {
  content: '\e807';
}

/* '¯áç' */
.icon-attention:before {
  content: '\e808';
}

/* '¯áê' */
.icon-location:before {
  content: '\e806';
}

/* '¯áå' */
.icon-video:before {
  content: '\e803';
}

/* '¯áâ' */
.icon-book-open:before {
  content: '\e802';
}

/* '¯áé' */
.icon-calendar:before {
  content: '\e804';
}

/* '¯áä' */
.icon-clock:before {
  content: '\e805';
}

/* '¯áà' */
.icon-twitter:before {
  content: '\e801';
}

/* '¯áü' */
.icon-map:before {
  content: '\e809';
}

/* '¯áë' */
.ui-tabs {
  position: relative;
  margin-top: 1em;
}

.ui-tabs .ui-tabs-nav {
  margin: 0;
  padding: 0;
  padding-left: 0 !important;
  float: left;
  width: 100%;
  border-bottom: 1px solid #d0d0d0;
}

.ui-tabs .ui-tabs-nav li {
  list-style: none;
  float: left;
  position: relative;
  top: 0;
  margin: 0;
  border-bottom-width: 0;
  padding: 0;
  white-space: nowrap;
}

.ui-tabs .ui-tabs-nav li a {
  float: left;
  padding: 7px 15px;
  margin-bottom: -1px;
  text-decoration: none;
  border-right: 1px solid #d0d0d0;
  border-bottom: 1px solid #d0d0d0;
  border-top: 5px solid #ccc;
}

.ui-tabs .ui-tabs-nav li.ui-tabs-active {
  border-bottom: 0;
}

.ui-tabs .ui-tabs-nav li.ui-tabs-active a {
  border-bottom: 1px solid #ffffff;
  border-top: 5px solid #86ce7f;
}

.ui-tabs .ui-tabs-nav li.ui-tabs-active a,
.ui-tabs .ui-tabs-nav li.ui-state-disabled a,
.ui-tabs .ui-tabs-nav li.ui-tabs-loading a {
  cursor: text;
}

.ui-tabs .ui-tabs-nav li a,
.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-active a {
  cursor: pointer;
}

.ui-tabs .ui-tabs-panel {
  display: none;
  border-width: 0;
  background: none;
  padding: 10px 0;
  width: 100%;
}
.ui-tabs .ui-tabs-panel.active {
  display: inline-block;
}
.ui-tabs .ui-tabs-panel p {
  margin: 2em 1% 1em;
}
.ui-tabs .ui-tabs-panel #map-canvas {
  margin: 0;
}

/*************/
img.img-left,
img.img-left {
  float: left;
  margin-right: 1em;
}

img.img-right,
img.img-right {
  float: right;
  margin-left: 1em;
}

@media only screen and (min-width: 320px) {
  img.img-30 {
    width: 50%;
  }

  img.img-50 {
    width: 50%;
  }
}
@media only screen and (max-width: 480px) {
  .ui-tabs.schedule .ui-tabs-nav li {
    max-width: 35%;
  }

  .ui-tabs.schedule .ui-tabs-nav li a {
    text-align: center;
    width: 100%;
    display: table-cell;
    vertical-align: middle;
    /*word-wrap: break-word;*/
    padding: 0px;
    padding-bottom: 1px;
    background: white;
  }

  .social {
    clear: both;
  }
  .social .twitter-tab {
    width: 48% !important;
  }
  .social .twitter-tab a {
    float: left;
    padding: 7px 15px;
    margin-bottom: -1px;
    text-decoration: none;
    border-right: 1px solid #d0d0d0;
    border-bottom: 1px solid #d0d0d0;
    border-top: 5px solid #ccc;
  }
  .social .facebook-tab {
    width: 52% !important;
  }
  .social #facebook {
    padding-left: 0;
    padding-right: 0;
    margin-left: -5px;
  }
}
@media only screen and (max-width: 480px) {
  img.img-50, img.img-30 {
    width: 100%;
  }
}
@media only screen and (min-width: 480px) {
  .img-grid li,
  .img-grid li:nth-child(2n) {
    width: 32%;
    margin-right: 2%;
    margin-bottom: 2%;
  }

  .img-grid li:nth-child(3n) {
    margin-right: 0;
  }
}
@media only screen and (min-width: 768px) {
  p {
    margin-left: 0;
    margin-right: 0;
  }

  .img-grid li,
  .img-grid li:nth-child(2n),
  .img-grid li:nth-child(3n) {
    width: 23%;
    margin-right: 2.66%;
    margin-bottom: 2.66%;
  }

  .img-grid li:nth-child(4n) {
    margin-right: 0;
  }

  img.img-30 {
    width: 30%;
  }
}
body {
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6 {
  font-family: "Lato", "Myriad Pro", "Helvetica Neue", Arial, sans-serif;
  margin-left: 0;
  margin-right: 0;
}

.intro {
  color: #586066;
  font-size: 1.1em;
  line-height: 1.4em;
}

h1.page-title {
  font-weight: normal;
  letter-spacing: -1px;
  color: #002240;
}

h1.article-title {
  color: #86ce7f;
  font-size: 1.7em;
  font-weight: 300;
  line-height: 1.2em;
}

@media only screen and (min-width: 768px) {
  .one-content h1, .one-content h2, .one-content h3, .one-content h4, .one-content h5, .one-content h6, .one-content p {
    margin-left: 0;
    margin-right: 0;
  }
  .one-content h1.page-title {
    margin-left: 0;
    /*padding-left: 5%;*/
    padding-bottom: 0.5em;
    border-bottom: 1px solid #e8e8e8;
  }

  .two-content h1, .two-content h2, .two-content h3, .two-content h4, .two-content h5, .two-content h6 {
    margin-left: 0;
    margin-right: 0;
  }

  .content-block h1, .content-block h2, .content-block h3, .content-block h4, .content-block h5, .content-block h6, .content-block p {
    margin-left: 0 !important;
    margin-right: 0;
  }
}
@media only screen and (min-width: 1120px) {
  p {
    font-size: 1.0625em;
    line-height: 1.44em;
  }

  p.intro {
    font-size: 1.25em;
  }

  h1.page-title {
    font-size: 2.3em;
  }
}
@media only screen and (min-width: 1320px) {
  h1.page-title {
    font-size: 2.6em;
  }
}
.ir {
  background-color: transparent;
  border: 0;
  overflow: hidden;
  *text-indent: -9999px;
}

.ir:before {
  content: "";
  display: block;
  width: 0;
  height: 150%;
}

.hidden {
  display: none !important;
  visibility: hidden;
}

.visuallyhidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
  clip: auto;
  height: auto;
  margin: 0;
  overflow: visible;
  position: static;
  width: auto;
}

.invisible {
  visibility: hidden;
}

.clearfix:before, .clearfix:after {
  content: " ";
  display: table;
}

.clearfix:after {
  clear: both;
}

.clearfix {
  *zoom: 1;
}

.half-width {
  float: left;
  display: block;
  margin-right: 2.325%;
  width: 48.8375%;
}
.half-width:last-child {
  margin-right: 0;
}

.omega {
  margin-right: 0 !important;
}

.shift-1 {
  margin-left: 8.52708%;
}

.shift-2 {
  margin-left: 17.05417%;
}

.shift-3 {
  margin-left: 25.58125%;
}

.shift-4 {
  margin-left: 34.10833%;
}

.shift-5 {
  margin-left: 42.63542%;
}

.shift-6 {
  margin-left: 51.1625%;
}

.shift-7 {
  margin-left: 59.68958%;
}

.shift-8 {
  margin-left: 68.21667%;
}

.shift-9 {
  margin-left: 76.74375%;
}

.shift-10 {
  margin-left: 85.27083%;
}

.shift-11 {
  margin-left: 93.79792%;
}

.shift-12 {
  margin-left: 102.325%;
}

/* negative shift */
.n-shift-1 {
  margin-left: -8.52708%;
}

.n-shift-2 {
  margin-left: -17.05417%;
}

.n-shift-3 {
  margin-left: -25.58125%;
}

.n-shift-4 {
  margin-left: -34.10833%;
}

.n-shift-5 {
  margin-left: -42.63542%;
}

.n-shift-6 {
  margin-left: -51.1625%;
}

.n-shift-7 {
  margin-left: -59.68958%;
}

.n-shift-8 {
  margin-left: -68.21667%;
}

.n-shift-9 {
  margin-left: -76.74375%;
}

.n-shift-10 {
  margin-left: -85.27083%;
}

.n-shift-11 {
  margin-left: -93.79792%;
}

.n-shift-12 {
  margin-left: -102.325%;
}

@media only screen and (max-width: 968px) {
  .half-width {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 100%;
  }
  .half-width:last-child {
    margin-right: 0;
  }
}
html, body {
  width: 100%;
  height: 100%;
  background: #f2f6fa;
}

.container {
  width: 100%;
  height: 100%;
  position: absolute;
  background: #1b1f23;
}

.page-width {
  overflow: hidden;
  *zoom: 1;
  max-width: 83.75em;
  margin-left: auto;
  margin-right: auto;
}

.content-con {
  background-color: #f4f7f9;
  padding-top: 78px;
}

.content-inner {
  overflow: hidden;
  *zoom: 1;
}

.site-header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  color: #fff;
  font-family: 'Lato','Myriad Pro','Helvetica Neue',Arial,sans-serif;
}
.site-header .title-con {
  width: 100%;
  height: 45px;
  background: #002240;
  border-top: 1px solid #12324d;
  border-bottom: 1px solid #061825;
}
.site-header .region-con {
  padding-bottom: 6px;
}

.no-sidemenu .section.nav-ltwo {
  display: none;
}

.section.one-content {
  padding-bottom: 30px;
  padding-left: 16px;
  padding-right: 16px;
}

.section.two-content {
  padding-bottom: 30px;
  padding-left: 16px;
  padding-right: 16px;
}

.landing-page-articles {
  overflow: hidden;
  *zoom: 1;
  max-width: 83.75em;
  margin-left: auto;
  margin-right: auto;
}
.landing-page-articles article {
  float: left;
  display: block;
  margin-right: 2.325%;
  width: 48.8375%;
  display: inline-block;
  vertical-align: top;
}
.landing-page-articles article:last-child {
  margin-right: 0;
}
.landing-page-articles article:nth-child(2n) {
  margin-right: 0;
}
.landing-page-articles article:nth-child(2n+1) {
  clear: left;
}

.nav-con-primary .page-width {
  overflow: visible;
}

.site-footer {
  background: #002240 url(../images/watermark.png) no-repeat left bottom;
  background-size: 100%;
  color: #bed6ec;
  padding: 0px 0px 0px 20px;
}
.site-footer .nav-section {
  width: 220px;
  padding-right: 10px;
  vertical-align: top;
  display: inline-block;
}

.site-copyright {
  background: #001a31;
  border-top: 1px solid #12324d;
  color: #8ea5ba;
}
.site-copyright a {
  color: #019fd4;
  font-weight: bold;
  font-size: 0.9375em;
}

.no-bullet {
  list-style-type: none;
}

.tt-query,
.tt-hint {
  width: 396px;
  height: 30px;
  padding: 8px 12px;
  font-size: 24px;
  line-height: 30px;
  border: 2px solid #ccc;
  -webkit-border-radius: 8px;
  -moz-border-radius: 8px;
  border-radius: 8px;
  outline: none;
}

.typeahead {
  background-color: #fff;
}

.tt-query {
  -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
  -moz-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
}

.tt-hint, .tt-suggestion {
  color: #999;
}

.tt-dropdown-menu {
  width: 100%;
  margin-top: 40px;
  padding: 8px 0;
  background-color: #fff;
  border: 1px solid #ccc;
  border: 1px solid rgba(0, 0, 0, 0.2);
  -webkit-border-radius: 8px;
  -moz-border-radius: 8px;
  border-radius: 8px;
  -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
  -moz-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
}

.tt-suggestion {
  padding: 3px 20px;
  font-size: 18px;
  line-height: 24px;
}

.tt-suggestion.tt-cursor {
  color: black;
  background-color: #0097cf;
}

.tt-suggestion p {
  margin: 0;
}

.toggle-alerts {
  float: unset !important;
  margin-left: 10px;
}

/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN - 320 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 320px) {
  .content-con {
    padding-top: 110px !important;
    background-size: 900px , 920px;
    background-image: url(../images/blue-swoosh.png), url(../images/banner-large.jpg);
    background-repeat: no-repeat, no-repeat;
    background-position: center 330px,center 45px;
  }
  .content-con .content-inner {
    position: relative;
  }
  .content-con .site-header {
    z-index: 10;
  }

  .content-inner.two-col.no-menu .section.whole-content {
    min-height: 600px;
    padding-left: 10px;
    padding-right: 10px;
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 100%;
  }
  .content-inner.two-col.no-menu .section.whole-content:last-child {
    margin-right: 0;
  }
  .content-inner.two-col.no-menu .section.whole-content .system-overview-left-col {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 100%;
  }
  .content-inner.two-col.no-menu .section.whole-content .system-overview-left-col:last-child {
    margin-right: 0;
  }
  .content-inner.two-col.no-menu .section.whole-content .system-overview-right-col {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 100%;
    margin-right: 0;
    padding-top: 20px;
  }
  .content-inner.two-col.no-menu .section.whole-content .system-overview-right-col:last-child {
    margin-right: 0;
  }
}
@media only screen and (max-width: 320px) {
  #alert-management input.button-clear {
    margin-bottom: 10px;
    margin-top: 10px;
    width: 100%;
    height: 60px;
    word-wrap: break-word;
    font-size: .8em;
    line-height: 20px;
  }
  #alert-management input[name='unsubscribe-all'] {
    width: 100%;
    font-size: .8em;
    text-align: center;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN - 480 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 480px) {
  .content-con {
    padding-top: 80px !important;
    background-size: 900px;
    background-image: url(../images/blue-swoosh.png), url(../images/banner-large.jpg);
    background-repeat: no-repeat, no-repeat;
    background-position: center 255px,center top;
  }
  .content-con .content-inner {
    position: relative;
  }

  .home-page .content-con {
    padding-top: 200px !important;
  }

  .content-inner.two-col.no-menu .section.one-content {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 100%;
  }
  .content-inner.two-col.no-menu .section.one-content:last-child {
    margin-right: 0;
  }

  .content-inner.two-col.no-menu .section.two-content {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 100%;
  }
  .content-inner.two-col.no-menu .section.two-content:last-child {
    margin-right: 0;
  }

  /* LAYOUTS WITH THE TWO CONTENTS BEING EQUAL WIDTH*/
  .content-inner.two-col.no-menu .section.one-content.half {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 100%;
  }
  .content-inner.two-col.no-menu .section.one-content.half:last-child {
    margin-right: 0;
  }

  .content-inner.two-col.no-menu .section.two-content.half {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 100%;
  }
  .content-inner.two-col.no-menu .section.two-content.half:last-child {
    margin-right: 0;
  }
}
/* Change the content margins in mobile view */
@media only screen and (max-width: 767px) {
  .home-page-header, .content-inner {
    width: 100% !important;
  }

  .content-inner {
    border-left: none;
    border-right: none;
  }

  .no-sidemenu .trip-planner, .trip-planner-page .trip-planner, .trip-planner-page .dark-module, .module, #map-canvas {
    margin: 0px 0px 1em !important;
  }

  .route-overview .section.one-content {
    padding-bottom: 0 !important;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN - 768 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 768px) {
  .content-con {
    padding-top: 200px !important;
    background-size: 1680px;
    background-image: url(../images/banner-large-mask.png), url(../images/blue-swoosh.png), url(../images/banner-large.jpg);
    background-repeat: no-repeat, no-repeat, no-repeat;
    background-position: center 100px, center 595px, center 100px;
  }
  .content-con .content-inner {
    position: relative;
    height: auto;
    border-right: 1px solid #002240;
    border-left: none;
  }

  .small-only {
    display: none;
  }

  .home-page .content-con {
    padding-top: 188px;
  }

  .site-header {
    text-align: left;
    top: 42px;
  }
  .site-header .title-con {
    height: 63px;
  }
  .site-header .title-con .page-width {
    width: 94%;
    overflow: visible;
  }
  .site-header .region-con {
    height: 87px;
  }
  .site-header .region-con .page-width {
    width: 94%;
  }
  .site-header .site-title {
    position: relative;
    top: -40px;
  }

  .section.one-content {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 65.89167%;
    padding-left: 28px;
    padding-right: 0;
    border-left: 1px solid #e8e8e8;
  }
  .section.one-content:last-child {
    margin-right: 0;
  }

  .section.two-content {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 31.78333%;
    margin-right: 0;
    margin-top: 116px;
    padding-left: 0;
    padding-right: 0;
  }
  .section.two-content:last-child {
    margin-right: 0;
  }

  .content-inner.two-col.no-menu .section.one-content {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 65.89167%;
  }
  .content-inner.two-col.no-menu .section.one-content:last-child {
    margin-right: 0;
  }

  .content-inner.two-col.no-menu .section.two-content {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 31.78333%;
    margin-right: 0;
    margin-top: 145px;
  }
  .content-inner.two-col.no-menu .section.two-content:last-child {
    margin-right: 0;
  }

  .content-inner.two-col.no-menu .section.whole-content {
    min-height: 600px;
    padding-left: 28px;
    padding-right: 28px;
  }
  .content-inner.two-col.no-menu .section.whole-content .system-overview-left-col {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 48.8375%;
  }
  .content-inner.two-col.no-menu .section.whole-content .system-overview-left-col:last-child {
    margin-right: 0;
  }
  .content-inner.two-col.no-menu .section.whole-content .system-overview-right-col {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 48.8375%;
    margin-right: 0;
    padding-top: 20px;
  }
  .content-inner.two-col.no-menu .section.whole-content .system-overview-right-col:last-child {
    margin-right: 0;
  }

  /* LAYOUTS WITH THE TWO CONTENTS BEING EQUAL WIDTH*/
  .content-inner.two-col.no-menu .section.one-content.half {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 48.8375%;
  }
  .content-inner.two-col.no-menu .section.one-content.half:last-child {
    margin-right: 0;
  }

  .content-inner.two-col.no-menu .section.two-content.half {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 48.8375%;
    margin-right: 0;
    margin-top: 90px;
  }
  .content-inner.two-col.no-menu .section.two-content.half:last-child {
    margin-right: 0;
  }

  .section.nav-ltwo {
    min-height: 100px;
    position: relative;
    top: 0;
    right: -5px;
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 31.78333%;
    background: #002240;
    color: #fff;
  }
  .section.nav-ltwo:last-child {
    margin-right: 0;
  }
  .section.nav-ltwo .l-two {
    padding-bottom: 5%;
    margin-top: 60px;
  }
  .section.nav-ltwo ul {
    margin: 0;
    padding: 0;
  }
  .section.nav-ltwo ul li {
    position: relative;
    margin: 0.25em 0;
  }
  .section.nav-ltwo ul li a {
    display: block;
    padding: 0.2em 9%;
    line-height: 1.2em;
    position: relative;
  }
  .section.nav-ltwo ul li a:hover, .section.nav-ltwo ul li a:focus, .section.nav-ltwo ul li.is-current > a {
    background: #143a5b;
  }
  .section.nav-ltwo ul li.is-current > a {
    font-weight: bold;
    color: #fff;
  }
  .section.nav-ltwo ul li.is-current > a:before {
    content: "";
    display: block;
    width: 10px;
    height: 10px;
    background: white;
    position: absolute;
    left: -7px;
    top: 38%;
    transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    /* IE 9 */
    -webkit-transform: rotate(45deg);
    /* Opera, Chrome, and Safari */
  }
  .section.nav-ltwo ul li li a {
    padding-left: 18%;
  }
  .section.nav-ltwo ul li li li a {
    padding-left: 27%;
  }
  .section.nav-ltwo ul li li li li a {
    padding-left: 36%;
  }
  .section.nav-ltwo ul li li li li li a {
    padding-left: 45%;
  }
  .section.nav-ltwo a {
    color: #d0e4f5;
  }

  /* .section.nav-ltwo close */
  .nav-con-primary {
    position: absolute;
    width: 100%;
    top: 37px;
    z-index: 3;
    right: 0;
    height: 1px;
    -webkit-transition: none;
    -moz-transition: none;
    -o-transition: none;
    transition: none;
  }
  .nav-con-primary .nav-primary {
    display: inline-block;
    float: right;
    margin-top: 5px;
  }
  .nav-con-primary .page-width {
    width: 94%;
  }
  .nav-con-primary.fixed .nav-primary {
    margin-top: 0px;
  }

  .nav-con-tools {
    position: absolute;
    z-index: 2;
    width: 100%;
    top: 0;
    right: 0;
    height: 43px;
    background: #001a31;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  }
  .nav-con-tools .page-width {
    width: 94%;
  }
  .nav-con-tools a {
    color: #c0d7e7;
  }

  .nav-con-footer {
    clear: both;
  }

  .site-footer {
    background-image: url(../images/watermark-large.png);
    background-size: 70%;
    background-position: right bottom;
  }

  .site-copyright .page-width {
    position: relative;
    width: 94%;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN - 1120 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 1120px) {
  .site-header .title-con {
    height: 69px;
  }
  .site-header .title-con .site-title {
    top: 0;
  }

  .site-header .title-con.fixed, .nav-con-primary.fixed {
    position: fixed;
    width: 100%;
    z-index: 3;
    top: 0;
  }

  .site-header .region-con.fixed {
    margin-top: 69px;
  }

  .section.one-content {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 48.8375%;
  }
  .section.one-content:last-child {
    margin-right: 0;
  }

  .section.two-content {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 23.25625%;
    float: left;
  }
  .section.two-content:last-child {
    margin-right: 0;
  }

  .content-inner.two-col.no-menu .section.one-content {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 65.89167%;
  }
  .content-inner.two-col.no-menu .section.one-content:last-child {
    margin-right: 0;
  }

  .content-inner.two-col.no-menu .section.two-content {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 31.78333%;
    margin-right: 0;
    margin-top: 200px;
  }
  .content-inner.two-col.no-menu .section.two-content:last-child {
    margin-right: 0;
  }
  .route-overview .content-inner.two-col.no-menu .section.two-content {
    margin-top: 145px;
  }

  /* LAYOUTS WITH THE TWO CONTENTS BEING EQUAL WIDTH */
  .content-inner.two-col.no-menu .section.one-content.half {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 48.8375%;
  }
  .content-inner.two-col.no-menu .section.one-content.half:last-child {
    margin-right: 0;
  }

  .content-inner.two-col.no-menu .section.two-content.half {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 48.8375%;
    margin-right: 0;
    margin-top: 130px;
  }
  .content-inner.two-col.no-menu .section.two-content.half:last-child {
    margin-right: 0;
  }

  .section.nav-ltwo {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 23.25625%;
    margin-right: 0;
    bottom: 0;
    min-height: 600px;
    right: -1px;
    float: none;
    position: absolute;
  }
  .section.nav-ltwo:last-child {
    margin-right: 0;
  }

  .section.nav-ltwo:after {
    background: #002240;
    display: block;
    width: 5px;
    top: 0;
    right: -2px;
    content: "";
    position: absolute;
    min-height: 200000px;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN - 1320 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 1320px) {
  .site-footer {
    background-size: 50%;
  }
}
.region-modal, .route-modal {
  position: absolute !important;
  min-height: 550px;
}
.region-modal .regionHolder, .region-modal .routeHolder, .route-modal .regionHolder, .route-modal .routeHolder {
  overflow: hidden;
  *zoom: 1;
  margin-bottom: 20px;
}
.region-modal ul[class^='col'], .route-modal ul[class^='col'] {
  float: left;
}
.region-modal ul[class^='col'] li[class^="col"], .route-modal ul[class^='col'] li[class^="col"] {
  list-style: none;
  padding: 3px;
  overflow: hidden;
}
.region-modal ul[class^='col'] li[class^="col"] a, .route-modal ul[class^='col'] li[class^="col"] a {
  color: #59b558;
  padding-left: 5px;
  padding-right: 5px;
  margin-bottom: 5px;
  line-height: 1em;
  display: block;
}
.region-modal ul[class^='col'] li[class^="col"].large a, .route-modal ul[class^='col'] li[class^="col"].large a {
  font-size: 1.5em;
  padding: 5px;
}
.region-modal ul[class^='col'] li.disabled, .route-modal ul[class^='col'] li.disabled {
  background: transparent;
}
.region-modal ul[class^='col'] li.disabled a, .route-modal ul[class^='col'] li.disabled a {
  color: #235622;
  pointer-events: none;
}
.region-modal ul[class^='col'] li.disabled:hover a, .route-modal ul[class^='col'] li.disabled:hover a {
  color: #235622;
}
.region-modal ul[class^='col'] li:hover, .route-modal ul[class^='col'] li:hover {
  background: #59b558;
  border-radius: 3px;
}
.region-modal ul[class^='col'] li:hover a, .route-modal ul[class^='col'] li:hover a {
  color: white;
}
.region-modal .region-search-link, .region-modal .route-search-link, .route-modal .region-search-link, .route-modal .route-search-link {
  position: absolute;
  bottom: 10px;
}
.region-modal .region-search-link a, .region-modal .route-search-link a, .route-modal .region-search-link a, .route-modal .route-search-link a {
  text-decoration: underline;
  font-weight: bold;
  color: white;
}

.modal, .region-modal, .route-modal {
  display: none;
  width: 700px;
  border-radius: 10px;
  background: #002240 url(../images/watermark.png) no-repeat right bottom;
  padding: 1em;
  position: fixed;
  z-index: 999999;
  top: 50%;
  left: 20px;
}
.modal.active, .active.region-modal, .active.route-modal {
  display: block;
}
.modal p, .region-modal p, .route-modal p {
  color: white;
}
.modal h1, .region-modal h1, .route-modal h1 {
  color: white;
  padding: 0;
  margin-top: 0px;
}
.modal .closeBtn, .region-modal .closeBtn, .route-modal .closeBtn {
  position: absolute;
  top: 5px;
  font-size: 12px;
  right: 10px;
  color: white;
  font-weight: bold;
  cursor: pointer;
}

.subscription-modal label {
  color: white;
  margin-bottom: 10px;
  display: inline-block;
  cursor: pointer;
}
.subscription-modal label input {
  margin-right: 10px;
}
.subscription-modal label:last-child {
  margin-bottom: 0px;
}
.subscription-modal .form-input {
  border: none;
}
.subscription-modal .form-input input[type="text"] {
  border: 1px solid rgba(0, 0, 0, 0.25);
}
.subscription-modal .form-input input[type="text"].error {
  border: 2px solid red;
}
.subscription-modal .error-message {
  font-size: .9em;
  color: red;
}
.subscription-modal h4 {
  color: white;
  font-size: 1.2em;
  margin: 2px 2px 1px;
}
.subscription-modal .terms {
  margin-top: 10px;
}
.subscription-modal .subnote {
  font-style: italic;
  font-size: 1em;
  text-align: center;
  color: white;
}
.subscription-modal .displayButton {
  margin: 14px 0px;
  width: 100%;
  position: relative;
}
.subscription-modal .route-list {
  width: 620px;
  margin: 0 auto;
  padding: 0px;
  margin-top: 15px;
  margin-bottom: 15px;
}
.subscription-modal .route-list span {
  color: white;
  font-style: italic;
  font-size: .8em;
}
.subscription-modal .route-list ul {
  padding: 0;
  margin: 0px;
}
.subscription-modal .route-list ul li {
  list-style: none;
  display: inline-block;
  margin: 5px;
}
.subscription-modal .route-list ul li .directions-icon {
  -webkit-transition: all 200ms cubic-bezier(0.55, 0.085, 0.385, 0.83);
  -moz-transition: all 200ms cubic-bezier(0.55, 0.085, 0.385, 0.83);
  -o-transition: all 200ms cubic-bezier(0.55, 0.085, 0.385, 0.83);
  transition: all 200ms cubic-bezier(0.55, 0.085, 0.385, 0.83);
  cursor: pointer;
  font-weight: 700;
  background: #273d57;
  color: #fff;
  border-radius: 3px;
  padding: 0em 0.2em;
  text-align: center;
  width: 35px;
  height: 35px;
  padding-top: 6px;
  opacity: 1;
}
.subscription-modal .route-list ul li .directions-icon.selected {
  opacity: 1;
  background: #49a348;
  -webkit-transform: scale(1.2, 1.2);
  transform: scale(1.2, 1.2);
  -ms-transform: scale(1.2, 1.2);
  /* IE 9 */
}
.subscription-modal .route-list ul li .directions-icon:active {
  opacity: 1;
  background: #273d57;
  -webkit-transform: scale(1, 1);
  transform: scale(1, 1);
  -ms-transform: scale(1, 1);
  /* IE 9 */
}

.region-modal-cover, .route-modal-cover, .modal-cover {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  min-height: 100%;
  background: rgba(0, 0, 0, 0.6);
  z-index: 999;
}
.region-modal-cover.active, .route-modal-cover.active, .modal-cover.active {
  display: block;
}

.section.one-content ul {
  padding-left: 30px;
}

.section.one-content ol {
  padding-left: 30px;
}

.section.one-content ul.img-grid {
  padding-left: 0;
}

.page-title .page-title a.stop-name {
  display: block;
  font-size: .6em;
}

#travel-overview {
  position: relative;
}
@media (min-width: 1120px) {
  #travel-overview .col-left {
    float: left;
    width: 70%;
  }
}
#travel-overview .col-left h3 {
  margin-bottom: 20px !important;
}
@media (min-width: 768px) {
  #travel-overview .col-right {
    position: relative;
    float: right;
  }
}
@media (min-width: 768px) {
  #travel-overview .col-right {
    clear: right;
    width: 30%;
  }
}
#travel-overview a.change-direction {
  background: #3c853b;
  border-radius: 4px;
  padding: 4px 8px 6px 7px;
  color: white;
  font-weight: bold;
  margin-top: 5px;
  display: block;
  width: 175px;
  position: relative;
  top: 0px;
  right: 0px;
  padding-left: 40px;
}
@media (min-width: 768px) {
  #travel-overview a.change-direction {
    float: right;
  }
}
#travel-overview a.change-direction i {
  transition: all 0.5s ease;
  position: absolute;
  border-top-left-radius: 4px;
  border-bottom-left-radius: 4px;
  background: #1c3e1c;
  top: 0px;
  left: 0px;
  height: 100%;
  padding: 9px 8px 0px 8px;
}
#travel-overview a.change-direction.toggle {
  padding-left: 8px;
  padding-right: 40px;
}
#travel-overview a.change-direction.toggle i {
  right: 0px;
  left: auto;
  border-top-left-radius: 0px;
  border-bottom-left-radius: 0px;
  border-top-right-radius: 4px;
  border-bottom-right-radius: 4px;
}
#travel-overview .ui-tabs-panel {
  /* Required to return appropriate element width/height in JS */
  visibility: hidden;
  position: absolute;
  display: block;
  padding-bottom: 20px;
}
#travel-overview .ui-tabs-panel.active {
  visibility: visible;
  position: relative;
  display: inline-block;
}
#travel-overview .ui-tabs-panel table {
  margin-top: 0px;
}

.preview-schedule.panel {
  width: 100%;
  border-top: 3px solid #70cbf2;
}
.preview-schedule.panel.small {
  width: 60%;
}
.preview-schedule.panel.medium {
  width: 70%;
}
.preview-schedule.panel.large {
  position: relative;
  padding: 10px;
  color: white;
  font-weight: normal;
  background: #2ab1ec;
  min-height: 120px;
}
.preview-schedule.panel.large i {
  font-size: 40px;
  float: left;
}
.preview-schedule.panel.large .effectiveDate {
  font-size: 26px;
  font-weight: 400;
  line-height: 28px;
  padding-bottom: 39px;
  text-shadow: 1px 2px rgba(0, 0, 0, 0.2);
}
.preview-schedule.panel.large a {
  position: absolute;
  bottom: -20px;
  left: 0px;
  margin-top: 0px;
  width: 100%;
  background: #1B7297;
  text-align: left;
  padding-left: 65px;
}
.preview-schedule.panel.large a:hover {
  color: white;
  font-weight: bold;
}
.preview-schedule.panel.large span {
  display: block;
  margin-left: 55px;
  padding-bottom: 5px;
}
.preview-schedule.panel .button {
  margin-bottom: 20px;
  background: #2ab1ec;
  line-height: 1.25em;
}
.preview-schedule.panel .button .fa {
  padding-right: 10px;
}

.side-panel {
  position: absolute;
  top: 10px;
  right: 0px;
  margin: 10px 20px 1em;
  text-align: right;
}
.side-panel a {
  background: #49a348;
  border-radius: 3px;
  width: auto;
  height: 30px;
  color: white;
  font-weight: bold;
  padding-left: 5px;
  padding-right: 5px;
  line-height: 30px;
  display: inline-block;
  text-align: center;
}
.side-panel a i {
  margin-right: 5px;
}
.side-panel a:hover {
  background: #5cb95b;
}

.sidemenu .side-panel {
  right: 25%;
}

.site-title {
  font-size: 2em;
  line-height: 1.1em;
  margin: 0;
}
.site-title a {
  display: block;
  width: 164px;
  height: 39px;
  padding: 8px 0;
  margin: 5px 0 0 3%;
}
.site-title a span {
  display: block;
  height: inherit;
  width: inherit;
  text-indent: -999em;
  overflow: hidden;
  background: url(../images/logo-small.png) no-repeat;
  -moz-background-size: 100%, 100%;
  -o-background-size: 100%, 100%;
  -webkit-background-size: 100%, 100%;
  background-size: 100%, 100%;
}

.content-inner {
  position: relative;
  background: #fff;
  width: 94%;
  margin-bottom: 20px;
  border: 1px solid #e8e8e8;
  border-top: 0px solid #002240;
  overflow: hidden;
  *zoom: 1;
}

.choose-region .content-inner {
  background: none;
  border: none;
}

.content-inner .top-bar {
  border-top: 5px solid #002240;
  width: 100%;
  position: absolute;
  z-index: 1;
}

.home-page .top-bar {
  display: none;
}

.content-inner.home-page {
  background: transparent;
  border: none;
  border-top: none;
}

.home-page-header {
  margin-top: -45px;
  width: 94%;
}
.home-page-header .content-block {
  margin-bottom: 70px;
}

.home-page-title {
  margin-bottom: 20px;
}
.home-page-title h3 {
  color: #fff;
  font-size: 5em;
  line-height: .93em;
  text-shadow: 1.5px 1.5px 3px rgba(0, 0, 0, 0.5);
}
.home-page-title h3 small {
  font-size: .4em;
  line-height: .4em;
}
.home-page-title h3 span {
  line-height: .8em;
}
.home-page-title h3 .region {
  font-size: .5em;
  margin-top: 10px;
  display: block;
}
.home-page-title a {
  color: #fff;
  font-size: .5em;
}
.home-page-title a:hover, .home-page-title a:focus {
  text-decoration: underline;
}
.home-page-title p {
  color: #ebebec;
  font-size: 1.5em;
  line-height: 1.25em;
  font-weight: bold;
  text-shadow: 1.5px 1.5px 3px rgba(0, 0, 0, 0.5);
}

.site-region {
  margin: 0;
  padding: 0;
  width: 100%;
  text-align: center;
  text-shadow: 1px 2px 0 rgba(0, 34, 64, 0.43);
}
.site-region span {
  font-size: 0.8em;
  font-weight: bold;
  font-family: 'Lato';
  line-height: 1.1em;
}
.site-region small {
  display: none;
}

.campaign-message {
  margin: 0;
  background: rgba(244, 247, 249, 0.18);
  padding: 0.5em 0;
  text-shadow: 1px 1px 0 rgba(0, 34, 64, 0.43);
}
.campaign-message h2, .campaign-message h3 {
  margin: 0;
  text-align: center;
  line-height: 1em;
  letter-spacing: -1px;
}
.campaign-message h3 {
  font-size: 1.05em;
  margin-top: 0.2em;
}

.search-con {
  position: relative;
}
.search-con .input {
  border: none;
  background: #444b52;
  color: #fff;
  line-height: 1em;
  height: 35px;
  padding: 6px 45px 9px 0.8em;
  width: 100%;
  -webkit-appearance: none;
  box-sizing: border-box;
}
.search-con .submit {
  position: absolute;
  right: -5px;
  top: 5px;
  display: block;
  color: #C0D7E7;
  font-size: 18px;
  height: 35px;
  width: 35px;
  padding: 0;
  cursor: pointer;
  -webkit-appearance: none;
}

.module {
  margin: 0 4% 1em;
  border-top: 5px solid #002240;
  position: relative;
  background: #fff;
  -webkit-backface-visibility: hidden;
  -webkit-perspective: 1000;
}
.module .title {
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1em;
  font-size: 1em;
  font-weight: 400;
  color: #002240;
  padding: 0.9em 1em;
  margin: 0;
}

.module.community-list {
  margin: 0;
  padding: 0 10px 20px;
}
.module.community-list h3 {
  padding-left: 0px;
}

.alt-anchor {
  margin: 0;
}
.alt-anchor a .fa {
  margin-right: 5px;
}

#map-canvas {
  height: 450px;
  margin-left: 0;
  margin-bottom: 1em;
}
#map-canvas img {
  max-width: none !important;
}

#mapHolder {
  margin-top: 20px;
}

.dark-module, .light-module {
  background: #143a5b;
  background-size: 100%;
  color: #fff;
  padding: 4%;
  margin-bottom: 4%;
  position: relative;
  box-shadow: 3px 3px 0px rgba(0, 0, 0, 0.1);
}
.dark-module .title, .light-module .title {
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1em;
  font-size: 1em;
  font-weight: 700;
  padding: 0;
  margin: 0 0 0.6em 0;
}

.dark-module .stops-holder .direction {
  position: relative;
  padding: 10px;
}
.dark-module .stops-holder .directions-icon {
  display: inline-block;
  font-weight: 700;
  background: #49a348;
  color: #fff;
  border-radius: 3px;
  padding: 0.2em 0.3em;
  float: left;
  position: absolute;
  left: -8px;
  top: 16px;
  text-align: center;
}
.dark-module .stops-holder .directions-title {
  margin-left: 30px;
}

.twitter-typeahead {
  border-radius: 4px;
}

#nextDeparturesModule {
  background: #e6ebef;
  border: 1px solid #d8d8d8;
  min-height: 105px;
  overflow: hidden;
  padding: 20px !important;
}
#nextDeparturesModule h3 {
  color: #002240;
}
#nextDeparturesModule .fa {
  color: #000;
}

#findBusMod {
  padding: 20px !important;
  margin-bottom: 25px;
}
#findBusMod .stops-holder {
  margin-top: 0px;
  display: none;
}
#findBusMod .inline-input-button {
  width: 25%;
  height: 39px;
}
#findBusMod #route-number {
  border-bottom-left-radius: 4px;
  border-top-left-radius: 4px;
}
#findBusMod.closed {
  height: 160px;
}
#findBusMod.open {
  height: auto;
}
#findBusMod.open .stops-holder {
  display: block;
}
#findBusMod.open .stops-holder ol {
  margin-top: 14px;
}
#findBusMod .displayButton {
  margin: 14px 0 0;
  width: 100%;
}
#findBusMod .direction {
  position: relative;
  padding: 10px;
  margin-left: 8px;
  margin-right: 1px;
  border-radius: 2px;
  border: 1px solid #fff;
}
#findBusMod .direction .directions-icon {
  top: 50%;
  margin-top: -15px;
}
#findBusMod input.input-text {
  height: 39px;
}

.no-sidemenu .trip-planner, .trip-planner-page .trip-planner {
  margin: 0px 4% 1em;
}
.no-sidemenu .dark-module, .trip-planner-page .dark-module {
  margin: 0px 4% 1em;
}

@media (min-width: 320px) and (max-width: 480px) {
  .trip-planner-page article .instruction-holder {
    display: none;
  }
}
.departures.swipe {
  width: 400px;
  height: 200px;
}

.swipeThis {
  overflow: hidden;
}

.swipeThis ul {
  overflow: hidden;
  list-style: none;
  position: relative;
  margin: 0px;
  padding: 0px;
}

.swipeThis li {
  display: block;
  float: left;
  margin-right: 20px;
}

.swipeThis .indicators {
  height: 30px;
  margin: 20px auto 0;
}
.swipeThis .indicators span {
  cursor: pointer;
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.4);
  float: left;
  margin-right: 5px;
  text-indent: -99999em;
}
.swipeThis .indicators span.active {
  background: rgba(0, 0, 0, 0.7);
}

.trip-print {
  display: none;
}

.trip-planner {
  background: #002240;
  color: #fff;
  padding: 20px;
  margin-bottom: 4%;
  position: relative;
  overflow: hidden;
  background: #002240 url(../images/watermark.png) no-repeat right bottom;
  box-shadow: 3px 3px 0px rgba(0, 0, 0, 0.1);
}
.trip-planner .tripswitch-holder {
  position: absolute;
  right: 25px;
  top: 69px;
  font-size: 27px;
}
.trip-planner .tripswitch-holder i {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  margin: 10px 0;
  cursor: pointer;
  -webkit-transition: transform .5s ease-out;
  -transition: transform .5s ease-out;
}
.trip-planner .tripswitch-holder i:hover {
  -webkit-transform: rotate(-90deg);
  transform: rotate(-90deg);
}
.trip-planner .tripswitch-holder:before {
  content: "";
  display: block;
  width: 13px;
  height: 9px;
  border-top: 1px solid white;
  border-right: 1px solid white;
}
.trip-planner .tripswitch-holder:after {
  content: "";
  display: block;
  width: 13px;
  height: 9px;
  background: transparent;
  border-bottom: 1px solid white;
  border-right: 1px solid white;
}
.ie9 .trip-planner {
  overflow: visible !important;
}
.trip-planner.close {
  height: 52px;
}
.ie9 .trip-planner.close {
  overflow: hidden !important;
}
.trip-planner.full {
  background: #002240 url(../images/watermark.png) no-repeat right bottom;
}
.trip-planner.full .alerts {
  margin-top: 10px;
}
.trip-planner.full .minimizeBtn {
  display: none;
}
.trip-planner.full #starting-point, .trip-planner.full #destination {
  width: 84%;
  width: calc(100% - 59px);
}
.trip-planner.full .form-input.last {
  margin-top: 10px;
}
.trip-planner.small {
  margin-top: 30px;
  margin-bottom: 25px;
}
.trip-planner.small .starting-field i.inline-icon, .trip-planner.small .destination-field i.inline-icon {
  right: 35px;
}
.trip-planner #starting-point, .trip-planner #destination {
  width: 80%;
  width: calc(100% - 65px);
  border-top-right-radius: 0px;
  border-bottom-right-radius: 0px;
}
.trip-planner .title {
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1em;
  font-size: 1em;
  font-weight: 700;
  padding: 0;
  margin: 0 0 1em 0 !important;
}
.trip-planner .title .route {
  text-transform: none;
  float: right;
}
.trip-planner .title .route a {
  color: #fff;
}
.trip-planner a.view-maps,
.trip-planner a.view-maps:visited {
  font-size: 0.875em;
  font-weight: bold;
  line-height: 1.1em;
  color: #aad5fd;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  display: block;
  margin: 0.5em auto 0;
  padding: 0.5em 0.5em;
}
.trip-planner a.view-maps:hover,
.trip-planner a.view-maps:focus {
  color: #dceefe;
}
.trip-planner .button.schedules,
.trip-planner .button.handydart {
  font-size: 0.8em;
  background-color: #1ab0ef;
  border-top: 2px solid #76d6f4;
  margin-top: 1.5em;
}
.trip-planner .button.handydart {
  text-transform: none;
}
.trip-planner .button.schedules:hover, .trip-planner .button.schedules:focus,
.trip-planner .button.handydart:hover, .trip-planner .button.handydart:focus {
  background-color: #56c2ef;
}
.trip-planner .hiddenInputs {
  display: none;
}
.trip-planner #hiddenInputs {
  position: relative;
  z-index: 100000;
}
.trip-planner .drop-down {
  padding: 4px;
  border-radius: 2px;
  line-height: 25px;
  color: #959595;
  text-indent: 9px;
  cursor: pointer;
  height: 35px;
  background: white;
  text-align: left;
  font-size: 1em;
  font-weight: normal;
  text-transform: none;
  font-family: "Lato", "Myriad Pro", "Helvetica Neue", Arial, sans-serif;
}
.trip-planner form .form-input {
  border: none;
}
.trip-planner i.inline-icon {
  height: 33px;
  display: block;
  width: 20px;
  text-align: center;
  position: absolute;
  right: 4px;
  top: 0px;
  padding-top: 5px;
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
  cursor: pointer;
}
.trip-planner .starting-field i.inline-icon, .trip-planner .destination-field i.inline-icon {
  right: 29px;
}
.trip-planner i.icon-location.inline-icon {
  font-size: 1.4em;
  background: #ccc;
  color: white;
  width: 30px;
  height: 100%;
  padding-top: 7px;
  padding-left: 4px;
}
.trip-planner .clearField {
  cursor: pointer;
  position: absolute;
  right: 68px;
  display: block;
  top: 0px;
  width: 25px;
  background: white;
  line-height: 35px;
  height: 100%;
  padding-left: 6px;
  padding-top: 2px;
  color: #8B8B8B;
}
.trip-planner .clearField:hover {
  color: red;
}
.trip-planner .drop-down-content {
  display: none;
}
.trip-planner .drop-down-content.show {
  display: block;
  margin-top: -5px;
}
.trip-planner .drop-down-content.show ol {
  background: white;
  color: grey;
  margin: 0;
  padding: 8px;
  border-bottom-left-radius: 3px;
  border-bottom-right-radius: 3px;
}
.trip-planner .drop-down-content.show li {
  cursor: pointer;
  list-style: none;
  height: 25px;
  padding-left: 8px;
}
.trip-planner .drop-down-content.show li:hover {
  color: white;
  background: #40b0ff;
}
.trip-planner .trip-error {
  color: white;
  display: none;
  margin-top: 10px;
  float: left;
}
.trip-planner.routes .route-list {
  width: 48%;
  float: left;
  margin-right: 4%;
}
.trip-planner.routes .route-list:last-of-type {
  margin-right: 0;
}
.trip-planner.routes .route-list li {
  list-style: none;
  color: #58bd50;
  float: left;
  font-weight: bold;
  width: 100%;
  margin-right: 10px;
  margin-bottom: 5px;
}
.trip-planner.routes .route-list li a {
  color: #49a348;
  word-wrap: break-word;
}

/* add in animations for sidebar accordion modules */
.csstransitions .trip-planner {
  -webkit-transition: max-height .5s;
  transition: max-height .5s;
}
.csstransitions .trip-planner.close {
  height: auto;
  min-height: 52px;
  max-height: 52px;
}

/* add in animations for sidebar accordion modules */
/*.csstransitions {
    #findBusMod {
        &.open {
            .stops-holder {display:block; max-height:10000px;}
        }
        &.closed {
            .stops-holder {display:block; height:auto; max-height:0px; min-height:0px;}
        }
        .stops-holder {
            -webkit-transition:max-height .5s;
            transition:max-height .5s;
        }
    }
}*/
.places-container {
  width: 100%;
  background-color: #fff;
  position: absolute !important;
  z-index: 2;
  border-radius: 2px;
  /*border-top: 1px solid #d9d9d9;*/
  font-family: Arial,sans-serif;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
}
.places-container .pac-item {
  cursor: default;
  padding: 0 4px;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  line-height: 30px;
  text-align: left;
  border-top: 1px solid #e6e6e6;
  font-size: 11px;
  color: #999;
}
.places-container .pac-item:hover {
  background-color: #fafafa;
  cursor: pointer;
}
.places-container .pac-item .pac-icon {
  width: 15px;
  height: 20px;
  margin-right: 7px;
  margin-top: 6px;
  display: inline-block;
  vertical-align: top;
  background-image: url("//maps.gstatic.com/mapfiles/api-3/images/autocomplete-icons.png");
  background-size: 34px;
}
.places-container .pac-item .pac-icon.pac-icon-marker {
  background-position: -1px -161px;
}
.places-container .pac-item.pac-item-selected, .places-container .pac-item.pac-item-selected:hover {
  background-color: #ebf2fe;
}
.places-container .pac-item.pac-item-selected .pac-icon.pac-icon-marker, .places-container .pac-item.pac-item-selected:hover .pac-icon.pac-icon-marker {
  background-position: -18px -161px;
}
.places-container .pac-item .pac-item-query {
  font-size: 13px;
  padding-right: 3px;
  color: #000;
}
.places-container .pac-item .pac-matched {
  font-weight: 700;
}

/** FIND TRANSIT SYSTEM MODULE **/
.finding-transit-system-loader {
  margin-bottom: 30px;
  font-weight: bold;
}
.finding-transit-system-loader img {
  width: 32px;
  height: 32px;
  margin: 0  auto;
}
.finding-transit-system-loader .regions {
  margin-top: 10px;
}
.finding-transit-system-loader .regions a {
  font-size: 1.4em;
  background-color: #59b558;
  color: white;
  padding-left: 7px;
  padding-right: 7px;
  padding-bottom: 5px;
  border-radius: 4px;
}

.find-transit-or {
  margin-bottom: 20px;
  width: 100%;
  text-align: center;
}
.find-transit-or span {
  background: white;
  border-radius: 50%;
  display: inline-block;
  width: 30px;
  height: 30px;
  padding-top: 4px;
  font-weight: bold;
  color: #002240;
}
.find-transit-or span:after, .find-transit-or span:before {
  content: "";
  display: inline-block;
  font-weight: bold;
  color: white;
  float: left;
  margin-left: -14px;
}
.find-transit-or span:after {
  margin-right: -14px;
  float: right;
}

/************/
.notecode-wrapper .note {
  width: 100%;
  float: left;
}
.notecode-wrapper .code {
  font-size: .8em;
  color: #40B0FF;
  font-style: italic;
}
.notecode-wrapper .description {
  font-style: italic;
  font-size: .8em;
  color: #939393;
}

.minimizeBtn {
  color: #143a5b;
  float: right;
  position: absolute;
  top: 14px;
  right: 20px;
  cursor: pointer;
  background: #f2f6fa;
  padding: 5px 5px 2px 5px;
  border-radius: 20px;
}

.home-page .trip-planner {
  margin: 0 !important;
}

.home-page-paragraph {
  background: #002240 url(../images/watermark.png) no-repeat right bottom;
  color: #fff;
  padding: 20px;
  margin-top: 20px;
  margin-bottom: 60px;
}
.home-page-paragraph h4 {
  font-size: 1.5em;
}

.white-bg {
  background: #fff;
  padding: 20px;
  border-top: 5px solid #002240;
  margin-top: 20px;
}
.white-bg img {
  margin-top: 22px;
}

.form-input .inline-icon {
  position: absolute;
  color: #dddddd;
}
.form-input .inline-icon.fa-chevron-down, .form-input .inline-icon.fa-chevron-up {
  position: absolute;
  color: #dddddd;
  background: none;
  padding: 0;
  line-height: 35px;
  right: 0.5em !important;
  cursor: pointer;
}

.starting-field i, .destination-field i {
  cursor: pointer;
}
.starting-field i.active, .destination-field i.active {
  background: #40b0ff !important;
}

#trip-notes {
  height: auto;
}

#map-canvas {
  margin-top: 25px;
  box-shadow: 3px 3px 0px rgba(0, 0, 0, 0.1);
  border: 1px solid #002240;
}

.destination-title .highlight {
  color: #3C853B;
}

.stops-holder {
  margin: 0;
  padding: 0;
  padding-left: 0 !important;
  margin-top: 1em;
}
.stops-holder li {
  position: relative;
  list-style: none;
  color: #333;
  min-height: 30px;
  padding: 12px 20px 12px;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border-bottom: 1px solid #c8c8c8;
  background: white;
}
@media (min-width: 320px) and (max-width: 480px) {
  .stops-holder li {
    padding: 10px 10px 10px 10px;
  }
}
.stops-holder li.suggested-route {
  background: #e6ebef;
  border-left: 1px solid #d8d8d8;
  border-right: 1px solid #d8d8d8;
}
.stops-holder li.suggested-route.active {
  background: #0191c2;
  border-left: 1px solid #0191c2;
}
.stops-holder ol {
  margin: 0;
}

#map-canvas .trip-error-overlay {
  z-index: 100;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  color: white;
  text-align: center;
  display: none;
}
#map-canvas .trip-error-overlay span {
  display: block;
  top: 50%;
  font-weight: bold;
  position: relative;
}
#map-canvas .trip-error-overlay.active {
  display: block;
}

.routes h3, .stops h3 {
  margin-left: 0px;
}

#bus-departures form {
  overflow: auto;
}
#bus-departures a {
  word-wrap: break-word;
  color: #3c853b;
}

.bus-routes-list {
  overflow: hidden;
}
.bus-routes-list a {
  word-wrap: break-word;
}
.bus-routes-list .direction {
  min-height: 30px;
}
.bus-routes-list .direction .directions-icon {
  top: 50%;
  margin-top: -16px;
}
.bus-routes-list h2 {
  margin: 0;
  margin-bottom: 20px;
}
.bus-routes-list .stops-holder {
  margin: 0;
}
.bus-routes-list.close {
  height: 50px;
}

.direction-list .directions-icon, #bus-departures .directions-icon, #travel-directions .directions-icon {
  background: #fff;
  height: 1.5em;
  width: 1.5em;
  display: inline-block;
}
.direction-list .stops-holder .stop, #bus-departures .stops-holder .stop, #travel-directions .stops-holder .stop {
  border: 1px solid #e5e5e5;
  padding-left: 20px;
}
.direction-list .stops-holder .stop span, #bus-departures .stops-holder .stop span, #travel-directions .stops-holder .stop span {
  color: green;
}
.direction-list .stops-holder .suggested-route, #bus-departures .stops-holder .suggested-route, #travel-directions .stops-holder .suggested-route {
  padding-left: 10px;
}
.direction-list .directions-icon.map-pin, #bus-departures .directions-icon.map-pin, #travel-directions .directions-icon.map-pin {
  border: .3em solid #666;
}
.direction-list .directions-icon.stop-info, #bus-departures .directions-icon.stop-info, #travel-directions .directions-icon.stop-info {
  margin-top: -7px;
  display: inline-block;
  position: static;
  height: 1.5em;
  width: 1.5em;
  border: .2em solid #666;
  line-height: .85;
  margin-left: 10px;
  font-weight: normal;
}
.direction-list .directions-icon.inline, #bus-departures .directions-icon.inline, #travel-directions .directions-icon.inline {
  margin-top: -7px;
  display: inline-block;
  position: static;
  color: #666 !important;
  text-decoration: none;
}
.direction-list .help-tip, .direction-list .collapse, .direction-list #bus-departures .collapse, #bus-departures .direction-list .collapse, .direction-list #travel-directions .collapse, #travel-directions .direction-list .collapse, #bus-departures .help-tip, #bus-departures .collapse, #travel-directions .help-tip, #travel-directions .collapse {
  font-size: 30px;
  position: absolute;
  top: 5px;
  right: 5px;
  color: #49a348;
  cursor: pointer;
}
.direction-list .collapse, #bus-departures .collapse, #travel-directions .collapse {
  right: 40px;
  top: 10px;
  color: grey;
}
.direction-list .agencie, #bus-departures .agencie, #travel-directions .agencie {
  color: #49a348;
  font-size: 12px;
}
.direction-list .agencie a, #bus-departures .agencie a, #travel-directions .agencie a {
  color: #49a348 !important;
}

.departures.module .collapse {
  font-size: 30px;
  position: absolute;
  cursor: pointer;
  right: 15px !important;
  top: 10px;
  color: grey;
}
.departures.module .toolShowHide {
  font-size: .5em;
  float: right;
  padding: 5px;
}
@media only screen and (min-width: 767px) {
  .departures.module .toolShowHide {
    display: none;
  }
}

.suggested-route {
  cursor: pointer;
  overflow: hidden;
  -webkit-transition: border-color .25s, background-color .25s;
  -ms-transition: border-color .25s, background-color .25s;
  transition: border-color .25s, background-color .25s;
  box-shadow: 3px 3px 0px rgba(24, 74, 119, 0.1);
}
.suggested-route:hover {
  background-color: #fff !important;
}
.suggested-route.active {
  box-shadow: 3px 3px 0px rgba(0, 0, 0, 0.1);
  background-color: #0191c2 !important;
  color: white;
}
.suggested-route.active .directions-icon {
  background: white;
}
.suggested-route.active .direction-wrapper .dash-arrow {
  background: white;
  color: #002240;
}
.suggested-route.active i.fa.fa-arrow-right {
  color: white;
}
.suggested-route.active .time-wrapper {
  color: #fff;
}
.suggested-route.active .directions-time {
  margin-top: 5px;
  padding: 5px;
  color: #002240;
}
.suggested-route.active .directionsBtn {
  color: #002240;
  background: #fff;
}
.suggested-route.active .directionsBtn:hover, .suggested-route.active .directionsBtn:focus {
  color: #002240;
  background: #eee;
}
.suggested-route ul {
  margin: 0;
  margin-top: 10px;
}
.suggested-route .directions-map {
  display: block;
  overflow: hidden;
  padding: 0 10px;
}
@media (min-width: 320px) and (max-width: 480px) {
  .suggested-route .directions-map {
    padding: 0;
  }
}
.suggested-route .walking-direction, .suggested-route .transit-direction {
  display: inline-block;
  margin-right: 5px;
}
.suggested-route .direction-wrapper {
  position: relative;
  float: left;
  width: 100%;
}
.suggested-route .direction-wrapper .dash {
  position: relative;
  top: -10px;
  padding-right: 5px;
  display: inline;
}
.suggested-route .direction-wrapper .dash-arrow {
  background: white;
  color: #002240;
  padding-left: 30px;
  margin-left: -33px;
  position: relative;
  z-index: 1;
  border-radius: 3px;
  height: 32px;
  width: 80px;
  padding-top: 4px;
  display: inline-block;
  top: -11px;
}
.suggested-route .time-wrapper {
  width: 48%;
  border-radius: 2px;
  padding: 5px;
  color: #333;
}
.suggested-route .directions-time {
  font-size: 16px;
  font-weight: bold;
  margin-top: 5px;
  padding: 5px;
  color: #002240;
}
.suggested-route .directionsBtn {
  display: none;
  cursor: pointer;
  text-align: center;
  float: left;
  background: #49a348;
  width: 100%;
  border-radius: 2px;
  padding: 5px;
  color: white;
  margin-top: 10px;
}
.suggested-route .directionsBtn:hover, .suggested-route .directionsBtn:focus {
  background: #5cb95b;
}
.suggested-route .directions-icon {
  background: white;
  margin-right: 5px;
  display: inline-block;
  position: relative;
  z-index: 2;
  height: 2em;
  width: 2em;
  border-radius: 3px;
  padding-top: 10px;
}
.suggested-route .directions-icon.next-bus {
  margin-left: -10px;
}
.suggested-route .directions-icon img {
  margin-top: -10px;
}
.suggested-route .suggested-time {
  display: inline-block;
  padding-top: 10px;
  font-weight: bold;
}
.suggested-route .start-end-time {
  padding-top: 5px;
  font-size: .9em;
  color: #666;
}
.suggested-route i.fa.fa-arrow-right {
  color: #aaa;
}

/* Updated Suggested Routes */
.route-times {
  overflow: hidden;
  padding: 0 10px;
}
@media (min-width: 320px) and (max-width: 480px) {
  .route-times {
    padding: 0;
  }
}
.route-times p {
  overflow: hidden;
}
.route-times .route-option {
  color: #fff;
  background: #002240;
  border-radius: 99px;
  font-size: 1.25em;
  line-height: 1.75em;
  width: 1.75em;
  height: 1.75em;
  display: inline-block;
  text-align: center;
  margin-top: 5px;
}

.active .route-times .route-option {
  color: #002240;
  background: #f2f6fa;
}

.route-times-data {
  display: block;
  float: right;
  text-align: right;
}
.route-times-data .time-wrapper {
  padding: 0;
}

.direction {
  overflow: inherit !important;
}

.instruction-holder .direction-list {
  width: 80%;
}

.direction-list .direction {
  font-size: 1.25em;
  list-style: none;
  border-left: 2px solid #002240;
  margin-left: 8px;
}
.direction-list .direction .directions-icon {
  border: none;
  width: 1.25em;
  height: 1.25em;
  padding-top: 10px;
  margin-left: -4px;
}
.direction-list .direction img {
  width: 100%;
}
.direction-list .direction span strong {
  margin-right: 10px;
}
.direction-list .direction .agencie {
  float: right;
  color: #49a348;
  font-size: 12px;
}
.direction-list .direction .agencie a {
  color: #49a348 !important;
}
@media (min-width: 320px) and (max-width: 480px) {
  .direction-list .direction .agencie {
    float: right;
    font-size: 12px;
    background: rgba(73, 163, 72, 0.14);
    font-weight: bold;
    line-height: 1.4em;
    width: 100%;
    padding-left: 5px;
  }
  .direction-list .direction .agencie span {
    padding-top: 5px;
    display: block;
  }
  .direction-list .direction .agencie a {
    text-decoration: underline;
    width: 100%;
    display: block;
    padding: 5px 0 5px 0px;
  }
}
.direction-list .direction .instructions {
  margin: 10px 10px 10px 20px;
  font-size: .7em;
  color: #0191c2;
  background: #F9F9F9;
  padding: 10px;
  width: 100%;
}
.direction-list .direction .wrapper {
  padding-bottom: 11px;
  padding-left: 30px;
}
.direction-list .direction .wrapper .continue {
  font-size: .7em;
}
.direction-list .direction .wrapper .continue p {
  margin: 1em 0 1em 0;
}
.direction-list .direction .wrapper .route-alerts {
  margin: 10px 0 18px 20px !important;
  padding-left: 0px !important;
  list-style: none;
  color: #EF7B2D;
}
.direction-list .direction .wrapper .route-alerts li .fa {
  margin-right: 8px;
  color: #EF7B2D !important;
}
.direction-list .direction .wrapper .route-alerts li a {
  font-size: 0.8em !important;
  color: #EF7B2D;
}
.direction-list .direction .header {
  position: relative;
  margin-top: -2px;
  padding-left: 25px;
  padding-bottom: 5px;
}
.direction-list .direction .header i {
  position: absolute;
  top: 3px;
  right: 0px;
  color: #ef7b2d;
}
.direction-list .direction .arrivalTime {
  margin-left: 20px;
  font-size: .7em;
  color: #0191c2;
  background: #F9F9F9;
  padding: 5px;
  margin-top: 5px;
  margin-bottom: 5px;
  display: block;
  width: 100%;
}
@media (min-width: 320px) and (max-width: 480px) {
  .direction-list .direction .arrivalTime {
    margin-left: -5px;
    width: 102%;
  }
}
.direction-list .direction .arrivalStop {
  font-weight: 300;
}
@media (min-width: 320px) and (max-width: 480px) {
  .direction-list .direction .arrivalStop {
    padding-left: 5px;
  }
  .direction-list .direction .arrivalStop .label {
    font-weight: bold;
    font-size: .7em;
    width: 100%;
    display: block;
    line-height: .7em;
    padding-top: 10px;
  }
  .direction-list .direction .arrivalStop .value {
    font-size: .6em;
    line-height: 1.4em;
    padding-top: 5px;
    margin: 0;
    padding-bottom: 0px;
    display: block;
  }
}
.direction-list .direction.last {
  border-left: none;
  position: relative;
  height: 40px;
}
.direction-list .direction.last .step-icon {
  position: absolute;
  top: 0px;
  z-index: 1;
  width: 240px;
  height: 36px;
  border-radius: 20px;
  background: #002240;
}
.direction-list .direction.last .header {
  position: absolute;
  z-index: 20;
  top: 1px;
  color: white;
}
.direction-list .direction.last img {
  position: absolute;
  top: 1px;
  left: 1px;
  z-index: 1000;
  background: white;
  border-radius: 50%;
  width: 30px;
}
@media (min-width: 320px) and (max-width: 480px) {
  .direction-list .direction.last {
    background: transparent;
    padding: 0;
  }
  .direction-list .direction.last .step-icon {
    border-radius: 0px;
    border: none;
    background: transparent;
    left: 10px;
    top: 2px;
    z-index: 100;
  }
  .direction-list .direction.last .header {
    background: #002240;
    width: 100%;
    height: 40px;
    padding-top: 9px;
    padding-left: 25px;
    position: relative;
  }
}
.direction-list .direction.walking {
  border-left: 2px dashed #002240;
}
.direction-list .direction.walking .arrival-stop-icon {
  display: none;
}
.direction-list .direction.transit .spacer {
  margin-bottom: 30px;
}
.direction-list .direction .step-icon {
  float: left;
  display: block;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: white;
  border: 2px solid #002240;
  margin-left: -16px;
  margin-top: -7px;
}
.direction-list .direction .arrival-stop-icon {
  width: 20px;
  height: 20px;
  background: white;
  border: 2px solid #002240;
  margin-left: -40px;
  border-radius: 50%;
  float: left;
  margin-top: -44px;
}

.direction.hide, .note.hide {
  display: none;
}

.select-stop {
  position: absolute;
  top: 20px;
  right: -7px;
}
.select-stop input {
  height: 16px;
  width: 16px;
}

.site-alerts {
  margin: 0 0 1em;
}
.site-alerts ul {
  padding-left: 0 !important;
}
.site-alerts .alert {
  position: relative;
  color: white;
  background: #ef7b2d;
  padding: 10px;
  border-radius: 3px;
}
.site-alerts .alert.upcoming {
  background: grey;
}
.site-alerts .alert.upcoming .affected-route-alerts a {
  color: grey;
}
.site-alerts .alert.upcoming .future-message {
  margin-left: 43px;
}
.site-alerts .alert .icon {
  font-size: 2em;
}
.site-alerts .alert .title {
  position: absolute;
  top: 20px;
  padding-left: 10px;
  margin-top: -5px;
  color: white;
  font-size: 1.5em;
  text-transform: uppercase;
}
.site-alerts .alert .details {
  float: right;
  position: absolute;
  text-decoration: underline;
  line-height: 20px;
  top: 10px;
  right: 10px;
}
.site-alerts .alert a {
  color: white;
}
.site-alerts .alert .affected-route-alerts {
  margin-top: 4px;
  margin-left: 45px;
}
.site-alerts .alert .affected-route-alerts a {
  color: #ef7b2d;
}

.alert-list {
  margin: 0 0 1em;
}
.alert-list .multiple-alerts {
  color: #ef7b2d;
}
.alert-list .multiple-alerts .icon:first-of-type {
  margin-right: 8px;
}
.alert-list .multiple-alerts a {
  float: right;
  color: #ef7b2d;
}
.alert-list ul {
  display: none;
  padding-left: 0 !important;
  list-style-type: none;
}
.alert-list .alert {
  position: relative;
  color: white;
  background: #ef7b2d;
  padding: 10px;
  border-radius: 3px;
  margin-bottom: 10px;
}
.alert-list .alert.upcoming {
  background: grey;
}
.alert-list .alert.upcoming .affected-route-alerts a {
  color: grey;
}
.alert-list .alert.upcoming .future-message {
  margin-left: 43px;
}
.alert-list .alert .icon {
  font-size: 2em;
  float: left;
  padding-bottom: 50px;
  position: absolute;
  top: 50%;
  margin-top: -15px;
}
.alert-list .alert .date {
  color: white;
  display: block;
  margin-left: 43px;
}
.alert-list .alert .title {
  display: block;
  top: 20px;
  margin-left: 43px;
  margin-top: 0;
  margin-bottom: 10px;
  color: white;
  font-size: 1.5em;
}
.alert-list .alert a {
  color: white;
}
.alert-list .alert .affected-route-alerts {
  margin-top: 4px;
  margin-left: 45px;
}
.alert-list .alert .affected-route-alerts a {
  color: #ef7b2d;
}

@media print {
  .alert-list, #travel-routes {
    display: none;
  }

  .instruction-holder {
    margin-left: 20px;
  }
}
.affected-route-alerts {
  overflow: hidden;
  margin-top: 1.5em;
}
.affected-route-alerts ul {
  margin: 0;
  padding: 0;
}
.affected-route-alerts ul li {
  display: inline;
  list-style: none;
  font-weight: bold;
  margin-right: 2px;
  width: 100%;
}
.affected-route-alerts ul li a {
  background: #fff;
  color: #002240;
  font-size: 0.9em;
  display: inline-block;
  line-height: 1em;
  font-family: Arial, sans-serif;
  padding: 0.4em 0.6em;
  border-radius: 5px;
  text-align: center;
  min-width: 1.1em;
  margin-bottom: 5px;
}
.affected-route-alerts strong {
  font-size: 0.6875em;
  text-transform: uppercase;
  display: block;
  line-height: 1em;
  margin-bottom: 1em;
}
.affected-route-alerts .today {
  float: left;
  margin-right: 20px;
  margin-bottom: 1.2em;
}
.affected-route-alerts .today strong {
  color: #f8a144;
}
.affected-route-alerts .today a {
  background-color: #f8a144;
  color: #fff;
}

.module.news {
  border-bottom: 1px solid #e8e8e8;
}
.module.news .title {
  border-bottom: 1px solid #e8e8e8;
}
.module.news ul {
  margin-left: 35px;
}
.module.news h4 {
  padding-left: 1em !important;
}
.module.news .news-article-short {
  border-bottom: 1px solid #e8e8e8;
  padding: 1em 1em 2em 2em;
}
.module.news .news-article-short h3 {
  margin: 0;
  font-size: 1.4625em;
  line-height: 1.1em;
  font-family: "Helvetica Neue", Arial, sans-serif;
  padding: 0;
}
@media screen and (min-width: 1100px) {
  .module.news .news-article-short h3 {
    font-size: 1.9em;
    padding: 0;
  }
}
.module.news .news-article-short .date {
  margin: 0.4em 0 0.7em;
}
.module.news .news-article-short h3 a {
  font-weight: normal;
}
.module.news .news-article-short p {
  display: inline;
  margin-bottom: 0px !important;
  margin-top: 0px !important;
  padding: 0 0 1em 0;
}
.module.news .news-article-short .tags {
  font-style: italic;
  font-size: 0.875em;
  color: #7c8790;
  display: block;
}
.module.news .news-article-short .read-more {
  margin-top: 1em;
  width: 7em;
}
.module.news .news-article-short .read-more:before {
  content: "...";
  display: inline;
}
.module.news .news-article-short footer {
  padding: 0;
}
.module.news .news-article-short:last-of-type {
  border-bottom: none;
}
.module.news .click-more {
  color: #002240;
  font-size: 1em;
  position: absolute;
  top: 0.85em;
  right: 0.9em;
  line-height: 1em;
  font-weight: bold;
  color: #004b8d;
}

.date {
  color: #1e2c39;
  font-size: 0.75em;
  letter-spacing: 1px;
  text-transform: uppercase;
  display: block;
}

#twitter-widget-0 {
  height: 390px !important;
  overflow-y: auto;
}

.ie9 .filter-wrap i {
  display: none !important;
}

.module.news, .module.video {
  float: left;
  display: block;
  margin-right: 2.325%;
  width: 48.8375%;
}
.module.news:last-child, .module.video:last-child {
  margin-right: 0;
}

.module.callout, .module.ad, .social {
  display: inline-block;
  vertical-align: top;
  width: 32%;
  margin-right: .75em;
}

.module.callout img, .module.ad img {
  min-width: 100%;
}

.social {
  margin-right: 0;
  background: #fff;
  box-shadow: 2px 2px 0px #e2e9f0;
}

.module.video {
  margin-right: 0;
}
.module.video .click-more {
  color: #002240;
  font-size: 1em;
  position: absolute;
  top: 0.85em;
  right: 0.9em;
  line-height: 1em;
  font-weight: bold;
  color: #004b8d;
}

.transit-future img {
  margin-bottom: 1em;
}

.ui-tabs-nav li a {
  width: 100%;
  color: #3c853b;
}

.social {
  clear: both;
}
.social .ui-tabs {
  margin-top: 0px;
}
.social .ui-tabs-panel {
  padding-left: 10px;
  padding-right: 20px;
  max-height: 500px;
}
.social .twitter-tab {
  font-size: .75em;
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1em;
  width: 48%;
}
.social .twitter-tab .icon-twitter {
  margin-left: 15px;
}
.social .twitter-tab a {
  color: #55ACEE;
  border-right: none !important;
}
.social .facebook-tab {
  font-size: .75em;
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1em;
  width: 52%;
}
.social .facebook-tab .icon-facebook {
  margin-left: 15px;
}
.social .facebook-tab a {
  color: #3c5a96;
  border-right: 0;
}
.social #tabs-1 {
  padding: 5px;
}
.social #tabs-1 iframe {
  width: 100%;
}

.ui-tabs .ui-tabs-nav li.ui-tabs-active.facebook-tab a {
  border-top: 5px solid #3c5a96;
}

.ui-tabs .ui-tabs-nav li.ui-tabs-active.twitter-tab a {
  border-top: 5px solid #55acee;
}

.fares .ui-tabs .ui-tabs-nav li a {
  padding: 7px 5px;
}

.breadcrumb {
  border-bottom: 1px solid #e8e8e8;
}
.breadcrumb ul {
  margin: 0;
  padding: 10px 0 0.2em;
  padding-left: 0 !important;
}
.breadcrumb li {
  display: inline;
  list-style: none;
  padding-right: 5px;
}
.breadcrumb a {
  color: #7d877d;
  font-size: 0.9em;
  margin-right: 10px;
}
.breadcrumb a:hover, .breadcrumb a:focus {
  text-decoration: underline;
}

.bus-holder {
  position: relative;
  top: 40px;
  margin-top: -40px;
  z-index: 2;
  padding-left: 4%;
  padding-right: 4%;
}
.bus-holder .bus-logo {
  background: url(../images/bus-icon.png) no-repeat;
  margin: 0 auto;
  height: 100px;
  width: 90px;
  display: block;
}

.site-message {
  position: relative;
  text-align: center;
  color: #fff;
  background: #001a31;
  font-size: 2em;
  line-height: 1em;
}
.site-message p {
  margin: 0;
  padding: 0.7em 0 0.8em;
}
.site-message p em {
  font-style: normal;
}

.two-content .highlight .title {
  color: #1f1f1f;
  margin: 0 0 1em;
}
.two-content .highlight a img:hover {
  opacity: .75;
}

.site-footer {
  border-top: 1px solid #12324d;
}
.site-footer h4 {
  margin: 2em 0 0.5em 0;
  color: #fff;
  font-weight: bold;
  text-transform: uppercase;
  font-size: 0.97em;
}
.site-footer h4 a {
  color: #fff;
  display: block;
}
.site-footer a {
  color: #bed6ec;
}
.site-footer a:hover, .site-footer a:focus {
  text-decoration: underline;
}

.site-footer ul {
  padding: 0;
  margin: 0 0 1em;
}
.site-footer ul li {
  margin-bottom: 0.5em;
  font-size: 0.9375em;
}
.site-footer ul a {
  color: #f4f7f9;
  display: block;
  line-height: 1.3em;
}

.site-footer .legal {
  padding: 20px 0 20px 75px;
  background: url(../images/icn-bus.png) no-repeat left center;
}
.site-footer .legal a {
  display: inline-block;
  padding: 0.3em;
}
.site-footer .legal li {
  display: inline;
  font-size: 0.82em;
  margin-right: 0.5em;
}

.site-copyright {
  position: relative;
}
.site-copyright .site-title {
  padding: 0;
  background: none;
  border: none;
  height: auto;
  margin-top: 1px;
  margin-left: 4%;
}
.site-copyright .site-title a {
  width: 180px;
  height: 37px;
  padding: 10px 0;
}
.site-copyright .to-top {
  position: absolute;
  right: 4%;
  top: 6px;
  width: 25%;
  text-align: right;
}

.copyright {
  font-size: 0.78em;
  color: #8ea5ba;
  text-align: center;
  display: block;
  margin: 0;
  width: 100%;
  position: absolute;
  left: 0;
  top: -30px;
}

/* Top Anchor */
#top {
  position: relative;
  top: -100px;
  display: block;
}

/* Events Sidebar */
.sidebar-event h3, .sidebar-media h3, .sidebar-contact h3 {
  margin-top: 0;
  padding-top: 1em;
  border-top: 1px solid #e8e8e8;
}
.sidebar-event h4, .sidebar-media h4, .sidebar-contact h4 {
  margin-bottom: 0;
}
.sidebar-event ul, .sidebar-media ul, .sidebar-contact ul {
  list-style-type: none;
}
.sidebar-event ul li, .sidebar-media ul li, .sidebar-contact ul li {
  margin-bottom: .75em;
}

/* Filters */
.filter-wrap {
  float: left;
  position: relative;
  overflow: hidden;
  margin-bottom: 10px;
}
.filter-wrap select {
  display: block;
  font-size: 20px;
  margin: 0 10px 0 0;
  background: #f4f7f9;
  color: #485056;
  padding-left: 5px;
  padding-right: 30px;
  font-size: 13px;
  min-width: 150px;
  line-height: 20px;
  font-weight: bold;
  border: 1px solid rgba(0, 0, 0, 0.25);
  border-radius: 3px;
  height: 30px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  text-indent: 1px;
  text-overflow: '';
  outline: none;
}
.filter-wrap select::-ms-expand {
  display: none;
}
.filter-wrap select:focus {
  border: 1px solid rgba(0, 0, 0, 0.75);
}
.filter-wrap i {
  display: block;
  position: absolute;
  color: #485056;
  top: 0;
  line-height: 25px;
  right: 17px;
  margin-left: 5px;
  height: 100%;
  pointer-events: none;
}
.filter-wrap i:after {
  content: "|";
  text-indent: -9999em;
  font-size: 2em;
  width: 1px;
  height: 100px;
  top: 1px;
  right: 15px;
  position: absolute;
  border-right: 1px solid rgba(255, 255, 255, 0.25);
}

.filter-module {
  margin: 0 0 1em 0;
  background: #002240;
  padding: 20px;
  min-height: 125px;
}
.filter-module.small {
  min-height: 82px !important;
  overflow: hidden;
}
.filter-module.small .filter-wrap {
  clear: both;
}
.filter-module form {
  padding: 0;
}
.filter-module .filter-wrap select {
  background: #143a5b;
  color: #c0d7e7;
  border: 1px solid rgba(255, 255, 255, 0.1);
}
.filter-module .filter-wrap select:focus {
  border: 1px solid rgba(255, 255, 255, 0.4);
}
.filter-module .filter-wrap i {
  color: #c0d7e7;
}
.filter-module .filter-wrap i:after {
  border-right: 1px solid rgba(255, 255, 255, 0.1);
}

/*** NEXT DEPARTURES MODULE */
.nextDeparturesPage .nextDeparturesHead {
  width: 100%;
  border: 1px solid #143a5b;
  height: 50px;
  position: relative;
}
.nextDeparturesPage .nextDeparturesHead input {
  border: none;
  border-radius: 0px;
  font-size: 2em;
  font-weight: 300;
  width: 90%;
  padding-top: 3px;
  padding-left: 5px;
}
.nextDeparturesPage .nextDeparturesHead .fa {
  font-size: 2em;
  position: absolute;
  width: 60px;
  height: 60px;
  padding: 20px;
  top: -15px;
  color: #143a5b;
  cursor: pointer;
  right: 0px;
}
.nextDeparturesPage .nextDeparturesHead .fa.disabled {
  color: #22629a;
  pointer-events: none;
}
.nextDeparturesPage .nextDeparturesHead .helptext {
  margin-top: 15px !important;
}
.nextDeparturesPage .spinner {
  right: 30px !important;
  top: 19px !important;
}
.nextDeparturesPage h3.nextDepartures {
  display: none;
}
.nextDeparturesPage h3.nextDepartures.active {
  margin-top: 50px;
  display: block;
}
.nextDeparturesPage ul {
  margin: 20px 0 0;
  padding-left: 0px !important;
}
.nextDeparturesPage ul li {
  position: relative;
  list-style: none;
  border: 1px solid rgba(177, 202, 234, 0.3);
  margin-bottom: 10px;
}
.nextDeparturesPage ul li .header {
  padding: 10px;
  background: rgba(177, 202, 234, 0.3);
  margin-bottom: 5px;
  overflow: hidden;
  *zoom: 1;
}
.nextDeparturesPage ul li .header .routeName {
  float: left;
  text-transform: uppercase;
  font-size: .9em;
  font-weight: 400;
}
.nextDeparturesPage ul li .header .routeName span {
  background: #5cb95b;
  border-radius: 5px;
  color: white;
  padding: 2px 4px 2px 4px;
  font-weight: bold;
  font-size: 1em;
  white-space: nowrap;
}
.nextDeparturesPage ul li .header .arrivalSeconds {
  float: left;
  font-size: 1em;
  font-weight: 700;
  color: #143a5b;
  line-height: 16px;
  margin-left: 10px;
  width: 80%;
  font-weight: normal;
  text-transform: uppercase;
  background: white;
  padding: 2px 6px 4px 7px;
  border-radius: 5px;
}
.nextDeparturesPage ul li .footer {
  padding: 0px 10px 10px 10px;
}
.nextDeparturesPage ul li .footer .arrival-time {
  position: absolute;
  top: 15px;
  right: 5px;
  font-size: 1em;
  font-weight: 700;
  text-align: right;
}
.nextDeparturesPage ul li .footer .arrival-time span {
  color: #2ab1ec;
  font-size: 1.2em;
}
.nextDeparturesPage ul li .footer .stop-name {
  font-size: 1em;
}
.nextDeparturesPage ul li .footer .headsign {
  width: 80%;
  font-size: 1.3em;
  color: #143a5b;
  font-weight: 400;
  margin-bottom: 5px;
}

/****************************/
/** TOOL TIP **/
#tooltip {
  text-align: center;
  color: #fff;
  background: #111;
  position: absolute;
  z-index: 100;
  padding: 15px;
}
#tooltip:after {
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 10px solid #111;
  content: '';
  position: absolute;
  left: 50%;
  bottom: -10px;
  margin-left: -10px;
}
#tooltip.top:after {
  border-top-color: transparent;
  border-bottom: 10px solid #111;
  top: -20px;
  bottom: auto;
}
#tooltip.left:after {
  left: 26px;
  margin: 0;
}
#tooltip.right:after {
  right: 26px;
  left: auto;
  margin: 0;
}

/******/
.home-page .module.news button {
  margin: 1em;
}
.home-page .module.news button a.news-more {
  color: white;
}
.home-page .news-item {
  padding-bottom: 0 !important;
  border-bottom: none !important;
}
.home-page .news-item ul, .home-page .news-item h4 {
  padding: 1em !important;
  margin: 0 !important;
}
.home-page .news-item p {
  margin-bottom: 0 !important;
}
.home-page .news-item li {
  list-style: none !important;
}

/* News List */
.news-list {
  border-top: 1px solid #e8e8e8;
  padding-bottom: 20px;
}
.news-list h4 {
  margin: 0 0 1em 0;
  padding-top: 1em;
  font-size: 1.4em;
  max-width: 60%;
}
.news-list ul {
  list-style-type: none;
}
.news-list button {
  margin-top: 20px;
}

.news-item {
  position: relative;
  padding-bottom: 18px;
  border-bottom: 1px solid #e8e8e8;
  padding-bottom: 0;
  border-bottom: none;
}
.news-item:last-of-type {
  border-bottom: none;
}
.news-item h4 {
  max-width: 60%;
}
.news-item hr {
  margin: 0;
  height: auto;
}

.news-date {
  position: absolute;
  display: block;
  margin-top: 10px;
  top: 0;
  right: 0;
  margin: 0 !important;
  max-width: 170px;
  background: #e8e8e8;
  font-style: italic;
}
.news-date span {
  width: 100%;
  display: block;
  float: left;
  padding: 10px;
}

.news-author {
  float: left;
  padding: 10px;
  width: 100%;
  background: #1AB0EF;
  color: white;
  display: none;
}

.content-page .news-author {
  margin-bottom: 1em;
  background: none;
  color: inherit;
  padding: 0;
  font-size: 16px;
  float: left;
  width: 50%;
}
.content-page .news-author i {
  margin-right: 1em;
}
.content-page .news-header {
  width: 100%;
  min-height: 40px;
}
.content-page .news-date {
  position: relative;
  float: right;
  background: none;
}

.news-item ul, .event-item ul {
  padding-left: 0 !important;
}

/* Event List */
.event-list-page h1.page-title {
  margin-bottom: 0;
}

.event-list {
  padding-bottom: 20px;
}
.event-list h4 {
  margin: 0 0 1em 0;
  padding-top: 1em;
  font-size: 1.4em;
  max-width: 60%;
}
.event-list ul {
  list-style-type: none;
}
.event-list button {
  margin-top: 20px;
}

.event-item {
  position: relative;
  padding-bottom: 18px;
  border-bottom: 1px solid #e8e8e8;
}

.event-date {
  position: absolute;
  display: block;
  margin-top: 10px;
  top: 0;
  right: 0;
  margin: 0 !important;
  padding: 1em 10px;
  background: #e8e8e8;
  font-style: italic;
}

/* Contact Page */
form#contact label {
  text-indent: -9999px;
  height: 0;
  display: block;
}
form#contact label.error-message {
  display: inline;
  text-indent: 0px;
  color: #F00;
  margin-top: 4px;
}
form#contact .form-input {
  margin-bottom: 0.5em;
  padding: 0.4em 0;
  border: none;
}
form#contact textarea {
  margin-bottom: 0 !important;
  padding-left: 0.6em !important;
  padding-right: 0.6em !important;
  width: 100%;
  min-height: 180px;
  border: 1px solid rgba(0, 0, 0, 0.25) !important;
}
form#contact textarea.failed {
  border: 1px solid red !important;
}
form#contact .input-text {
  border: 1px solid rgba(0, 0, 0, 0.25);
}
form#contact .input-text.failed {
  border: 1px solid red;
}
form#contact .half-width-left {
  clear: left;
}
form#contact fieldset#message {
  margin-bottom: 0.5em;
}

/* Alerts Page */
.alerts-list-page h1.page-title {
  margin-bottom: 0;
}

.alerts-list-filter {
  background: #143a5b;
  padding: 20px;
}
.alerts-list-filter p {
  margin: 1em 0 0.6em;
  color: #fff;
}
.alerts-list-filter label {
  margin-right: 1em;
  color: #fff;
}

.alerts-filter-wrap {
  overflow: hidden;
}

.list-alerts-wrap {
  margin-top: 20px;
}

.list-alerts {
  padding: 20px;
  border-bottom: 1px solid #e8e8e8;
}
.list-alerts .exclamation-alert a {
  color: #ef7b2d;
}
.list-alerts .info-alert a {
  color: grey;
}
.list-alerts i {
  font-size: 30px;
  padding: 10px;
  margin: 0 18px 50px 0;
  display: block;
  float: left;
  overflow: auto;
  border-radius: 5px;
}
.list-alerts .fa-exclamation-triangle {
  color: white;
  background: #ef7b2d;
}
.list-alerts .fa-info {
  color: white;
  background: grey;
  width: 50px;
  text-align: center;
}
.list-alerts .date {
  display: inline-block;
  font-size: 1em;
}
.list-alerts .title {
  font-size: 1.125em;
}
.list-alerts .alerts, .list-alerts .affected-route-alerts {
  margin-top: 1em;
}
.list-alerts .alerts li a, .list-alerts .affected-route-alerts li a {
  color: #fff;
  background: #49a348;
}
.list-alerts .alerts li a:hover, .list-alerts .affected-route-alerts li a:hover {
  background: #5cb95b;
}
.list-alerts .alert {
  position: relative;
}
.list-alerts .alert-body {
  float: left;
  width: 80%;
}
.list-alerts .exclamation-alert li a {
  background: #ef7b2d;
}
.list-alerts .exclamation-alert li a:hover {
  background: #f08d4a;
}
.list-alerts .info-alert li a {
  background: grey;
}
.list-alerts .info-alert li a:hover {
  background: #aaa;
}

/* Alerts Detail Page */
.alerts-details-page .alert-type .alert.upcoming, .alerts-details-page .alert-type .active-message {
  color: #ef7b2d;
}

.next-bus-wrap {
  margin-top: 20px;
}

.next-bus {
  padding: 20px;
  border-bottom: 1px solid #e8e8e8;
}
.next-bus .route-number {
  display: inline-block;
  background: #49a348;
  border-radius: 3px;
  text-align: center;
  width: 50px;
  padding: 5px 0;
  color: #fff;
  font-weight: 700;
  float: left;
  margin-top: 5px;
  margin-bottom: 20px;
  margin-right: 18px;
  font-size: 1.125em;
}
.next-bus .route-number:hover {
  background: #5cb95b;
}
.next-bus .date {
  display: inline;
  font-size: 1em;
}
.next-bus .title {
  font-size: 1.125em;
}
.next-bus a {
  color: #3c853b;
}

.alerts-details-page .route-icons {
  list-style-type: none;
  overflow: hidden;
}
.alerts-details-page .route-icons li {
  float: left;
  margin-right: 8px;
}
.alerts-details-page .route-icons li a {
  border-radius: 5px;
  text-align: center;
  color: #fff;
  display: block;
  min-width: 1.1em;
  padding: 0.3em 0.6em;
  background: #49a348;
  font-weight: 700;
  margin-bottom: 10px;
}
.alerts-details-page .route-icons li a:hover {
  background: #5cb95b;
}

.route-icons {
  padding-left: 0px !important;
}

/* Transit Future Page */
.call-to-action .action-box {
  background: #49a348;
  padding: 16px;
  color: #fff;
  border-radius: 2px;
}
.call-to-action .action-box h3 {
  margin-top: 0;
}
.call-to-action .action-box p {
  margin-bottom: 0;
}

/* Search Results Page */
@media only screen and (min-width: 768px) {
  .search-results-page .one-content {
    width: 100%;
    padding: 0 28px;
  }
}
.page-title-wrap {
  width: 94%;
}

.search-results-page .page-title {
  color: #fff;
  font-size: 1.8em;
  text-shadow: 1px 2px 0 rgba(0, 34, 64, 0.43);
}

.search-results-page .content-inner h3 {
  padding-top: 20px;
  padding-bottom: 10px;
}
.search-results-page .filter-module {
  min-height: 80px;
  margin-top: 25px;
  overflow: hidden;
}
.search-results-page .searchresults-filter-wrap {
  float: left;
  width: 100%;
}
.search-results-page .filter-module p {
  color: #fff;
}
.search-results-page .search-results {
  clear: both;
}
.search-results-page .search-results ul {
  list-style-type: none;
  padding-left: 0;
}
.search-results-page .search-results li {
  border-bottom: 1px solid #e8e8e8;
  padding: 20px 0;
}
.search-results-page .search-results a {
  font-size: 1.5em;
  margin-bottom: .75em;
  display: block;
}
.search-results-page .searchresults-list-filter input#region-list {
  width: 76%;
  height: 39px;
}
.search-results-page .searchresults-list-filter button.inline-input-button {
  height: 39px;
}
@media only screen and (max-width: 1120px) and (min-width: 768px) {
  .search-results-page .sidemenu .side-panel {
    right: 0;
  }
}
@media only screen and (max-width: 767px) {
  .search-results-page .side-panel {
    top: 10px;
    float: none;
  }
}

/* Account Pages */
.account-signup-page .section.one-content, .account-details-page .section.one-content {
  width: 100%;
  padding-right: 28px;
}

form.sign-up label {
  text-indent: -9999px;
  height: 0;
  display: block;
}

form.sign-up .form-input {
  padding: 0.4em 0.6em;
}

.button-clear {
  background: #1ab0ef;
}

.button-clear:hover, .button-clear:focus {
  background: #56c2ef;
}

.my-regions, .my-routes {
  border-top: 1px solid #e8e8e8;
  padding-bottom: 30px;
  overflow: hidden;
}
.my-regions h4, .my-routes h4 {
  margin-bottom: .75em;
}

.region-text-list, .route-text-list {
  clear: both;
  overflow: hidden;
  margin-bottom: 20px;
  background: #e8e8e8;
  padding: 10px 0;
}
.region-text-list ul, .route-text-list ul {
  list-style-type: none;
  padding-left: 0 !important;
  margin: 0;
}
.region-text-list ul li, .route-text-list ul li {
  width: 100%;
}
.region-text-list ul li p, .route-text-list ul li p {
  margin: 0;
}

.half-right .region-name, .half-right .route-name {
  float: left;
  width: 65%;
  padding-left: 18px;
}
.half-right .region-radio, .half-right .route-check {
  float: left;
  width: 25%;
}
.half-right .region-delete, .half-right .route-delete {
  float: left;
  width: 10%;
}

.region-delete-button, .route-delete-button {
  background: #bbb;
  font-size: 1.5em;
  padding: 0 .2em;
  text-align: center;
  float: right;
  margin-right: 10px;
}

.region-delete-button:hover, .route-delete-button:hover {
  background: #56c2ef;
}

.tt-dropdown-menu {
  margin-top: -2px;
  max-height: 300px;
  overflow: scroll;
}
.tt-dropdown-menu .tt-dataset-states {
  max-height: 300px;
}

.twitter-typeahead {
  width: 100%;
  background: #fff;
}

.tt-suggestion {
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  cursor: pointer;
}
.tt-suggestion:hover, .tt-suggestion.tt-cursor {
  color: white;
}

#region-list {
  width: 100%;
  position: relative;
  vertical-align: top;
  background-color: white;
}

.half-right .tt-query, .half-right .tt-hint {
  border: 1px solid rgba(0, 0, 0, 0.25);
  border-radius: 0;
  border-top-left-radius: 2px;
  border-bottom-left-radius: 2px;
  font-size: 1em;
  padding: 0.6em 0.5em 0.8em;
  height: 38px;
  width: 100%;
}
.half-right span.tt-dropdown-menu {
  background-color: #fff;
  border: 1px solid #ccc;
  margin-top: -15px;
  width: 100%;
  padding-left: 10px;
}
.half-right div.tt-suggestion.tt-is-under-cursor {
  background-color: #ccc;
}
.half-right div.tt-suggestion > p {
  margin: 0;
  line-height: 35px;
}
.half-right span.twitter-typeahead {
  width: 100%;
}

/* login page */
.login-wrapper {
  background: #fff;
  width: 50%;
  margin: 0 auto;
  border-top: 5px solid #002240;
  padding: 20px 40px;
}
.login-wrapper fieldset {
  margin-bottom: 10px;
}
.login-wrapper fieldset label {
  display: block;
}
.login-wrapper fieldset input {
  border: 1px solid rgba(0, 0, 0, 0.25);
  border-radius: 2px;
  padding: .5em .5em;
  margin-bottom: 16px;
  margin-top: 3px;
  width: 100%;
}

form#contact {
  /* General styles for all types of buttons */
  /* Necessary 3d styles for buttons with perspective */
}
form#contact .progress-button {
  position: relative;
  display: inline-block;
  outline: none;
  border: none;
  background: #1d9650;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 1px;
  width: 190px;
  margin-left: 2em;
  -webkit-transition: background 0.3s;
  transition: background 0.3s;
}
form#contact .progress-button[disabled],
form#contact .progress-button[disabled].state-loading {
  cursor: default;
}
form#contact .progress-button .content {
  position: relative;
  display: block;
}
form#contact .progress-button .content::before,
form#contact .progress-button .content::after {
  position: absolute;
  right: 20px;
  color: #0e7138;
  font-family: FontAwesome;
  opacity: 0;
  -webkit-transition: opacity 0.3s 0.3s;
  transition: opacity 0.3s 0.3s;
}
form#contact .progress-button .content::before {
  content: "\f00c";
  /* Checkmark for success */
  line-height: 2;
}
form#contact .progress-button .content::after {
  content: "\f00d";
  /* Cross for error */
}
form#contact .progress-button.state-error {
  background: #ff3f49;
}
form#contact .progress-button.state-error .content::after {
  color: #d8000b;
}
form#contact .progress-button.state-success .content::before,
form#contact .progress-button.state-error .content::after {
  opacity: 1;
}
form#contact .progress-button.state-error .content::after {
  margin-top: 9px;
}
form#contact .notransition {
  -webkit-transition: none !important;
  transition: none !important;
}
form#contact .progress-button .progress {
  background: #148544;
}
form#contact .progress-button .progress-inner {
  position: absolute;
  left: 0;
  background: #0e7138;
}
form#contact .progress-button[data-horizontal] .progress-inner {
  top: 0;
  width: 0;
  height: 100%;
  -webkit-transition: width 0.3s, opacity 0.3s;
  transition: width 0.3s, opacity 0.3s;
}
form#contact .progress-button[data-vertical] .progress-inner {
  bottom: 0;
  width: 100%;
  height: 0;
  -webkit-transition: height 0.3s, opacity 0.3s;
  transition: height 0.3s, opacity 0.3s;
}
form#contact .progress-button[data-perspective] {
  position: relative;
  display: inline-block;
  padding: 0;
  background: transparent;
  -webkit-perspective: 900px;
  perspective: 900px;
}
form#contact .progress-button[data-perspective] .content {
  padding: 0 60px;
  background: #1d9650;
}
form#contact .progress-button[data-perspective] .progress-wrap {
  display: block;
  -webkit-transition: -webkit-transform 0.2s;
  transition: transform 0.2s;
  -webkit-transform-style: preserve-3d;
  transform-style: preserve-3d;
}
form#contact .progress-button[data-perspective] .content,
form#contact .progress-button[data-perspective] .progress {
  outline: 1px solid transparent;
  /* Smoothen jagged edges in FF */
}
form#contact .progress-button[data-style="fill"][data-horizontal] {
  overflow: hidden;
}
form#contact .progress-button[data-style="fill"][data-horizontal] .content {
  z-index: 10;
  -webkit-transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
}
form#contact .progress-button[data-style="fill"][data-horizontal] .content::before,
form#contact .progress-button[data-style="fill"][data-horizontal] .content::after {
  top: 100%;
  right: auto;
  left: 50%;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
form#contact .progress-button[data-style="fill"][data-horizontal].state-success .content,
form#contact .progress-button[data-style="fill"][data-horizontal].state-error .content {
  -webkit-transform: translateY(-165%);
  transform: translateY(-165%);
}

.neighbourhood-holder {
  margin-top: 10px;
}
.neighbourhood-holder .fares-table {
  margin-top: 10px;
}

#wheretobuy .fares-table td[data-title="notes"] p {
  margin: 0 !important;
}
#wheretobuy #map-canvas {
  width: 98%;
}

/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN 320 - MAX 480 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 320px) and (max-width: 480px) {
  .module {
    margin: 0;
  }

  .filter-module {
    padding: 20px 10px;
  }
  .filter-module .filter-wrap {
    min-width: 100%;
  }
  .filter-module .filter-wrap select {
    width: 100%;
  }

  form .form-input.half-width-left {
    width: 100%;
    float: none;
    margin-left: 0px !important;
  }

  form .form-input.half-width-right {
    width: 100%;
    float: none;
    margin-left: 0px !important;
  }

  .site-alerts .alert .title {
    margin-top: 12px;
  }

  .site-alerts .alert .route-icons {
    margin-top: 18px;
  }

  .alerts-list-filter {
    padding: 20px 10px;
  }

  .preview-schedule.panel {
    width: 100%;
  }
  .preview-schedule.panel.medium {
    width: 100%;
  }
  .preview-schedule.panel.large {
    width: 100%;
    height: 140px !important;
  }
  .preview-schedule.panel.large .effectiveDate {
    line-height: 28px;
    font-size: 26px !important;
  }
  .preview-schedule.panel.large a {
    margin-top: 0px;
    padding-left: 21px;
    width: 100%;
    background: #1B7297;
    text-align: center;
  }

  .news-list .loadMoreNews {
    width: 100% !important;
  }

  /*** NEXT DEPARTURES MODULE */
  .nextDeparturesPage .nextDeparturesHead input {
    width: 80%;
    font-size: 1.5em;
    padding: 8px;
  }
  .nextDeparturesPage .nextDepartures.active {
    margin-top: 70px !important;
  }
  .nextDeparturesPage ul li .header {
    padding: 10px;
    overflow: hidden;
  }
  .nextDeparturesPage ul li .header .arrivalSeconds {
    margin-top: 10px;
    width: 100%;
    float: left;
    margin-left: 0px;
  }

  #travel-overview a.change-direction {
    position: relative;
    margin-bottom: 10px;
  }

  .no-sidemenu .trip-planner, .trip-planner-page .trip-planner {
    margin: 0;
  }

  .trip-planner .title .route {
    font-size: 0.85em;
    line-height: 1.45em;
    white-space: nowrap;
  }

  #findBusMod .stops-holder ol {
    padding-left: 0;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN 768 - MAX 1120 !!!!!!!!!!!!!!!!!!!! */
/* between table and mobile break points */
@media only screen and (min-width: 768px) and (max-width: 1120px) {
  .site-title a span {
    background: url(../images/logo-medium.png) no-repeat;
  }

  .section.nav-ltwo .l-two {
    margin-top: 38px;
  }

  .breadcrumb ul {
    padding-top: 50px !important;
  }

  .sidemenu .side-panel {
    right: 32%;
  }

  .title-con .site-title a {
    position: absolute;
    top: 0px;
    z-index: 100;
  }

  .nav-tools ul {
    display: none;
  }

  .nav-tools {
    position: relative;
  }
  .nav-tools i {
    display: block;
    position: absolute;
    color: #c0d7e7;
    top: 0px;
    line-height: 25px;
    right: 17px;
    margin-left: 5px;
    height: 100%;
    pointer-events: none;
  }
  .nav-tools i:after {
    content: "|";
    text-indent: -9999em;
    font-size: 2em;
    width: 1px;
    height: 100px;
    top: 1px;
    right: 15px;
    position: absolute;
    border-right: 1px solid rgba(255, 255, 255, 0.1);
  }

  .nav-tools select {
    display: block;
    font-size: 20px;
    margin-right: 10px;
    background: #02233f;
    text-transform: uppercase;
    width: 80px;
    color: #c0d7e7;
    padding-left: 5px;
    font-size: 13px;
    line-height: 20px;
    font-weight: bold;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 3px;
    height: 30px;
    -webkit-appearance: none;
    outline: none;
  }

  .nav-tools select:focus {
    border: 1px solid rgba(255, 255, 255, 0.4);
  }

  #travel-overview a.change-direction {
    position: relative;
    margin-bottom: 10px;
  }

  .departures.module .title {
    font-size: .95em !important;
  }
  .departures.module .collapse {
    font-size: 25px !important;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN - 1120 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 1120px) {
  .nav-tools ul {
    display: block;
  }

  .nav-tools select, .nav-tools i {
    display: none;
  }
}
/** FIXES FOR FIREFOX **/
@-moz-document url-prefix() {
  .nav-tools select {
    -moz-appearance: none;
    text-indent: 0.01px;
    text-overflow: '';
    padding-top: 5px;
  }

  .nav-primary a {
    font-weight: normal !important;
    padding: 20px .5em !important;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MAX - 480 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (max-width: 480px) {
  .region-modal ul[class^='col'] {
    float: none;
    margin-top: 10px;
  }

  .home-page-title {
    margin-top: 70px;
    margin-bottom: 20px;
  }
  .home-page-title h3 {
    color: #fff;
    font-size: 2em;
    line-height: .93em;
    text-shadow: 1.5px 1.5px 3px rgba(0, 0, 0, 0.5);
  }
  .home-page-title h3 small {
    font-size: .4em;
    line-height: .4em;
  }
  .home-page-title h3 span {
    line-height: .8em;
  }
  .home-page-title h3 .region {
    font-size: .5em;
    margin-top: 10px;
    display: block;
    float: right;
  }
  .home-page-title a {
    color: #fff;
    font-size: 1em;
  }

  .home-page-header {
    margin-top: -40px;
  }

  form#contact .progress-button {
    width: 100%;
    margin-top: 10px;
    margin-left: 0;
  }
  form#contact button[type='clear'] {
    width: 100%;
  }

  .subscription-modal .form-input {
    margin-bottom: .5em;
  }
  .subscription-modal h4 {
    font-size: 1em;
    margin: 2px 2px 1px;
  }
  .subscription-modal form {
    height: 350px;
    overflow: scroll;
  }
  .subscription-modal form::-webkit-scrollbar {
    display: none;
  }
  .subscription-modal .route-list {
    width: 100%;
    margin: 0 auto;
    padding-top: 10px;
    margin-bottom: 30px;
  }
  .subscription-modal .route-list:after {
    font-family: FontAwesome;
    content: "scroll \f078";
    position: absolute;
    left: 50%;
    bottom: -10px;
    display: block;
    color: white;
    width: 40px;
    height: 20px;
    margin: 0 auto;
    margin-left: -33px;
    font-size: .7em;
    text-align: center;
    line-height: 10px;
    font-weight: 700;
  }
  .subscription-modal .route-list span {
    color: white;
    font-style: italic;
    font-size: .8em;
  }
  .subscription-modal .route-list ul {
    padding: 0;
    margin: 0px;
    height: 85px;
    display: block;
    overflow-y: scroll;
  }
  .subscription-modal .route-list ul li {
    list-style: none;
    display: inline-block;
    margin: 5px;
  }
  .subscription-modal .route-list ul li .directions-icon.selected {
    opacity: 1;
    background: #49a348;
    -webkit-transform: scale(1.2, 1.2);
    transform: scale(1.2, 1.2);
    -ms-transform: scale(1.2, 1.2);
    /* IE 9 */
  }

  .android .subscription-modal form {
    height: 490px;
    overflow: scroll;
  }
  .android .subscription-modal form::-webkit-scrollbar {
    display: none;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MAX - 768 !!!!!!!!!!!!!!!!!!!! */
/** ONLY FOR MOBILE **/
@media only screen and (max-width: 767px) {
  .page-title {
    padding-right: 70px;
  }

  .suggested-route .directionsBtn {
    display: block !important;
  }

  .direction-list .direction {
    position: relative;
    background: white;
    border: none;
    padding: 10px;
    margin-top: 10px;
  }
  .direction-list .direction .header {
    color: #002240;
    padding: 0 0 0 15px !important;
  }
  .direction-list .direction .instructions {
    margin: 0px;
  }
  .direction-list .direction .wrapper {
    margin-top: 0px;
    padding-bottom: 0px;
    padding: 0px;
    background: white;
    color: #002240;
  }
  .direction-list .direction .wrapper .route-alerts {
    margin-left: 0 !important;
    padding-left: 2px !important;
  }
  .direction-list .direction .wrapper .arrivalStop {
    margin-top: 12px;
  }
  .direction-list .direction .wrapper .arrivalStop .arrivalTime {
    margin-top: 10px !important;
    margin-left: 0px !important;
  }
  .direction-list .direction.walking {
    border: none;
  }
  .direction-list .direction .step-icon {
    margin-top: 0px;
    padding-right: 0;
    margin-right: 10px;
    margin-left: -25px;
  }

  .side-panel {
    top: 15px;
    position: relative;
    float: right;
    margin-right: 0;
  }
  .section.two-content .side-panel {
    position: absolute;
    margin-right: 16px;
  }
  .side-panel a {
    width: 30px;
  }
  .side-panel a i {
    margin-right: 0px;
    margin-top: 6px;
  }

  .login-wrapper {
    width: 100%;
    padding: 20px 18px;
  }

  .side-panel-text {
    visibility: hidden;
    display: block;
    width: 0;
    height: 0;
    overflow: hidden;
  }

  .content-inner.two-col.no-menu .section.two-content {
    margin-top: 0px;
  }

  .alt-anchor {
    margin-bottom: 20px;
  }

  #map-canvas {
    margin: 0 4% 1em;
  }

  .content-block {
    margin: 0 4% 1em !important;
  }

  .content-block.fares, .content-block.overview {
    margin: 0 0 1em !important;
  }

  .site-header {
    background: #143a5b;
    z-index: 10;
  }

  .module.news, .module.video {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 100%;
  }
  .module.news:last-child, .module.video:last-child {
    margin-right: 0;
  }

  .module.callout, .module.ad, .social {
    display: inline-block;
    vertical-align: top;
    width: 100%;
    margin-right: 1em;
  }

  .search-con {
    padding: 10px;
  }
  .search-con i {
    margin-top: 12px;
    margin-right: 5px;
  }

  .home-page-title {
    margin-bottom: 20px;
  }
  .home-page-title h3 {
    color: #fff;
    font-size: 3em;
    line-height: .93em;
    text-shadow: 1.5px 1.5px 3px rgba(0, 0, 0, 0.5);
  }
  .home-page-title h3 small {
    font-size: .4em;
    line-height: .4em;
  }
  .home-page-title h3 span {
    line-height: .8em;
  }
  .home-page-title h3 .region {
    font-size: .5em;
    margin-top: 10px;
    display: block;
    float: right;
  }
  .home-page-title a {
    color: #fff;
    font-size: .75em;
  }

  .home-page-header {
    margin-top: -120px;
  }

  .account-login-page .home-page-header {
    margin-top: 0;
  }

  .trip-planner.routes .route-list li {
    width: 100%;
  }
  .trip-planner .today {
    width: 100%;
  }

  .highlight {
    padding-bottom: 20px;
  }

  .preview-schedule.panel {
    width: 100%;
  }
  .preview-schedule.panel.medium {
    width: 100%;
  }
  .preview-schedule.panel.large {
    width: 100%;
    height: auto;
  }
  .preview-schedule.panel.large .effectiveDate {
    line-height: 28px;
  }

  .region-modal {
    height: 100%;
  }

  .region-modal .regionHolder, .region-modal .routeHolder, .route-modal .regionHolder, .route-modal .routeHolder {
    overflow-y: scroll;
    height: calc(100% - 110px);
    margin: 9px -13px 0px -16px;
    font-size: 12px;
    padding-left: 10px;
  }
  .region-modal .regionHolder, .route-modal .regionHolder {
    height: calc(100% - 160px);
    padding-left: 10px;
    margin: 9px -13px 0px -16px;
    font-size: 16px;
  }
  .region-modal .routeHolder ul, .route-modal .routeHolder ul {
    width: 100% !important;
  }
  .region-modal .routeHolder ul:first-of-type, .route-modal .routeHolder ul:first-of-type {
    margin-bottom: 0;
  }
  .region-modal .routeHolder ul + ul, .route-modal .routeHolder ul + ul {
    margin-top: 0;
    margin-bottom: 0;
  }
  .region-modal .routeHolder li a, .route-modal .routeHolder li a {
    font-size: 1.5em;
    margin-bottom: 10px;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN - 480 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 480px) {
  .transit-future {
    width: 43%;
    float: left;
    margin-right: 0;
  }

  .campaign-image {
    width: 43%;
    float: right;
    margin-left: 0;
  }

  .site-message {
    font-size: 2em;
  }

  .nav-con-primary ul {
    display: block;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN - 768 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 768px) {
  a[name=top] {
    position: absolute;
    top: 0;
  }

  .section.one-content {
    min-height: 600px;
  }

  .search-con {
    font-size: 0.8em;
    float: right;
    width: 23%;
    height: 29px;
    margin-top: 6px;
  }
  .search-con .input {
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: #002240;
    height: 29px;
    color: #c0d7e7;
    font-weight: bold;
    font-size: 1.2em;
    outline: none;
  }
  .search-con .input:focus {
    background: #002240;
    color: #c0d7e7;
    border: 1px solid rgba(255, 255, 255, 0.4);
  }
  .search-con .submit {
    cursor: pointer;
    height: 29px;
  }

  .site-title {
    border: none;
    padding: 0;
  }
  .site-title a {
    margin: 0;
    width: 180px;
    height: 45px;
  }

  .site-region {
    border: none;
    text-align: right;
    margin-top: 23px;
  }
  .site-region span {
    float: right;
    font-size: 1.8em;
  }
  .site-region small {
    display: inline;
    font-size: 0.7em;
    line-height: 2.7em;
    float: right;
    margin-top: 9px;
    margin-right: 0.8em;
  }
  .site-region small a {
    color: #fff;
  }
  .site-region small a:hover, .site-region small a:focus {
    text-decoration: underline;
  }

  .breadcrumb {
    border: none;
  }
  .breadcrumb ul {
    padding-top: 20px;
    text-transform: uppercase;
    letter-spacing: 1px;
  }

  .home-page .module.callout, .home-page .module.ad, .home-page .social {
    min-height: 450px;
  }

  .two-content {
    padding-top: 20px;
  }
  .two-content .highlight, .two-content .call-to-action, .two-content .sidebar-event, .two-content .sidebar-media, .two-content .sidebar-contact {
    padding: 3% 9% 0;
    margin-left: 0;
    margin-right: 0;
  }
  .two-content .highlight .title, .two-content .call-to-action .title, .two-content .sidebar-event .title, .two-content .sidebar-media .title, .two-content .sidebar-contact .title {
    margin-left: 0;
    margin-right: 0;
  }

  .nav-con-primary ul {
    margin: 0;
    padding: 0;
  }
  .nav-con-primary ul .l-two {
    display: none;
  }
  .nav-con-primary li {
    display: inline;
  }

  .nav-con-tools {
    z-index: 10;
  }
  .nav-con-tools li {
    display: inline;
    margin-right: 0.7em;
  }
  .nav-con-tools .nav-tools {
    font-weight: bold;
    font-size: 0.8em;
    float: right;
    margin-top: 6px;
  }
  .nav-con-tools .nav-tools .region-name {
    display: none;
  }

  .module.community-list {
    padding: 0 28px 30px;
  }

  .search-results-page .search-left {
    float: left;
  }
  .search-results-page .search-right {
    float: right;
  }

  .site-copyright .site-title {
    margin-left: 0;
  }
  .site-copyright .to-top {
    position: absolute;
    right: 0;
  }

  .copyright {
    top: 10px;
    left: 190px;
    font-size: 0.9em;
    width: auto;
    text-align: left;
  }

  /* Account pages */
  .half-left {
    float: left;
    width: 48%;
    margin-right: 4%;
  }

  .half-right {
    float: right;
    width: 48%;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN - 768 / MAX - 801 --- for iPad Portrait !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 768px) and (max-width: 801px) {
  .home-page .module.callout, .home-page .module.ad {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 48.8375%;
  }
  .home-page .module.callout:last-child, .home-page .module.ad:last-child {
    margin-right: 0;
  }
  .home-page .module.ad {
    margin-right: 0 !important;
  }
  .home-page .social {
    float: left;
    display: block;
    margin-right: 2.325%;
    width: 100%;
  }
  .home-page .social:last-child {
    margin-right: 0;
  }
}
@media only screen and (min-width: 768px) and (max-width: 968px) {
  .trip-planner.full, .trip-planner.routes {
    padding: 20px 30px;
  }
  .trip-planner.full .button.schedules, .trip-planner.routes .button.schedules {
    width: 48%;
    display: inline-block;
    margin-right: 3%;
  }
  .trip-planner.full .button.handydart, .trip-planner.routes .button.handydart {
    width: 48%;
    display: inline-block;
  }
}
@media only screen and (min-width: 1120px) and (max-width: 1381px) {
  .sidemenu .trip-planner form .form-input.half-width-left, .sidemenu .trip-planner form .form-input.half-width-right {
    width: 100%;
  }
  .sidemenu .trip-planner .form-reset {
    min-height: auto !important;
  }

  .no-menu .trip-planner .form-reset {
    min-height: 33px;
  }
}
@media only screen and (min-width: 1028px) and (max-width: 1119px) {
  .sidemenu .trip-planner .form-reset {
    min-height: 33px;
  }
}
@media only screen and (min-width: 1415px) {
  .sidemenu .trip-planner .form-reset {
    min-height: 33px;
  }
}
@media only screen and (max-width: 989px) {
  .trip-planner form .form-input.half-width-left, .trip-planner form .form-input.half-width-right {
    width: 100%;
  }
}
@media only screen and (max-width: 836px) {
  .no-sidemenu .trip-planner, .trip-planner-page .trip-planner {
    margin: 0 0 1em;
  }
  .no-sidemenu .dark-module, .trip-planner-page .dark-module {
    margin: 0 0 1em;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN - 1120 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 1120px) {
  .two-content .highlight, .two-content .call-to-action, .two-content .sidebar-event, .two-content .sidebar-media, .two-content .sidebar-contact {
    padding-left: 4%;
    padding-right: 4%;
  }

  .content-inner {
    border-right-color: #002240;
  }

  .site-region small {
    display: inline;
    font-size: 0.7em;
    line-height: 2.7em;
    float: right;
    margin-right: 0.8em;
  }

  .site-title a span {
    background: url(../images/logo-large.png) no-repeat;
  }

  .site-copyright .site-title a span {
    background: url(../images/logo-medium.png) no-repeat;
  }

  .home-page .trip-planner {
    min-height: 420px;
  }

  .trip-planner.full, .trip-planner.routes {
    padding: 20px 30px;
  }
  .trip-planner.full .button.schedules, .trip-planner.routes .button.schedules {
    width: 48%;
    display: inline-block;
    margin-right: 3%;
  }
  .trip-planner.full .button.handydart, .trip-planner.routes .button.handydart {
    width: 48%;
    display: inline-block;
  }

  .bus-holder {
    top: 44px;
    margin-top: -44px;
  }
}
.staff-directory .header .col {
  color: white;
  background: #000000;
}

.staff-directory .col {
  float: left;
  color: black;
  padding: 10px;
  width: calc(100% / 5);
  word-break: break-all;
}

.staff-directory .row {
  width: 100%;
}

.staff-directory .row:nth-of-type(2n) {
  background: #EFF3F7;
}

.staff-directory .row-holder .row.hide {
  display: none;
}

@media (max-width: 765px) {
  .staff-directory .header {
    display: none;
  }

  .staff-directory .row-holder .col {
    float: none;
    width: 100%;
  }

  .staff-directory .row-holder .col[data-type]:before {
    content: attr(data-type) ": ";
    display: block;
    color: #333;
    float: left;
    font-weight: bold;
  }

  .staff-directory .row-holder .row {
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  }
}
.search-help-wrapper {
  padding: 25px 0 20px 20px;
  width: 100%;
}
.search-help-wrapper a {
  float: right;
}

.filter-module.small.media-release-filter-module {
  min-height: 200px !important;
  overflow: visible;
}

.page-width {
  position: relative;
}

.nav-con-primary {
  /* Main nav icons */
}
.nav-con-primary .fa-calendar {
  background: url(../images/icon-calendar-white.png) no-repeat;
  width: 20px;
  height: 16px;
  position: relative;
  top: -1px;
  background-size: 100%;
}
.nav-con-primary .fa-calendar:before {
  visibility: hidden;
}
.nav-con-primary .fa-credit-card {
  background: url(../images/icon-fare-white.png) no-repeat;
  width: 20px;
  height: 16px;
  position: relative;
  top: -1px;
  background-size: 100%;
}
.nav-con-primary .fa-credit-card:before {
  visibility: hidden;
}
.nav-con-primary .fa-info-circle {
  background: url(../images/icon-info-white.png) no-repeat;
  width: 20px;
  height: 16px;
  position: relative;
  top: -1px;
  background-size: 100%;
}
.nav-con-primary .fa-info-circle:before {
  visibility: hidden;
}
.nav-con-primary .fa-info-circle.large {
  background: none;
  width: auto;
  height: auto;
}
.nav-con-primary .fa-info-circle.large:before {
  visibility: visible;
}
.nav-con-primary .fa-comments-o {
  background: url(../images/icon-news-white.png) no-repeat;
  width: 20px;
  height: 16px;
  position: relative;
  top: -1px;
  background-size: 100%;
}
.nav-con-primary .fa-comments-o:before {
  visibility: hidden;
}
.nav-con-primary .fa-road {
  background: url(../images/icon-sign-white.png) no-repeat;
  width: 20px;
  height: 16px;
  position: relative;
  top: -1px;
  background-size: 100%;
}
.nav-con-primary .fa-road:before {
  visibility: hidden;
}
.nav-con-primary .fa-envelope {
  background: url(../images/icon-mail-white.png) no-repeat;
  width: 20px;
  height: 16px;
  position: relative;
  top: -1px;
  background-size: 100%;
}
.nav-con-primary .fa-envelope:before {
  visibility: hidden;
}

/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MAX - 767 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (max-width: 767px) {
  .nav-primary .is-parent.is-active-parent > a {
    background: #2b3137 !important;
  }

  .nav-primary .is-current.is-active-parent > a {
    background: #394149 !important;
  }

  .nav-primary .l-two a {
    padding-left: 3.3em !important;
  }

  .nav-primary .is-active-parent > .nav-align > .nav-label {
    display: none;
  }

  .nav-con-primary {
    background: #1b1f23;
  }
  .nav-con-primary a {
    color: #eee;
  }

  .nav-con-tools {
    background: #1b1f23;
  }
  .nav-con-tools a {
    color: #eee;
  }

  .nav-con-feedback {
    background: orange;
  }

  .secondary-nav-title {
    display: none;
  }

  .js .container {
    overflow: hidden;
    position: relative;
    height: 100%;
    width: 100%;
  }

  .js .content-con {
    position: absolute;
    overflow-x: hidden;
    overflow-y: scroll;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 5;
  }

  .js .content-fade {
    display: block;
    visibility: hidden;
    position: absolute;
    left: 0;
    top: 0;
    content: '';
    width: 100%;
    height: 100%;
    opacity: 0;
    z-index: 10;
    background: rgba(27, 31, 35, 0.15);
    -moz-transition: opacity 0.3s;
    -o-transition: opacity 0.3s;
    -webkit-transition: opacity 0.3s;
    transition: opacity 0.3s;
  }

  .js .nav-primary-open .content-fade,
  .js .nav-tools-open .content-fade,
  .js .nav-feedback-open .content-fade {
    visibility: visible;
    opacity: 1;
  }

  .nav-primary-open-btn,
  .nav-tools-open-btn,
  .nav-feedback-open-btn {
    display: block;
    position: absolute;
    top: 7px;
    right: 4%;
    overflow: hidden;
  }

  .nav-tools-open-btn {
    right: 18%;
  }

  .nav-primary-open-btn {
    width: 38px;
    height: 31px;
    padding: 5px;
  }
  .nav-primary-open-btn span {
    display: block;
    text-indent: -999px;
    background: url(../images/icn-nav.png) no-repeat center center;
    background-size: 100%;
    overflow: hidden;
    width: 100%;
    height: 100%;
  }

  .nav-tools-open-btn {
    right: 60px;
    width: 32px;
    height: 32px;
    padding: 5px;
  }
  .nav-tools-open-btn span {
    display: block;
    text-indent: -999px;
    background: url(../images/icn-tools.png) no-repeat center center;
    background-size: 100%;
    overflow: hidden;
    width: 100%;
    height: 100%;
  }

  .js .nav-con-primary,
  .js .nav-con-feedback {
    height: 100%;
    width: 280px;
    overflow-y: auto;
    overflow-x: hidden;
    position: relative;
    top: 0;
    right: 0;
    z-index: 1;
    opacity: 0;
    -moz-transition: -moz-transform 0.3s ease-in, opacity 0.3s ease-in;
    -o-transition: -o-transform 0.3s ease-in, opacity 0.3s ease-in;
    -webkit-transition: -webkit-transform 0.3s ease-in, opacity 0.3s ease-in;
    transition: transform 0.3s ease-in, opacity 0.3s ease-in;
  }

  .js .nav-con-primary {
    position: fixed;
    top: 0;
    right: 0 !important;
  }

  .js .nav-con-tools {
    height: 100%;
    width: 280px;
    overflow-y: auto;
    overflow-x: hidden;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
    opacity: 0;
    -moz-transition: -moz-transform 0.3s ease-in, opacity 0.3s ease-in;
    -o-transition: -o-transform 0.3s ease-in, opacity 0.3s ease-in;
    -webkit-transition: -webkit-transform 0.3s ease-in, opacity 0.3s ease-in;
    transition: transform 0.3s ease-in, opacity 0.3s ease-in;
  }

  .js #mobile-push {
    position: absolute;
    z-index: 5;
    width: 100%;
    height: 100%;
    -webkit-transition: -webkit-transform 0.3s;
    -moz-transition: -ms-transform 0.3s;
    -o-transition: -ms-transform 0.3s;
    -ms-transition: -ms-transform 0.3s;
    transition: transform 0.3s;
  }

  .js .nav-primary-open .nav-con-primary {
    z-index: 10000000;
  }

  .js .nav-primary-open .nav-con-tools {
    display: none;
  }

  .js .nav-tools-open .nav-con-tools {
    z-index: 3;
  }

  .js .nav-primary-open #mobile-push {
    -webkit-transform: translate3d(-280px, 0, 0);
    -moz-transform: translate3d(-280px, 0, 0);
    -o-transform: translate3d(-280px, 0, 0);
    -ms-transform: translate3d(-280px, 0, 0);
    transform: translate3d(-280px, 0, 0);
  }

  .js .nav-primary-open .nav-con-primary {
    opacity: 1;
  }

  .js .nav-con-tools {
    left: 0;
    right: auto;
  }

  .js .nav-tools-open #mobile-push {
    -webkit-transform: translate3d(280px, 0, 0);
    -moz-transform: translate3d(280px, 0, 0);
    -o-transform: translate3d(280px, 0, 0);
    -ms-transform: translate3d(280px, 0, 0);
    transform: translate3d(280px, 0, 0);
  }

  .js .nav-tools-open .nav-con-tools {
    opacity: 1;
  }

  .nav-primary .nav-label {
    text-transform: uppercase;
    font-weight: bold;
    color: #a4b2c0;
    letter-spacing: 1px;
    height: 44px;
    margin: 0;
    font-size: 1em;
    padding: .7em 1.5em;
  }
  .nav-primary ul {
    margin: 0;
    padding: 0;
    border-top: 1px solid #0a0c0e;
    border-bottom: 1px solid #2f343a;
  }
  .nav-primary ul li a {
    display: block;
    border-top: 1px solid #2f343a;
    border-bottom: 1px solid #0a0c0e;
    padding: 0.5em 1.5em !important;
  }
  .nav-primary ul li a i {
    margin-right: 5px;
  }
  .nav-primary ul li a:hover, .nav-primary ul li a:focus {
    background: #2b3137;
  }
  .nav-primary .has-children > a:after {
    content: "";
    display: block;
    width: 0px;
    height: 0px;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-left: 6px solid #d0e4f5;
    position: relative;
    right: -10px;
    top: 5px;
    float: right !important;
  }
  .nav-primary .has-children.is-active-parent > a:after {
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #d0e4f5;
    right: -12px;
    top: 9px;
  }
  .nav-primary .l-three li a {
    padding-left: 4.5em !important;
  }

  .js .nav-primary {
    position: relative;
  }

  .nav-tools .nav-label {
    text-transform: uppercase;
    font-weight: bold;
    color: #a4b2c0;
    letter-spacing: 1px;
    height: 50px;
    margin: 0;
    font-size: 1em;
    padding: 1em 1.5em;
  }
  .nav-tools ul {
    margin: 0;
    padding: 0;
    border-top: 1px solid #0a0c0e;
    border-bottom: 1px solid #2f343a;
  }
  .nav-tools ul li a {
    display: block;
    border-top: 1px solid #2f343a;
    border-bottom: 1px solid #0a0c0e;
    padding: 0.5em 1.5em;
  }
  .nav-tools ul li a i {
    margin-right: 5px;
  }
  .nav-tools ul li a:hover, .nav-tools ul li a:focus {
    background: #2b3137;
  }

  .mobile-none {
    display: none;
  }
}
@media only screen and (max-device-width: 767px) and (max-width: 767px) and (orientation: landscape) {
  .nav-primary {
    margin-bottom: 100px;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN - 768 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 768px) {
  .nav-primary-open-btn,
  .nav-tools-open-btn,
  .nav-feedback-open-btn {
    position: absolute;
    width: 0;
    height: 0;
    overflow: hidden;
  }

  .nav-primary .nav-label {
    display: none;
  }
  .nav-primary .nav-align {
    display: inline;
  }
  .nav-primary a {
    display: inline-block;
    padding: 18px 0.5em;
    font-weight: bold;
    color: #fff;
    height: 62px;
    font-size: 1em;
  }
  .nav-primary a i {
    margin-right: 0;
  }
  .nav-primary a:hover,
  .nav-primary a:focus {
    background: #143a5b;
  }

  .nav-secondary .nav-label {
    display: none;
  }

  .secondary-nav-title {
    display: block;
    padding: 30px 9% 20px;
    border-bottom: 1px solid #67798b;
    margin-bottom: 20px;
    margin-right: 20px;
  }
  .secondary-nav-title h3 {
    margin: 0;
  }

  .section.nav-ltwo .secondary-nav-title {
    padding: 20px 0 20px;
  }
  .section.nav-ltwo ul li.has-children > a:after {
    content: "";
    display: block;
    width: 0px;
    height: 0px;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-left: 6px solid #d0e4f5;
    position: absolute;
    right: 10px;
    top: 38%;
  }
  .section.nav-ltwo ul li.has-children.is-current > a:after {
    content: "";
    display: block;
    width: 0px;
    height: 0px;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #d0e4f5;
    position: absolute;
    right: 10px;
    top: 38%;
  }
}
/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MIN - 1120 !!!!!!!!!!!!!!!!!!!! */
@media only screen and (min-width: 1120px) {
  .site-header .site-title {
    margin-top: 18px;
  }

  .site-header .region-con {
    height: 100px;
  }

  .site-region span {
    font-size: 1.9em;
  }

  .site-region small {
    margin-top: 9px;
  }

  .site-title a {
    width: 272px;
    height: 36px;
    padding: 0;
  }

  .nav-primary a {
    padding-top: 21px;
    padding-bottom: 21px;
    height: 69px;
    font-size: 1em;
  }

  .nav-secondary {
    font-size: 1.0625em;
    padding-top: 0.3em;
    padding-bottom: 0.3em;
  }

  .nav-con-tools .nav-tools {
    margin-top: 8px;
  }
  .nav-con-tools .nav-tools li {
    margin-right: 1em;
  }
  .nav-con-tools .nav-tools a {
    font-size: 1.125em;
  }
  .nav-con-tools .nav-tools a:hover, .nav-con-tools .nav-tools a:focus {
    text-decoration: underline;
  }

  .content-con {
    padding-top: 206px;
  }
}
table.rt {
  min-width: 600px;
}

/** TABLES **/
.table {
  margin-bottom: 1em;
  border-bottom: 1px solid #e8e8e8;
}

table {
  table-layout: fixed;
  font-size: 12px;
  width: 100%;
  text-align: left;
  border-collapse: collapse;
  border: 1px solid #e8e8e8;
  margin-top: 2em;
}
table tr.active {
  background: #004078 !important;
  position: relative;
  z-index: 1;
}
table tr.active td {
  color: white;
  border-top: none;
  border-bottom: none;
}
table tr:nth-child(odd) {
  background-color: #fff;
}
table tr:nth-child(even) {
  background-color: #f2f6fa;
}
table td {
  color: #002240;
  border-right: 1px dashed #e8e8e8;
  padding: 10px 20px;
  font-size: 1.2em;
}
table td i {
  color: white;
  font-size: .8em;
  line-height: .8em;
  background: orange;
  padding: 0px 5px 0px 4px;
  font-weight: Bold;
  border-radius: 5px;
  margin-right: 10px;
  margin-left: -10px;
  height: 15px;
  cursor: pointer;
  cursor: pointer;
}
table tr.odd {
  background-color: #fff;
}
table tr.even {
  background-color: #f2f6fa;
}

th {
  font-weight: normal;
  font-size: 13px;
  color: white;
  text-transform: uppercase;
  border-right: 1px solid #e8e8e8;
  border-top: 1px solid #002240;
  border-left: 1px solid #002240;
  border-bottom: 1px solid #fff;
  padding: 12px 10px;
  background: #002240;
}
th.route-via, th.continue-as {
  background: #004078;
}
th.large {
  width: 120px;
}

th:last-child {
  border-right: none;
}

table.fares-table td {
  padding: 10px 10px;
}

/*!!!!!!!!!!!!!!!!!!!!!!!!!! RESPONSIVE TABLE !!!!!!!!!!!!!!!!!!!!!!!!!!*/
/*
horizontal tables
Added by Kyle - phil wanted this functionality
*/
@media screen {
  .cf:after {
    visibility: hidden;
    display: block;
    font-size: 0;
    content: " ";
    clear: both;
    height: 0;
  }

  * html .cf {
    zoom: 1;
  }

  *:first-child + html .cf {
    zoom: 1;
  }

  .horizontalTable {
    display: block;
    position: relative;
    width: 100%;
    overflow-x: auto\9;
  }

  .horizontalTable table {
    min-width: inherit !important;
  }

  .horizontalTable thead, thead.horizontal {
    margin: 0\9;
    display: block;
    float: left;
    position: relative;
    z-index: 1;
    width: 120px\9;
  }

  .horizontalTable tbody {
    display: block;
    width: auto;
    margin: 0\9;
    position: relative;
    overflow-x: auto;
    white-space: nowrap;
    float: left\9;
  }

  .horizontalTable thead tr, thead.horizontal tr {
    display: block;
    width: 100% \9;
  }

  .horizontalTable th, thead.horizontal th {
    display: block;
    border-right: none;
    box-shadow: 2px 0px 5px rgba(0, 0, 0, 0.2);
    max-width: 180px;
    border-bottom: 1px solid #0058a6;
  }

  .horizontalTable th:last-child, thead.horizontal th:last-child {
    border-bottom: none;
  }

  .horizontalTable thead tr th.large, thead.horizontal tr th.large, .horizontalTable thead tr th, thead.horizontal tr th {
    width: 120px;
    float: left\9;
  }

  thead.horizontal {
    position: absolute;
    top: 0px;
    left: 0;
    z-index: 2;
  }

  .horizontalTable tbody tr {
    display: inline-block;
    word-spacing: -1;
    /*margin-left:-3px;*/
    vertical-align: top;
    float: left\9;
    width: 90px\9;
  }
  .horizontalTable tbody tr.active td {
    border-top: 1px solid #002a4f;
    border-right: none;
  }

  .horizontalTable tbody tr:first-child {
    margin-left: 0px;
  }

  .horizontalTable td {
    position: relative;
    padding: 10px 15px;
    display: block;
    min-height: 48px;
    box-sizing: border-box;
    width: 90px;
    border-top: 1px solid #eee;
    float: left\9;
  }
  .horizontalTable td i {
    position: absolute;
    top: 5px;
    right: 0px;
    font-size: .7em;
    height: 15px;
    line-height: 15px;
    padding: 0px 4px 0px 4px;
  }
}
/* Mobile */
@media only screen and (max-width: 1140px) {
  table.responsive {
    margin-bottom: 0;
    margin-top: 0;
    table-layout: auto;
    border: none;
  }

  .pinned table thead tr th:not(:first-child) {
    display: none;
  }

  .pinned table tbody tr td:not(:first-child) {
    display: none;
  }

  .pinned {
    position: absolute;
    left: 0;
    top: 0;
    width: 35%;
    overflow: hidden;
    overflow-x: scroll;
    border-right: 1px solid #ccc;
    border-left: 1px solid #ccc;
  }

  .pinned table {
    border: none;
    width: 100%;
    margin-top: 0;
  }
  .pinned table td {
    border-right: none;
  }

  .pinned table th, .pinned table td {
    white-space: nowrap;
  }

  .pinned td:last-child {
    border-bottom: 0;
  }

  div.table-wrapper {
    position: relative;
    margin-bottom: 0;
    overflow: hidden;
    border-right: 1px solid #ccc;
    margin-top: 20px;
  }

  div.table-wrapper div.scrollable {
    margin-left: 35%;
  }

  div.table-wrapper div.scrollable {
    overflow: scroll;
    overflow-y: hidden;
  }

  table.responsive td, table.responsive th {
    position: relative;
    white-space: nowrap;
    overflow: hidden;
  }

  table.responsive th:first-child, table.responsive td:first-child, table.responsive td:first-child, table.responsive.pinned td {
    display: none;
  }
}
/*!!!!!!!!!!!!!!!!!!!!!!!!!! FARES TABLE !!!!!!!!!!!!!!!!!!!!!!!!!!*/
table.fares-table {
  border-style: none;
  border-top-width: 0;
  width: auto;
  border: 1px solid #e8e8e8;
  width: 100%;
}
table.fares-table tr {
  border-style: none;
  border-bottom-width: 0;
}
table.fares-table tr.title-row {
  font-weight: bold;
  font-size: 1.25em;
  border-bottom-width: 0;
  color: #333;
}
table.fares-table th, table.fares-table td {
  border-style: none;
  padding-right: 5px 1em;
  text-align: left;
  vertical-align: top;
}
table.fares-table th.tool, table.fares-table td.tool {
  padding: 0 1em;
}
table.fares-table th.fare-type, table.fares-table td.fare-type {
  font-size: 1.2em;
  font-weight: bold;
}
table.fares-table th + th,
table.fares-table th + td,
table.fares-table td + th,
table.fares-table td + td {
  border-left-width: 1px;
}
table.fares-table thead tr:last-child {
  border-bottom-width: 2px;
}
table.fares-table thead th,
table.fares-table tr.index th {
  font-weight: bold;
  line-height: 1.25;
  text-transform: uppercase;
}
table.fares-table thead th {
  background: #001a31;
}
table.fares-table tbody:first-of-type tr.index th {
  padding-top: 1em;
}
table.fares-table tbody .title-row th {
  background: #143a5b;
  color: #fff;
}
table.fares-table tbody th {
  font-weight: normal;
  background: none;
  color: #002240;
}

/* !!!!!!!!!!!!!!!!!!!! BREAKPOINT - MAX - 768 !!!!!!!!!!!!!!!!!!!! */
/** ONLY FOR MOBILE **/
@media only screen and (max-width: 767px) {
  #wheretobuy table.fares-table {
    margin-top: 10px !important;
  }

  table.fares-table {
    border: 1px solid #e8e8e8;
    padding-bottom: 0;
    display: block;
    width: 100%;
    margin-top: 0px;
    /*
     * make everything display block so it 
     * aligns vertically
     */
    /* Labeling
     * adding a data-title attribute to the cells
     * lets us add text before the content to provide
     * the missing context
     * 
     * Markup: 
     *   <td data-title="Column Header">Content Here</td>
     * 
     * Display:
     *   Column Header: Content Here
     */
  }
  table.fares-table caption {
    display: block;
  }
  table.fares-table thead {
    display: none;
    visibility: hidden;
  }
  table.fares-table tbody, table.fares-table tr, table.fares-table th, table.fares-table td {
    border: 0;
    display: block;
    text-align: left;
    white-space: normal;
  }
  table.fares-table tbody.fare-type, table.fares-table tr.fare-type, table.fares-table th.fare-type, table.fares-table td.fare-type {
    font-size: 1.2em;
    font-weight: bold;
  }
  table.fares-table tr {
    padding-bottom: 5px;
    border-bottom: solid 1px #e8e8e8;
  }
  table.fares-table tr.title-row {
    font-weight: bold;
    font-size: 1.5em;
    border-bottom: none;
    background: #143a5b;
    padding-left: 0;
    color: #fff;
  }
  table.fares-table th[data-title]:before,
  table.fares-table td[data-title]:before {
    content: attr(data-title);
    font-weight: bold;
    display: block;
    width: 100%;
  }
  table.fares-table th:not([data-title]) {
    font-weight: bold;
  }
  table.fares-table td:empty {
    display: none;
  }
}
/* accessibility overwrites */
.trip-planner.routes .route-list li a {
  color: #89d389;
}

.suggested-route.active .directions-time {
  color: #fff;
}

.ui-tabs .ui-tabs-nav li a {
  border-top: 5px solid #dedede;
}

/* take out background white in mobile */
.ui-tabs .ui-tabs-nav li.ui-tabs-active a {
  border-bottom: 1px solid #49a348;
  border-top: 5px solid #86ce7f;
  background: #49a348;
  color: #fff;
}

table tr:nth-child(even) {
  background-color: #ebf0f4;
}

table td {
  border-right: 1px dashed #ccc;
}

.notecode-wrapper .description {
  font-size: 1em;
  color: #888;
}

.notecode-wrapper .code {
  background: orange;
  padding: 0px 5px 0px 4px;
  font-weight: bold;
  color: white;
  line-height: .8em;
  border-radius: 5px;
  margin-right: 10px;
}

hr {
  border-top: 1px solid #ccc;
}

.news-item hr {
  margin-top: 30px;
}

.printonly {
  display: none;
  visibility: hidden;
}

@media print {
  * {
    background: transparent !important;
    color: #000 !important;
    /* Black prints faster: h5bp.com/s */
    box-shadow: none !important;
    text-shadow: none !important;
  }

  .horizontal {
    display: none !important;
  }

  .printonly {
    visibility: visible;
    display: block;
  }

  a,
  a:visited {
    text-decoration: underline;
  }

  a[href]:after {
    content: " (" attr(href) ")";
  }

  abbr[title]:after {
    content: " (" attr(title) ")";
  }

  /*
  * Don't show links for images, or javascript/internal links
  */
  .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after {
    content: "";
  }

  pre, blockquote {
    border: 1px solid #999;
    page-break-inside: avoid;
  }

  table {
    page-break-inside: auto;
    font-size: 11px;
  }

  tr {
    page-break-inside: avoid;
    page-break-after: auto;
  }

  thead {
    display: table-header-group;
    /* h5bp.com/t */
  }

  table th {
    border-color: #e8e8e8;
    background-color: #e8e8e8;
  }

  table td {
    padding: 10px !important;
    height: auto !important;
    font-size: inherit;
  }

  table th.route-via, th.route-via {
    border-color: #e8e8e8;
    background-color: #e8e8e8;
  }

  tfoot {
    display: table-footer-group;
  }

  tr,
  img {
    page-break-inside: avoid;
  }

  img {
    max-width: 100% !important;
  }

  @page {
    margin: 1.5cm 2cm 2cm;
  }
  html,
  body,
  .container,
  .mobile-push {
    overflow: auto;
    width: auto;
    height: auto;
    position: static;
  }

  body {
    font-size: 9pt;
  }

  p,
  h2,
  h3 {
    orphans: 3;
    widows: 3;
  }

  h2,
  h3 {
    page-break-after: avoid;
  }

  .page-width {
    max-width: 94%;
  }

  .site-header {
    position: static;
  }
  .site-header .title-con {
    height: auto;
    border: none;
  }

  .site-title {
    padding: 10px 0;
  }
  .site-title a {
    display: inline;
    height: auto;
    padding: 0;
    margin: 10px 0;
    text-decoration: none;
  }
  .site-title a span {
    text-indent: 0;
  }

  .page-title {
    font-size: 2.5em;
  }

  .region-con,
  .side-panel,
  .nav-primary-open-btn,
  .nav-tools-open-btn,
  .nav-secondary,
  .nav-con-tools,
  .nav-con-primary,
  .top-bar,
  .site-footer,
  .site-message,
  .site-copyright,
  .bus-holder,
  .content-fade,
  #directionTitle,
  #findBusMod {
    display: none;
  }

  .content-con {
    padding-top: 0;
  }

  .content-inner {
    border: none;
  }

  .section.one-content {
    padding: 0 0 2em;
    margin-bottom: 2em;
    border-bottom: 1px solid #e8e8e8;
  }

  .section.two-content {
    padding: 0;
    margin-top: 20 !important;
  }
  .section.two-content .highlight {
    width: 49%;
    display: inline-block;
  }

  .breadcrumb {
    border-top: 1px solid #e8e8e8;
  }
  .breadcrumb ul {
    padding: 5px 0;
  }
  .breadcrumb a {
    color: grey;
  }

  img.img-full,
  img.img-50,
  img.img-30 {
    width: auto;
    max-width: 100% !important;
  }

  .img-grid {
    max-width: 50%;
  }

  .fluid-width-video-wrapper {
    padding-top: 0 !important;
  }
  .fluid-width-video-wrapper ::before {
    content: "Video is hidden.";
    font-style: italic;
    color: grey;
    padding: 1em;
    border: 1px solid grey;
    border-radius: 5px;
  }
  .fluid-width-video-wrapper iframe {
    display: none;
  }

  .module {
    border: none;
    margin-left: 0;
    margin-right: 0;
  }
  .module .title {
    padding-left: 0;
    padding-right: 0;
  }

  .half-width {
    float: none;
    width: auto;
    padding-left: 0;
    padding-right: 0;
  }

  .home-page-header {
    margin-top: 0;
  }
  .home-page-header .region {
    display: none;
  }

  .home-page-title h3 {
    font-size: 4em;
  }
  .home-page-title h3 br {
    display: none;
  }
  .home-page-title h3 .region {
    display: none;
  }
  .home-page-title small {
    display: none;
  }

  .home-page-paragraph {
    padding: 0;
  }

  .home-page-trip,
  .social {
    display: none;
  }

  .trip-planner,
  .directionsBtn {
    display: none;
  }

  .suggested-route .time-wrapper {
    font-size: 1.5em;
    font-weight: bold;
    text-align: right;
  }

  .alerts-list-filter {
    display: none;
  }

  .list-alerts {
    padding-left: 0;
    padding-right: 0;
    border-top: 1px solid #e8e8e8;
    border-bottom: none;
  }
  .list-alerts i {
    padding-bottom: 30px;
    overflow: hidden;
  }

  .search-results-page .filter-module {
    display: none;
  }

  .departures.module {
    display: none !important;
  }

  .stops.module#travel-directions,
  .module.departures,
  #nextDeparturesModule,
  #findBusMod,
  .trip-planner,
  .gm-style a,
  .trip-print,
  .change-direction,
  h6.alt-anchor,
  span#pdfLinkHolder,
  h2.site-title a:after,
  .trip-planner-page .breadcrumb {
    display: none !important;
  }

  .step-icon {
    background: white !important;
  }

  #map-canvas {
    width: 100%;
  }

  .schedule .ui-tabs-nav {
    display: none;
  }
  .schedule table {
    margin-top: 0;
  }

  .static-tab-title {
    padding: 15px;
    border-top: 5px solid #86ce7f;
    display: block;
    font-size: 1.6em;
    border-right: 1px solid #e8e8e8;
    border-left: 1px solid #e8e8e8;
  }

  .table {
    border-right: 1px solid #e8e8e8;
  }

  .alert-list a[href]:after {
    content: "" !important;
  }

  #travel-overview .ui-tabs-panel {
    visibility: visible;
    position: static;
  }

  .table tr.active {
    background-color: #d1e9fd !important;
  }

  .preview-schedule.panel.medium {
    display: none;
  }

  /** PRINT TABLE STYLES **/
  .schedule .table table.rt {
    max-width: 640px;
    width: 100% !important;
    table-layout: auto;
  }

  .schedule .table table.rt th {
    font-size: 5.5pt;
    padding: 5px !important;
    text-transform: none;
  }

  .schedule .table table.rt td {
    font-size: 5.5pt;
    padding: 3px 5px !important;
  }

  .schedule .table table.rt tbody tr {
    border-bottom: 1px dashed #bbb;
  }

  .js .content-con, .js #mobile-push, .js .container, body {
    height: auto !important;
  }
}
