body {
  font-family: 'Roboto', sans-serif; }

a.minimal-template-logo:link,
a.minimal-template-logo:hover,
a.minimal-template-logo:active,
a.minimal-template-logo:visited {
  color: black; }

a.minimal-template-logo:hover {
  text-decoration: underline; }

.force-select {
  -webkit-user-select: all;
  /* Chrome 49+ */
  -moz-user-select: all;
  /* Firefox 43+ */
  -ms-user-select: all;
  /* No support yet */
  user-select: all;
  /* Likely future */ }

.content {
  padding-bottom: 60px; }

.main-sidebar {
  height: 80vh;
  position: fixed;
  color: white;
  width: 250px;
  border-right: 1px solid black;
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#41237b+0,0e52a3+100 */
  background: #41237b;
  /* Old browsers */
  background: -moz-linear-gradient(top, #41237b 0%, #0e52a3 100%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(top, #41237b 0%, #0e52a3 100%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to bottom, #41237b 0%, #0e52a3 100%);
  /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#41237b', endColorstr='#0e52a3',GradientType=0 );
  /* IE6-9 */
  overflow: auto; }
  .main-sidebar a:link, .main-sidebar a:active, .main-sidebar a:hover, .main-sidebar a:visited {
    color: white; }
  .main-sidebar ul {
    list-style: none;
    padding: 0;
    margin: 0;
    padding: 15px; }
    .main-sidebar ul li {
      padding: 0;
      margin: 0; }
      .main-sidebar ul li ul {
        padding: 0;
        padding-top: 10px; }

.page-content {
  margin-left: 250px;
  padding: 0 1% 0 1%; }

.sidebar-logo {
  width: 54px;
  float: left;
  margin: 15px; }

.sidebar-title {
  float: left;
  font-size: 16px;
  margin-top: 33px;
  margin-left: 2px;
  font-family: 'Roboto', sans-serif; }

.content-header.box-holder .box {
  background: #f4f8fb;
  border: 1px solid #cacaca;
  padding: 7px 12px;
  font-weight: medium;
  color: #03226d;
  width: 100%;
  margin: 0;
  padding: 15px 15px 15px 10px;
  font-size: 24px;
  font-family: 'Roboto', sans-serif; }

.bottom-left-links {
  bottom: 0;
  width: 100%;
  padding: 15px;
  background: #083b73;
  border-top: 1px solid #608ec3;
  padding-bottom: 30px;
  height: 20vh;
  width: 250px;
  position: fixed;
  bottom: 0;
  left: 0; }
  .bottom-left-links ul {
    list-style: none;
    padding: 0;
    margin: 0; }
    .bottom-left-links ul li {
      padding: 0;
      margin: 0;
      padding-bottom: 7px; }
  .bottom-left-links a:link, .bottom-left-links a:active, .bottom-left-links a:visited, .bottom-left-links a:hover {
    color: white; }

.above-content {
  padding: 15px 0;
  padding-bottom: 0; }
  .above-content .upper-links {
    top: 8px; }
    .above-content .upper-links li {
      list-style: none;
      float: right;
      font-size: .9em;
      color: grey;
      margin-right: 20px; }
      .above-content .upper-links li a:link, .above-content .upper-links li a:visited, .above-content .upper-links li a:active, .above-content .upper-links li a:hover {
        color: black;
        color: black;
        text-decoration: underline; }

.box-holder {
  margin-bottom: 15px; }
  .box-holder .box {
    border: 1px solid #d4d4d4;
    padding: 0; }
    .box-holder .box h2 {
      background: #f4f8fb;
      margin: 0;
      padding: 10px;
      font-weight: 200;
      font-size: 1.5em; }
      .box-holder .box h2 .banner-link {
        font-size: .66em;
        text-transform: none;
        margin-left: 10px;
        vertical-align: middle; }
    .box-holder .box .inner {
      padding: 15px; }
  .box-holder .box.announcements {
    background: #ffffec; }
    .box-holder .box.announcements h2 {
      background: #ffffbd; }

h2 .title-link {
  font-size: .4em;
  color: #646464;
  margin-left: 10px; }

.box {
  border: 1px solid #d4d4d4;
  padding: 0; }
  .box h2 {
    background: #f4f8fb;
    margin: 0;
    padding: 10px;
    font-weight: 200;
    text-transform: uppercase;
    font-size: 1.5em; }
    .box h2 .banner-link {
      font-size: .66em;
      text-transform: none;
      margin-left: 10px;
      vertical-align: middle; }
  .box .inner {
    padding: 15px; }

body.agency-routes li.routes a,
body.agency-stops li.stops a,
body.agency-calendars li.calendars a {
  list-style-type: circle;
  text-decoration: underline; }

.agency-link.current {
  border-bottom: 1px dotted white; }

.minimized {
  position: relative; }
  .minimized .page-content {
    margin-left: 0px;
    padding: 0 1% 0 1%; }
  .minimized .main-sidebar {
    width: 64px;
    height: 64px;
    position: inherit;
    float: left;
    z-index: 999;
    overflow: hidden; }
    .minimized .main-sidebar .sidebar-logo {
      width: 30px;
      float: left;
      margin: 15px;
      margin-bottom: 20px; }
  .minimized .content-header {
    margin-top: 30px; }
  .minimized .bottom-left-links {
    display: none; }
  .minimized .above-content {
    width: 100%;
    margin: 0;
    top: 0;
    height: 64px;
    left: 0;
    padding-left: 80px;
    padding-bottom: 0;
    border-bottom: 1px solid #ccc;
    background: white; }

.tab-holder {
  background: #35495d;
  border-radius: 9px;
  display: inline-block;
  margin: 30px 0 15px 0; }
  .tab-holder .tab {
    float: left;
    color: white;
    position: relative; }
  .tab-holder .tab i.fa {
    margin-right: 5px; }
  .tab-holder .tab img {
    height: 13px;
    position: relative;
    top: -2px;
    width: auto;
    margin-right: 5px;
    display: inline-block; }
  .tab-holder .tab.active {
    float: left;
    color: white;
    background: #0080ED; }
  .tab-holder .tab.active.first {
    border-top-left-radius: 8px;
    border-bottom-left-radius: 8px; }
  .tab-holder .tab.active.last {
    border-top-right-radius: 8px;
    border-bottom-right-radius: 8px; }
  .tab-holder .tab.active:after {
    top: 100%;
    left: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border-color: rgba(0, 175, 236, 0);
    border-top-color: #0080ED;
    border-width: 10px;
    margin-left: -10px; }

.tab-holder-large .tab {
  padding: 15px; }

.tab-holder-small .tab {
  padding: 6px 10px;
  font-size: .9em; }
.tab-holder-small .tab.active:after {
  top: 100%;
  left: 50%;
  border: solid transparent;
  content: " ";
  height: 0;
  width: 0;
  position: absolute;
  pointer-events: none;
  border-color: rgba(0, 175, 236, 0);
  border-top-color: #0080ED;
  border-width: 7px;
  margin-left: -7px; }

table.data-table > thead > tr.major-header > th {
  font-size: 1.7em;
  vertical-align: top; }
table.data-table > tbody > tr, table.data-table > thead > tr {
  border: 1px solid #e7e7e7;
  font-size: .8em; }
  table.data-table > tbody > tr > td, table.data-table > tbody > tr > th, table.data-table > thead > tr > td, table.data-table > thead > tr > th {
    padding: 2px; }
table.data-table td.editable {
  font-family: "Courier New", Courier, monospace; }

.add-item-major, .add-item-minor {
  background: #0080ED; }

.add-item-major:hover, .add-item-minor:hover {
  background: #01bdff; }

.add-item-major {
  color: white;
  font-size: 20px;
  font-weight: bold;
  border-radius: 4px;
  line-height: 0;
  padding: 0 6px;
  cursor: pointer; }

.input-label-minor {
  color: #0095c9; }

.input-minor {
  border: 1px solid #bed5dd;
  border-radius: 3px;
  padding: 3px;
  vertical-align: middle;
  padding-top: 5px; }

.input-minor:disabled {
  opacity: .5; }

.fa.fa-pencil-square-o {
  font-size: .6em;
  vertical-align: middle; }

.dropdown-toggle {
  background-color: #0080ED;
  border: 0;
  padding-left: 0; }
  .dropdown-toggle span.arrow {
    position: absolute;
    right: 0;
    border-top-right-radius: 3px;
    border-bottom-right-radius: 3px;
    background-color: #0095c9;
    padding: inerhit;
    width: 26px;
    top: 3px;
    height: 28px;
    vertical-align: middle;
    padding-top: 7px;
    color: white; }

.dropdown-toggle:hover {
  background-color: #0089b9; }
  .dropdown-toggle:hover span.arrow {
    background-color: #006f96; }

.open .dropdown-toggle {
  background-color: #0089b9; }
  .open .dropdown-toggle span.arrow {
    background-color: #006f96; }

.dropdown-toggle:after {
  content: none; }

a:link.breadcrumb-link, a:hover.breadcrumb-link, a:visited.breadcrumb-link {
  margin-bottom: 15px;
  display: inline-block;
  color: black;
  text-decoration: underline; }

.fa-pencil-square-o {
  cursor: pointer; }

.fa.fa-ban {
  color: red; }

.agency .export {
  margin-top: 15px; }
.agency .stops-need-review a:link, .agency .stops-need-review a:hover, .agency .stops-need-review a:visited, .agency .stops-need-review a:active {
  color: red; }

.route-children.fullscreen {
  position: fixed;
  top: 0;
  background: white;
  width: 100%;
  z-index: 9999;
  margin: 0;
  height: 100%;
  overflow: scroll;
  left: 0;
  padding: 0; }
  .route-children.fullscreen br:first-of-type {
    display: none; }
  .route-children.fullscreen .map-holder {
    top: 0;
    padding: 0;
    margin: 0; }

.plus-icon {
  display: inline-block;
  background: #0080ED;
  border-radius: 3px;
  color: white;
  margin: 4px; }

.plus-icon.plus-icon-small {
  padding: 9px 8px 6px;
  font-size: .66em;
  position: relative;
  top: -1px; }

.plus-icon.plus-icon-medium {
  font-size: 1em;
  padding: 5px 10px 4px; }

.plus-icon.plus-icon-large {
  padding: 5px 10px 4px;
  font-size: 1.33em; }

h2.sectional,
h3.sectional {
  background: #ECE4F1; }

h2.sectional {
  padding: 35px 0 35px 20px; }
  h2.sectional span {
    font-size: .6em;
    font-weight: 300;
    padding: 10px;
    text-transform: none; }

h2 .btn, h3 .btn {
  float: right; }

h2.sectional.table-title {
  margin-bottom: 0;
  position: relative;
  bottom: -2px; }

h3.sectional {
  padding: 15px;
  font-size: 1em; }

.tight-wrapper {
  width: auto;
  min-width: 0;
  display: table; }

.route-children {
  max-width: 100%; }

.table-filter input {
  color: black; }

.new-link {
  font-weight: bold;
  color: #0080ED; }

table.sortable-table.loading {
  opacity: .7; }
  table.sortable-table.loading thead tr {
    background: linear-gradient(182deg, #a17aba, #9db7ff, #a17aba, #9db7ff);
    background-size: 800% 800%;
    -webkit-animation: LoadingGradient 3s ease infinite;
    -moz-animation: LoadingGradient 3s ease infinite;
    animation: LoadingGradient 3s ease infinite; }
    table.sortable-table.loading thead tr th {
      background: 0; }
@-webkit-keyframes LoadingGradient {
  0% {
    background-position: 50% 0%; }
  50% {
    background-position: 51% 100%; }
  100% {
    background-position: 50% 0%; } }
@-moz-keyframes LoadingGradient {
  0% {
    background-position: 50% 0%; }
  50% {
    background-position: 51% 100%; }
  100% {
    background-position: 50% 0%; } }
@keyframes LoadingGradient {
  0% {
    background-position: 50% 0%; }
  50% {
    background-position: 51% 100%; }
  100% {
    background-position: 50% 0%; } }
.btn-save {
  background: #5FE688;
  border: 0;
  -webkit-box-shadow: 0px 3px 0px 0px #d6d6d6;
  -moz-box-shadow: 0px 3px 0px 0px #d6d6d6;
  box-shadow: 0px 3px 0px 0px #d6d6d6;
  outline: none !important;
  padding: 3px 20px;
  margin-bottom: 10px; }

.btn-save:hover {
  background: #5FE688; }

.btn-save:focus {
  outline: none;
  background: #5FE688; }

.btn-save:active {
  background: #33df67;
  outline: none;
  position: relative;
  top: 2px;
  -webkit-box-shadow: 0px 1px 0px 0px #d6d6d6;
  -moz-box-shadow: 0px 1px 0px 0px #d6d6d6;
  box-shadow: 0px 1px 0px 0px #d6d6d6; }

.route-page-circle {
  border-radius: 20px;
  height: 40px;
  width: 40px;
  display: inline-block;
  margin: 0 15px;
  position: relative;
  top: 6px;
  border: 2px solid white;
  -webkit-box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.5);
  -moz-box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.5);
  box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.5); }

.box-with-close, .box-with-no-close {
  width: auto;
  min-width: 0;
  display: table;
  border-radius: 4px;
  border: 1px solid #ccc;
  background: white; }
  .box-with-close h2, .box-with-no-close h2 {
    border-top-left-radius: 2px;
    border-top-right-radius: 2px;
    background: #fcfcfc;
    border-bottom: 1px solid #ccc;
    margin: 0;
    padding: 21px;
    font-weight: 200;
    text-transform: uppercase;
    font-size: 1.5em; }
    .box-with-close h2 span, .box-with-no-close h2 span {
      font-size: .8em;
      float: right;
      margin-left: 30px; }
  .box-with-close h2 span, .box-with-no-close h2 span {
    font-size: .6em;
    float: right;
    position: relative;
    top: 5px;
    text-transform: none; }
  .box-with-close .inner, .box-with-no-close .inner {
    padding: 15px; }

.box-with-no-close {
  width: 100%;
  display: table;
  border-radius: 4px;
  border: 1px solid #ccc;
  background: white;
  margin-bottom: 15px; }
  .box-with-no-close h2 {
    background: #ECE4F1;
    font-weight: 400; }

.gtfsm-tooltip {
  width: 17px;
  height: 17px;
  border-radius: 12px;
  background: #eee;
  display: inline-block;
  font-size: 12px;
  text-align: center;
  border: 1px solid grey;
  margin-left: 4px; }

.gtfsm-tooltip-alert {
  color: red; }
  .gtfsm-tooltip-alert i {
    position: relative;
    top: -7px;
    left: -7px; }

a.gtfsm-tooltip-alert:hover {
  text-decoration: none; }

a.gtfsm-tooltip:hover {
  text-decoration: none; }

.pattern-editor-undo,
.pattern-editor-redo, .generic-undo, .generic-redo {
  outline: none;
  box-shadow: 0px 3px 0px 0px #d6d6d6; }

.pattern-editor-undo:active,
.pattern-editor-redo:active,
.generic-undo:active,
.generic-redo:active {
  position: relative;
  top: 2px;
  outline: none;
  box-shadow: 0px 1px 0px 0px #d6d6d6; }

.user-agency-list td {
  padding: 3px 15px;
  border-bottom: 1px solid #eee;
  border-top: 1px solid #eee; }
.user-agency-list th {
  padding: 3px 15px; }
.user-agency-list tr:hover {
  background: #ecfaff; }

.agency-upcoming-calendars {
  list-style: none;
  padding: none; }

.gtfs-breadcrumb {
  top: 6px; }

.form-group .checkbox {
  margin-top: 0; }
.form-group .checkbox label {
  padding-left: 0; }

.updating-data-cover {
  display: none;
  opacity: 1;
  -webkit-transition: opacity .5s;
  /* Safari */
  transition: opacity .5s; }

.updating-data-cover.active {
  display: inherit;
  position: absolute;
  z-index: 9999999;
  padding: 0;
  margin: 0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.41); }
  .updating-data-cover.active .sk-fading-circle-holder {
    top: 50%;
    left: 50%;
    position: fixed;
    margin-left: -50px;
    margin-top: -50px;
    width: 100px;
    height: 100px; }
  .updating-data-cover.active .sk-fading-circle .sk-circle:before {
    background-color: black; }

.message-box {
  position: relative;
  padding: 10px;
  margin-bottom: 10px;
  border-radius: 4px;
  font-size: 1.1em;
  font-weight: bold; }
  .message-box .close-message-box {
    position: absolute;
    right: 0;
    right: 5px;
    top: 2px; }

.message-box.error-message {
  background: red; }

.message-box.success-message {
  background: #a8e579; }

.wake-robin-simple-box {
  padding: 20px 15px;
  border: #ccc 1px solid; }

.page-content {
  position: relative; }

body {
  -webkit-animation-delay: 0.1s;
  -webkit-animation-name: fontfix;
  -webkit-animation-duration: 0.1s;
  -webkit-animation-iteration-count: 1;
  -webkit-animation-timing-function: linear; }

@-webkit-keyframes fontfix {
  from {
    opacity: 1; }
  to {
    opacity: 1; } }
.fa.fa-grip:before {
  content: "\f142 \202F \f142 \202F \f142"; }

.fa.fa-grip-large:before {
  content: "\f142 \202F \f142 \202F \f142 \202F \f142 \202F \f142 \202F \f142 \202F \f142"; }

.agency-routes table.route-list {
  border: rgba(0, 0, 0, 0.1) solid 1px;
  margin-top: 15px; }
  .agency-routes table.route-list tbody tr:hover {
    background: #eff9fc; }
  .agency-routes table.route-list th {
    padding: 10px;
    background: #f8f7ff;
    cursor: pointer; }
  .agency-routes table.route-list .route-list-icon {
    width: 10px;
    height: 10px;
    border-radius: 10px;
    display: inline-block;
    margin-right: 4px; }
  .agency-routes table.route-list .fa-times {
    color: red;
    cursor: pointer; }
  .agency-routes table.route-list .fa-times:hover {
    color: #990000; }
  .agency-routes table.route-list tr.route-row.is-over.drag-before {
    border-top: 3px solid #0080ED; }
  .agency-routes table.route-list tr.route-row.is-over.drag-after {
    border-bottom: 3px solid #0080ED; }
  .agency-routes table.route-list tr.route-row {
    border: 1px solid rgba(0, 0, 0, 0.1);
    list-style: none;
    margin: 4px;
    -webkit-transition: margin 2s;
    transition: margin 2s; }
    .agency-routes table.route-list tr.route-row td.route-name {
      text-align: left; }
    .agency-routes table.route-list tr.route-row .route-circle {
      position: relative;
      bottom: 1px;
      vertical-align: middle;
      margin-right: 5px; }
    .agency-routes table.route-list tr.route-row td {
      margin: 4px;
      padding: 2px 5px;
      text-align: center; }
  .agency-routes table.route-list tr.route-row.dragable {
    cursor: ns-resize;
    border: 1px solid #ccc;
    padding: 5px;
    list-style: none; }
.agency-routes .editor-panel {
  margin: 15px 0 15px 0;
  padding: 15px; }
  .agency-routes .editor-panel button {
    margin-right: 15px; }
.agency-routes .order-edit-options {
  padding: 10px;
  padding-left: 0px; }
  .agency-routes .order-edit-options .btn {
    padding: 3px;
    font-size: .8em;
    margin-right: 4px; }
.agency-routes .order-edit-panel {
  margin-top: 15px; }
  .agency-routes .order-edit-panel .btn {
    margin-right: 5px; }
.agency-routes .onoffswitch {
  position: relative;
  width: 62px;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  top: 3px; }
.agency-routes .onoffswitch-checkbox {
  display: none; }
.agency-routes .onoffswitch-label {
  display: block;
  overflow: hidden;
  cursor: pointer;
  border: 0px solid #858585;
  border-radius: 6666px; }
.agency-routes .onoffswitch-inner {
  display: block;
  width: 200%;
  margin-left: -100%; }
.agency-routes .onoffswitch-inner:before, .agency-routes .onoffswitch-inner:after {
  display: block;
  float: left;
  width: 50%;
  height: 18px;
  padding: 0;
  line-height: 18px;
  font-size: 10px;
  color: white;
  font-family: Trebuchet, Arial, sans-serif;
  font-weight: bold;
  box-sizing: border-box; }
.agency-routes .onoffswitch-inner:before {
  content: "ON";
  padding-left: 9px;
  background-color: #3EC234;
  color: #FFFFFF; }
.agency-routes .onoffswitch-inner:after {
  content: "OFF";
  padding-right: 9px;
  background-color: #EEEEEE;
  color: #999999;
  text-align: right; }
.agency-routes .onoffswitch-switch {
  display: block;
  width: 11px;
  margin: 3.5px;
  background: #FFFFFF;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 40px;
  border: 0.5px solid rgba(0, 0, 0, 0.1);
  border-radius: 6px; }
.agency-routes .onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-inner {
  margin-left: 0; }
.agency-routes .onoffswitch-checkbox:checked + .onoffswitch-label .onoffswitch-switch {
  right: 0px; }
.agency-routes .cssload-container {
  float: right; }
.agency-routes .edit-order-toggle {
  font-size: 1.5em;
  margin-left: 4px;
  position: relative;
  top: 2px; }
.agency-routes .box.new-route {
  margin-top: 15px;
  width: auto;
  min-width: 0;
  display: table;
  border-radius: 2px; }
  .agency-routes .box.new-route h2 {
    border-top-left-radius: 2px;
    border-top-right-radius: 2px; }
.agency-routes h2 span {
  font-size: .6em;
  float: right;
  position: relative;
  top: 5px;
  text-transform: none; }
.agency-routes hr {
  margin: 0;
  margin-bottom: 10px; }
.agency-routes fieldset {
  min-width: 0;
  width: auto;
  display: table;
  position: relative;
  padding: 15px; }
  .agency-routes fieldset legend {
    position: absolute;
    top: -.75em;
    font-size: 1em;
    line-height: 1.5em;
    left: 15px;
    background: white;
    width: auto;
    min-width: 0;
    display: table; }

.dir-icon {
  display: none; }

.dir-icon.active {
  margin-right: 2px;
  display: inline-block;
  margin-left: 5px;
  position: relative;
  top: -3px;
  margin-top: 10px; }

.dir-icon.asc {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 4px 0 4px;
  border-color: black transparent transparent transparent; }

.dir-icon.desc {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 4px 5px 4px;
  border-color: transparent transparent black transparent; }

.pattern-title {
  padding: 0;
  margin: 0; }

.pattern-list-editor {
  display: inline-block; }
  .pattern-list-editor .btn-save {
    float: right;
    margin-top: 30px;
    padding: 4px 8px; }
  .pattern-list-editor > table > thead > tr.major-header > th:nth-child(1) {
    background: #f8f7ff;
    border-right: 1px solid #e7e7e7; }
  .pattern-list-editor > table > thead > tr.minor-header > th.pattern-header {
    background: #f8f7ff; }
  .pattern-list-editor > table > thead > tr.minor-header > th.pattern-header.last {
    border-right: 1px solid #e7e7e7;
    padding-right: 10px; }
  .pattern-list-editor > table > thead > tr.minor-header > th.timed-pattern-header.first {
    padding-left: 20px; }
  .pattern-list-editor > table > tbody > tr {
    padding-left: 4px; }
    .pattern-list-editor > table > tbody > tr > td.pattern-body {
      background: #fbfbff; }
    .pattern-list-editor > table > tbody > tr > td.pattern-body.last {
      border-right: 1px solid #e7e7e7;
      padding-right: 20px; }
    .pattern-list-editor > table > tbody > tr > td.timed-pattern-body.first {
      padding-left: 20px; }
  .pattern-list-editor > table > tbody > tr:hover {
    background: #b9edff; }
    .pattern-list-editor > table > tbody > tr:hover > td {
      background: #b9edff; }

.time-offset {
  font-size: .5em; }

.checkbox input[type=checkbox] {
  position: inherit;
  margin-top: 0;
  margin-left: 0;
  margin-right: 4px; }

.btn.btn-primary.dropdown-toggle {
  font-size: .5em; }

.pattern-list-editor .checkbox {
  margin-bottom: 0; }

.timed-pattern-dropdown {
  display: inline-block;
  width: 230px;
  margin-left: 15px;
  margin-right: 15px; }

.add-timed-pattern-ui .add-timed-pattern-input {
  padding: 5px;
  line-height: 1.1em;
  font-size: .7em; }
.add-timed-pattern-ui .add-item-major {
  margin-left: 3px;
  padding: 7px 7px;
  vertical-align: middle;
  font-size: .5em;
  font-weight: 300; }
.add-timed-pattern-ui .cancel-item {
  margin-left: 5px;
  vertical-align: middle;
  font-size: .5em;
  cursor: pointer;
  color: #969696; }
.add-timed-pattern-ui .cancel-item:hover {
  text-decoration: underline; }

.stop_name {
  position: relative; }

.stop_name .fa-map-marker {
  display: none; }

.stop_name:hover .fa-map-marker {
  display: inline-block;
  font-size: 1.1em;
  margin-left: 6px; }

.stop_name:before {
  content: ' ';
  width: 6px;
  height: 6px;
  position: absolute;
  left: 0;
  top: 9px;
  border-radius: 10px; }

.stop_name.has_alignment:before {
  background: #4bd78a; }

.stop_name.no_alignment:before {
  background: #f30050; }

tr.stop_pattern_row .fa-hand-paper-o {
  color: orange;
  font-size: 1.2em; }
tr.stop_pattern_row .stop_name {
  padding-left: 12px; }
  tr.stop_pattern_row .stop_name .add_row {
    font-size: 1.5em;
    font-weight: bold;
    line-height: 0;
    margin-left: 5px;
    opacity: 0;
    transition: opacity 0.12s, font-size 0.1s; }
  tr.stop_pattern_row .stop_name .add_row:hover {
    color: #0080ED;
    font-size: 1.7em;
    cursor: pointer; }
tr.stop_pattern_row input[type=text] {
  border: 1px;
  margin: 1px; }
tr.stop_pattern_row input[type=text]:focus {
  border: 1px solid;
  margin: 0px; }
tr.stop_pattern_row .field-icon-holder {
  padding: 5px; }

tr.stop_pattern_row:hover .stop_name .add_row {
  opacity: 1; }

.smart-input .error {
  background: #f30050; }

.stop_name {
  position: relative; }
  .stop_name .react-search__menu {
    position: absolute;
    z-index: 999; }
  .stop_name .react-search__menu-items {
    background: white;
    padding: 10px;
    -webkit-box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.75);
    -moz-box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.75);
    box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, 0.75); }
  .stop_name .react-search__menu--hidden {
    display: none; }

.cssload-container {
  display: inline-block;
  position: relative;
  top: 2px;
  left: 3px;
  height: 15px;
  text-align: center; }

.cssload-speeding-wheel {
  width: 10px;
  height: 10px;
  margin: 0 auto;
  border: 1px solid white;
  border-radius: 50%;
  border-left-color: transparent;
  border-right-color: transparent;
  animation: cssload-spin 575ms infinite linear;
  -o-animation: cssload-spin 575ms infinite linear;
  -ms-animation: cssload-spin 575ms infinite linear;
  -webkit-animation: cssload-spin 575ms infinite linear;
  -moz-animation: cssload-spin 575ms infinite linear; }

@keyframes cssload-spin {
  100% {
    transform: rotate(360deg);
    transform: rotate(360deg); } }
@-o-keyframes cssload-spin {
  100% {
    -o-transform: rotate(360deg);
    transform: rotate(360deg); } }
@-ms-keyframes cssload-spin {
  100% {
    -ms-transform: rotate(360deg);
    transform: rotate(360deg); } }
@-webkit-keyframes cssload-spin {
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }
@-moz-keyframes cssload-spin {
  100% {
    -moz-transform: rotate(360deg);
    transform: rotate(360deg); } }
label[for=headsign_select] {
  float: left;
  position: relative;
  top: 6px; }

.headsign-select-holder {
  display: inline;
  float: left; }

.headsign .Select-control {
  min-width: 180px; }

.number-icon {
  cursor: pointer; }

#Route-holder .map-style-controls {
  position: absolute;
  top: 471px;
  display: inherit;
  right: 78px;
  z-index: 999;
  bottom: inherit; }

table.patterns-table > thead > tr > th {
  background: #f8f7ff;
  padding: 8px;
  border-right: 1px solid #e7e4ff; }
table.patterns-table > thead > tr > th:last-of-type {
  padding: 8px;
  font-weight: 1.1em;
  border-right: 0; }
table.patterns-table > tbody > tr > td {
  padding: 8px;
  font-weight: 1.1em;
  border-right: 1px solid #eee; }
table.patterns-table > tbody > tr > td:last-of-type {
  padding: 8px;
  font-weight: 1.1em;
  border-right: 0; }

.direction-filter-box input {
  margin-right: 10px; }

.schedules-holder .save-panel-holder {
  margin-top: 0; }
.schedules-holder .save-panel-holder.isSaving {
  pointer-events: none;
  opacity: .5; }
.schedules-holder .sticky {
  pointer-events: none;
  z-index: 999999; }
.schedules-holder .sticky .save-panel-holder {
  pointer-events: all;
  display: table-cell;
  width: auto;
  right: 0;
  z-index: 999999;
  background: white;
  padding: 10px 10px 5px;
  border-bottom-left-radius: 4px;
  -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.75); }
.schedules-holder #editor-save,
.schedules-holder .pattern-editor-undo,
.schedules-holder .pattern-editor-redo {
  margin-top: 0; }
.schedules-holder btn.no-changes {
  box-shadow: 0px 3px 0px 0px #c3c3c3;
  background: white;
  border: 1px solid #ccc; }
.schedules-holder btn.no-changes:active {
  position: inherit;
  top: 0; }
.schedules-holder .pattern-editor-undo,
.schedules-holder .pattern-editor-redo {
  outline: none;
  box-shadow: 0px 3px 0px 0px #d6d6d6; }
.schedules-holder .pattern-editor-undo:active,
.schedules-holder .pattern-editor-redo:active {
  position: relative;
  top: 2px;
  outline: none;
  box-shadow: 0px 1px 0px 0px #d6d6d6; }

.schedule-calendar-header {
  background: #e0d4f8;
  font-size: 1.4em;
  font-weight: bold;
  padding: 15px; }

.calendar-filter-box,
.block-filter-box {
  padding-right: 0; }
  .calendar-filter-box h4 span:last-of-type,
  .block-filter-box h4 span:last-of-type {
    margin-right: 15px; }
  .calendar-filter-box h4 span,
  .block-filter-box h4 span {
    font-size: .65em !important;
    opacity: .9;
    display: inline-block;
    cursor: pointer; }
  .calendar-filter-box .box.inner,
  .block-filter-box .box.inner {
    padding-right: 0; }

.schedule-bucket-header {
  background: #ede7f8;
  height: 50px; }
  .schedule-bucket-header .days-header {
    width: 15%;
    float: left; }
  .schedule-bucket-header .inner {
    display: inline-block;
    padding: 10px 0 0 10px; }
  .schedule-bucket-header .time-axis {
    width: 85%;
    border-left: solid 1px black;
    position: relative;
    float: left; }
  .schedule-bucket-header .time-axis-tick {
    float: left;
    border-right: 1px solid rgba(0, 0, 0, 0.2);
    font-size: .6em;
    height: 50%;
    position: absolute;
    bottom: 0;
    padding-left: 1px; }
  .schedule-bucket-header .time-axis-tick:last-of-type {
    border-right: 0; }

.trip-holder .time-axis {
  width: 100%;
  border-left: solid 1px black;
  height: 100%;
  position: relative; }
.trip-holder .time-axis-tick {
  float: left;
  border-right: 1px solid rgba(0, 0, 0, 0.2);
  font-size: .6em;
  height: 100%;
  position: absolute;
  bottom: 0;
  padding-left: 1px; }

.pattern-row-header {
  width: 15%;
  float: left; }

.pattern-row {
  height: 80px;
  clear: both;
  display: inline-block;
  width: 100%;
  border-bottom: 1px solid grey; }
  .pattern-row .trip-holder {
    width: 85%;
    position: relative;
    display: inline-block;
    height: 100%; }

.block-item {
  float: left;
  padding: 4px;
  margin: 2px;
  border-radius: 3px;
  list-style-type: none;
  background: #eee;
  font-size: .8em;
  font-weight: bold;
  border: 1px solid grey;
  cursor: pointer;
  -webkit-box-shadow: 0px 2px 3px 0px rgba(0, 0, 0, 0.39);
  -moz-box-shadow: 0px 2px 3px 0px rgba(0, 0, 0, 0.39);
  box-shadow: 0px 2px 3px 0px rgba(0, 0, 0, 0.39); }

.block-item.block-hidden {
  opacity: 1;
  border: 1px solid grey;
  padding: 4px;
  background: white !important;
  color: black !important; }

.timed-pattern-row {
  clear: both; }

.filter-box .box {
  min-height: 290px;
  border-color: #95989A; }
  .filter-box .box h4 {
    border-bottom: 1px solid #95989A;
    padding-bottom: 12px;
    margin-bottom: 20px; }
    .filter-box .box h4 span {
      font-size: .8em;
      font-weight: normal;
      float: right; }

.calendar-filter-box label {
  padding: 0;
  font-weight: bold; }
.calendar-filter-box i {
  font-size: .8em;
  color: #bebebe;
  margin-left: 4px;
  margin-right: 4px; }
.calendar-filter-box i.active {
  color: #4BD78A; }
.calendar-filter-box .date-popup {
  font-size: .65em;
  font-weight: normal; }
.calendar-filter-box input[type=checkbox] {
  margin-right: 10px; }

.day-group-filter-panel {
  background: #E6F4FA;
  padding-left: 15px;
  padding-top: 10px;
  margin-bottom: 13px; }

.filter-title {
  color: #545454;
  font-size: 20px;
  margin-left: 16px;
  font-weight: bold; }

.schedule-calendar {
  margin-bottom: 30px;
  -webkit-box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.34);
  -moz-box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.34);
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.34); }
  .schedule-calendar .number-of-trips {
    color: #BFFFB4;
    margin-left: 7px;
    font-size: .75em; }
  .schedule-calendar .number-of-trips.no-trips {
    color: #D9D9D9; }
  .schedule-calendar h2 {
    background: #A17ABA;
    padding: 30px;
    font-size: 20px;
    color: white;
    margin: 0; }
    .schedule-calendar h2 .calendar-title-minimize,
    .schedule-calendar h2 .drawer-icon {
      cursor: pointer; }
    .schedule-calendar h2 i {
      cursor: pointer;
      font-size: .8em;
      color: #bebebe;
      margin-left: 4px;
      margin-right: 4px;
      border-radius: 10px;
      text-shadow: 0px 0px 2px white; }
    .schedule-calendar h2 i.active {
      color: #4BD78A; }
    .schedule-calendar h2 span.date-popup {
      opacity: .8;
      font-size: .8em; }
  .schedule-calendar .schedule-day-group-holder {
    position: relative; }
    .schedule-calendar .schedule-day-group-holder .white-blocker {
      height: 100%;
      background: #ccc;
      width: 15px;
      position: absolute;
      left: 0;
      top: 0; }
  .schedule-calendar h3 {
    background: #AC91BE;
    color: white;
    margin: 0;
    font-size: 19px;
    font-weight: normal;
    padding: 14px 30px;
    clear: both; }
  .schedule-calendar .schedule-pattern-group:nth-child(even) {
    background: #1380D1; }
    .schedule-calendar .schedule-pattern-group:nth-child(even) .cursor.active .cursor-time {
      background: #51A6E5; }
  .schedule-calendar .schedule-pattern-group {
    background: #51A6E5;
    min-height: 36px;
    position: relative; }
    .schedule-calendar .schedule-pattern-group .trip-popup-holder {
      position: absolute;
      width: 1000px;
      -o-user-select: text;
      -moz-user-select: text;
      -webkit-user-select: text;
      user-select: text; }
      .schedule-calendar .schedule-pattern-group .trip-popup-holder .trip-popup {
        min-width: 0;
        width: auto;
        display: table;
        position: absolute;
        color: #000000;
        background: white;
        line-height: 30px;
        text-align: center;
        box-shadow: 0px 2px 2px #000000;
        visibility: visible;
        bottom: 18px;
        left: 0;
        margin-left: -76px;
        z-index: 99999;
        border-top: 1px solid grey;
        border: #51A6E5 1px solid;
        border-bottom: #51A6E5 4px solid; }
        .schedule-calendar .schedule-pattern-group .trip-popup-holder .trip-popup a {
          cursor: pointer; }
        .schedule-calendar .schedule-pattern-group .trip-popup-holder .trip-popup ul {
          padding: 0;
          margin: 0;
          list-style-type: none; }
          .schedule-calendar .schedule-pattern-group .trip-popup-holder .trip-popup ul li {
            padding: 0;
            margin: 0; }
        .schedule-calendar .schedule-pattern-group .trip-popup-holder .trip-popup ul.trip-popup-top {
          background: #E7F5F5; }
          .schedule-calendar .schedule-pattern-group .trip-popup-holder .trip-popup ul.trip-popup-top li {
            padding: 4px 10px;
            line-height: 1.2em;
            margin: 0;
            text-align: left;
            font-size: .8em;
            font-weight: bold; }
        .schedule-calendar .schedule-pattern-group .trip-popup-holder .trip-popup ul.trip-popup-links li {
          padding: 2px 10px;
          font-weight: bold; }
      .schedule-calendar .schedule-pattern-group .trip-popup-holder .trip-popup:after {
        content: '';
        position: absolute;
        top: 100%;
        left: 50%;
        margin-left: -12px;
        width: 0;
        height: 0;
        border-top: 12px solid #51A6E5;
        border-right: 12px solid transparent;
        border-left: 12px solid transparent; }
    .schedule-calendar .schedule-pattern-group .click-cover {
      z-index: 999;
      position: absolute;
      width: 100%;
      height: 100%; }
    .schedule-calendar .schedule-pattern-group .cursor {
      display: none; }
    .schedule-calendar .schedule-pattern-group .cursor.active {
      height: 100%;
      display: inherit;
      width: 1px;
      z-index: 10;
      background: grey;
      position: absolute;
      pointer-events: none; }
      .schedule-calendar .schedule-pattern-group .cursor.active .cursor-time {
        background: #1380D1;
        position: absolute;
        top: 0;
        left: 0;
        color: white; }
    .schedule-calendar .schedule-pattern-group .schedule-pattern-header {
      position: relative; }
    .schedule-calendar .schedule-pattern-group .schedule-pattern-title {
      float: left;
      font-size: .85em;
      min-height: 40px;
      color: white;
      width: 22%;
      min-height: 40px;
      float: left;
      padding-top: 3px;
      padding-bottom: 3px;
      border-right: 1px solid rgba(255, 255, 255, 0.5); }
      .schedule-calendar .schedule-pattern-group .schedule-pattern-title span {
        position: relative;
        left: 25px;
        width: 90%;
        display: inline-block;
        min-height: 40px;
        vertical-align: middle; }
        .schedule-calendar .schedule-pattern-group .schedule-pattern-title span a:link, .schedule-calendar .schedule-pattern-group .schedule-pattern-title span a:hover, .schedule-calendar .schedule-pattern-group .schedule-pattern-title span a:active, .schedule-calendar .schedule-pattern-group .schedule-pattern-title span a:visited {
          color: white; }
        .schedule-calendar .schedule-pattern-group .schedule-pattern-title span a:hover {
          text-decoration: underline; }
    .schedule-calendar .schedule-pattern-group .drag-selection-span {
      background: rgba(0, 0, 0, 0.4);
      height: 100%;
      position: absolute;
      pointer-events: none; }
    .schedule-calendar .schedule-pattern-group .trip-tooltip {
      position: absolute;
      z-index: 99999; }
      .schedule-calendar .schedule-pattern-group .trip-tooltip span {
        background: white;
        border: grey 1px solid;
        padding: 3px; }
    .schedule-calendar .schedule-pattern-group .start-line {
      height: 100%;
      display: inherit;
      width: 1px;
      z-index: 10;
      background: blue;
      position: absolute;
      pointer-events: none; }
    .schedule-calendar .schedule-pattern-group .trip-hover-start-time,
    .schedule-calendar .schedule-pattern-group .trip-hover-end-time {
      font-size: .8em; }
    .schedule-calendar .schedule-pattern-group .trip-hover-start-time {
      display: inherit;
      height: 100%;
      z-index: 10;
      position: absolute;
      pointer-events: none; }
      .schedule-calendar .schedule-pattern-group .trip-hover-start-time span {
        position: absolute;
        right: 0;
        bottom: 0;
        background: white;
        color: black; }
    .schedule-calendar .schedule-pattern-group .trip-hover-end-time {
      display: inherit;
      height: 100%;
      z-index: 10;
      position: absolute;
      pointer-events: none; }
      .schedule-calendar .schedule-pattern-group .trip-hover-end-time span {
        position: absolute;
        left: 0;
        bottom: 0;
        background: white;
        color: black; }
    .schedule-calendar .schedule-pattern-group .time-axis {
      position: absolute;
      right: 0;
      bottom: 0;
      color: #E9F4FC;
      width: 78%;
      height: 100%;
      overflow: visible; }
      .schedule-calendar .schedule-pattern-group .time-axis .axis-click-cover {
        width: 100%;
        height: 100%;
        position: absolute;
        left: 0;
        top: 0;
        background: green; }
    .schedule-calendar .schedule-pattern-group .time-axis-tick {
      float: left;
      font-size: .6em;
      height: 100%;
      position: absolute;
      bottom: 0; }
      .schedule-calendar .schedule-pattern-group .time-axis-tick span {
        position: absolute;
        bottom: 0;
        height: 50%;
        border-left: 1px solid rgba(255, 255, 255, 0.5); }
    .schedule-calendar .schedule-pattern-group .time-axis-tick:first-of-type span {
      position: absolute;
      bottom: 0;
      border-left: 0; }
    .schedule-calendar .schedule-pattern-group .time-axis-tick:last-of-type {
      border-right: 0; }
    .schedule-calendar .schedule-pattern-group .click-cover:hover {
      border-left: 10px solid #FFCD7C; }
    .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group {
      background: white;
      border-bottom: 1px solid rgba(0, 0, 0, 0.2);
      position: relative; }
      .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .schedule-timed-pattern-group-title {
        width: 22%;
        float: left;
        position: relative;
        font-weight: bold;
        font-size: .9em;
        background: white;
        padding-top: 10px;
        padding-bottom: 10px;
        border-right: 1px solid #ccc; }
        .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .schedule-timed-pattern-group-title span {
          position: relative;
          left: 25px;
          z-index: 999; }
          .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .schedule-timed-pattern-group-title span a:link, .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .schedule-timed-pattern-group-title span a:hover, .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .schedule-timed-pattern-group-title span a:active, .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .schedule-timed-pattern-group-title span a:visited {
            color: black; }
          .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .schedule-timed-pattern-group-title span a:hover {
            text-decoration: underline; }
        .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .schedule-timed-pattern-group-title .time-pattern-duration {
          position: absolute;
          font-size: .9em;
          right: 7px;
          margin-top: -8px;
          font-weight: normal;
          top: 50%; }
      .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis {
        position: inherit;
        bottom: 0;
        color: white;
        width: 78%;
        height: 100%;
        min-height: 40px;
        overflow: visible;
        margin-left: 22%; }
        .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip-panel-holder {
          color: black;
          -webkit-user-select: auto;
          -moz-user-select: auto;
          -ms-user-select: alautol;
          user-select: auto; }
        .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip {
          position: relative;
          width: 100%;
          display: block;
          height: 15px;
          margin-bottom: 1px;
          overflow: hidden; }
          .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-dot {
            width: 14px;
            height: 14px;
            border-radius: 14px;
            border: 1px solid black;
            background: #00BA00;
            position: absolute;
            left: -7px;
            z-index: 9999; }
          .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-dot.not-saved:after {
            content: '';
            position: absolute;
            left: 11px;
            top: 9px;
            border-radius: 4px;
            width: 4px;
            height: 4px;
            background: orange; }
          .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-dot:hover .trip-hover {
            display: inherit;
            position: absolute;
            bottom: 10px;
            left: 5px;
            color: black; }
          .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-hover {
            display: none; }
          .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-line {
            background: #00BA00;
            position: absolute;
            top: 3.5px;
            height: 6px;
            border: 1px solid black;
            z-index: 9998; }
          .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-line:last-of-type:after {
            content: '';
            right: 2px;
            height: 100%;
            width: 5px;
            position: absolute;
            border-left: black 2px solid;
            border-right: black 2px solid; }
          .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-line.dark:last-of-type:after {
            content: '';
            right: 2px;
            height: 100%;
            width: 5px;
            position: absolute;
            border-left: white 2px solid;
            border-right: white 2px solid; }
          .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-line:hover, .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-dot:hover {
            cursor: pointer; }
            .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-line:hover .trip-hover, .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-dot:hover .trip-hover {
              display: inherit;
              position: absolute;
              width: 140px;
              color: #000000;
              background: #D4F9FF;
              height: 30px;
              line-height: 30px;
              text-align: center;
              border-radius: 6px;
              box-shadow: 0px 2px 2px #000000;
              visibility: visible;
              bottom: 30px;
              left: 50%;
              margin-left: -76px;
              z-index: 9999; }
            .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-line:hover .trip-hover:after, .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip .trip-dot:hover .trip-hover:after {
              content: '';
              position: absolute;
              top: 100%;
              left: 50%;
              margin-left: -8px;
              width: 0;
              height: 0;
              border-top: 8px solid #D4F9FF;
              border-right: 8px solid transparent;
              border-left: 8px solid transparent; }
        .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip:last-of-type {
          margin-bottom: 0px; }
        .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis .trip:first-of-type {
          margin-top: 0px; }
      .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis-tick {
        float: left;
        border-right: 1px solid rgba(0, 0, 0, 0.2);
        font-size: .6em;
        height: 100%;
        position: absolute;
        bottom: 0;
        padding-left: 1px; }
        .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis-tick span {
          -ms-transform: translate(10%, 0%) rotate(-30deg);
          /* IE 9 */
          -ms-transform-origin: 0% 100%;
          /* IE 9 */
          -webkit-transform: translate(10%, 0%) rotate(-30deg);
          /* Chrome, Safari, Opera */
          -webkit-transform-origin: 0% 100%;
          /* Chrome, Safari, Opera */
          transform: translate(10%, 0%) rotate(-30deg);
          transform-origin: 0% 100%;
          position: absolute; }
      .schedule-calendar .schedule-pattern-group .schedule-timed-pattern-group .time-axis-tick:first-of-type:before {
        content: '';
        height: 100%;
        width: 1px;
        background: grey;
        position: absolute;
        left: -1px;
        top: 0; }
  .schedule-calendar .schedule-calendar-add-trip-holder {
    padding: 19px 25px;
    border: 1px solid #95989A; }
    .schedule-calendar .schedule-calendar-add-trip-holder a {
      cursor: pointer; }

.no-trip-add-panel-holder {
  display: inline-block;
  width: 78%;
  margin-left: 22%; }

.trip-panel-holder {
  position: relative;
  top: 10px;
  width: 100%;
  -webkit-user-select: auto;
  -moz-user-select: auto;
  -ms-user-select: auto;
  user-select: auto; }
  .trip-panel-holder .panel {
    position: absolute;
    width: 101%;
    right: -.5%;
    top: 25px;
    z-index: 999999;
    padding: 15px;
    margin: 0%;
    background: white;
    -webkit-box-shadow: 0px 5px 5px 0px rgba(50, 50, 50, 0.59);
    -moz-box-shadow: 0px 5px 5px 0px rgba(50, 50, 50, 0.59);
    box-shadow: 0px 5px 5px 0px rgba(50, 50, 50, 0.59);
    border-top: 4px solid #03C5FF;
    margin-bottom: 50px; }
    .trip-panel-holder .panel h3 {
      background: white;
      color: black;
      margin: 0;
      font-size: 19px;
      font-weight: bold;
      padding: 14px 0px;
      clear: both;
      padding-top: 0; }
      .trip-panel-holder .panel h3 span {
        font-size: .8em;
        opacity: .5;
        float: right; }
    .trip-panel-holder .panel .btn-save {
      margin-bottom: 0; }
    .trip-panel-holder .panel .close {
      font-size: 1em;
      position: absolute;
      right: 20px;
      bottom: 20px; }
    .trip-panel-holder .panel .delete {
      font-size: 1em;
      position: absolute;
      right: 150px;
      color: red;
      opacity: 1;
      cursor: pointer; }
    .trip-panel-holder .panel .form-inline {
      width: 100%; }
      .trip-panel-holder .panel .form-inline input.panel_input {
        border-radius: 4px;
        border: none;
        border: 1px solid #ccc;
        padding: 5px; }
    .trip-panel-holder .panel label.start-time {
      margin-right: 12px; }
    .trip-panel-holder .panel .headway-panel.inactive fieldset {
      opacity: .6;
      pointer-events: none; }
    .trip-panel-holder .panel .headway-panel {
      background: #E6F4FA;
      padding: 20px 15px 15px;
      position: relative;
      margin-top: 10px; }
      .trip-panel-holder .panel .headway-panel div:first-of-type {
        margin-bottom: 10px; }
      .trip-panel-holder .panel .headway-panel .control-label {
        text-align: right;
        margin-right: 10px; }
      .trip-panel-holder .panel .headway-panel .headway-checkbox {
        position: absolute;
        top: -13px;
        background: rgba(255, 255, 255, 0.3); }
        .trip-panel-holder .panel .headway-panel .headway-checkbox label {
          font-size: 1.1em;
          font-weight: 500;
          clear: left; }
      .trip-panel-holder .panel .headway-panel label {
        clear: left; }
    .trip-panel-holder .panel .day-of-week-selector-holder label {
      float: left;
      font-weight: bold;
      margin-right: 10px;
      position: relative;
      top: 4px; }
    .trip-panel-holder .panel .day-of-week-selector-holder .day-of-week {
      cursor: pointer;
      float: left;
      padding: 5px 12px;
      border-radius: 3px;
      border: 1px solid #ccc;
      margin-right: 6px; }
    .trip-panel-holder .panel .day-of-week-selector-holder .day-of-week.selected {
      background: #89EA85;
      border: 0;
      padding: 6px 13px; }

.panel-triangle-holder {
  width: 100%;
  height: 30px;
  overflow: hidden;
  position: absolute; }

.panel-triangle {
  content: '';
  position: absolute;
  bottom: 100%;
  bottom: -15px;
  z-index: 9999;
  top: 7px;
  margin-left: -24px;
  width: 0;
  height: 0;
  border-bottom: 25px solid #03C5FF;
  border-right: 25px solid transparent;
  border-left: 25px solid transparent; }

.select2-dropdown {
  z-index: 99999999; }

.bg-cover {
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.1);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  /* Just to keep it at the very top */ }

.bound-input {
  float: right;
  color: black;
  width: 70px;
  opacity: .8;
  margin-right: 10px; }

.drawer-icon {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 12px 9px 0 9px;
  border-color: white transparent transparent transparent;
  display: inline-block;
  top: 6px;
  margin-right: 5px; }

.drawer-icon.minimized {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 9px 0 9px 12px;
  border-color: transparent transparent transparent white;
  display: inline-block;
  position: relative;
  top: 2px; }

.calendar-bound-iu {
  font-size: .65em;
  float: right;
  position: relative;
  top: -14px; }
  .calendar-bound-iu td {
    text-align: center;
    padding: 1px 10px; }
  .calendar-bound-iu .bounds-labels {
    font-weight: normal; }
  .calendar-bound-iu .bounds-text {
    font-family: "Courier New", Courier, "Lucida Sans Typewriter", "Lucida Typewriter", monospace; }
  .calendar-bound-iu img {
    width: 16px;
    margin-right: 4px;
    cursor: pointer; }
  .calendar-bound-iu img:active {
    opacity: .8; }
  .calendar-bound-iu .span-button-holder {
    display: inline-block;
    margin: 0 auto; }
    .calendar-bound-iu .span-button-holder .left-button,
    .calendar-bound-iu .span-button-holder .right-button {
      background: white;
      height: 16px;
      width: 30px;
      float: left;
      cursor: pointer;
      font-size: 1.3em; }
      .calendar-bound-iu .span-button-holder .left-button i,
      .calendar-bound-iu .span-button-holder .right-button i {
        position: relative;
        top: -2px;
        color: black; }
    .calendar-bound-iu .span-button-holder .left-button:active,
    .calendar-bound-iu .span-button-holder .right-button:active {
      background: #eee; }
    .calendar-bound-iu .span-button-holder .left-button {
      border-top-left-radius: 3px;
      border-bottom-left-radius: 3px;
      border-right: #ccc 1px solid; }
    .calendar-bound-iu .span-button-holder .right-button {
      border-top-right-radius: 3px;
      border-bottom-right-radius: 3px; }

.direction-group .direction-group-header {
  background: #D8CAE2;
  color: black;
  font-size: 1em;
  padding: 7px 30px; }

.date-popup.multiple {
  cursor: pointer; }

.date-popup {
  position: relative;
  cursor: pointer; }
  .date-popup .date-popup-hover {
    display: none; }
  .date-popup .date-popup-hover.active {
    display: inherit;
    background: white;
    position: absolute;
    padding: 5px;
    left: 0;
    top: 20px;
    -webkit-box-shadow: 0px 2px 3px 0px rgba(0, 0, 0, 0.39);
    -moz-box-shadow: 0px 2px 3px 0px rgba(0, 0, 0, 0.39);
    box-shadow: 0px 2px 3px 0px rgba(0, 0, 0, 0.39);
    border: 1px solid #87c1ff;
    z-index: 999999;
    min-width: 0;
    width: auto;
    display: table; }
    .date-popup .date-popup-hover.active ul {
      margin: 0;
      padding: 0; }
      .date-popup .date-popup-hover.active ul li {
        list-style: none;
        margin: 0;
        padding: 0; }
  .date-popup .date-popup-hover.active:after {
    content: '';
    position: absolute;
    top: -10px;
    left: 50%;
    margin-left: -5px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 5px 8px 5px;
    border-color: transparent transparent #87c1ff transparent; }

.schedule-calendar .date-popup {
  margin-left: 10px;
  margin-right: 10px;
  position: relative;
  z-index: 9999; }
.schedule-calendar .date-popup-hover.active {
  color: black;
  top: 30px; }

.loading-schedules-text {
  text-align: center; }

.calendar-list-enter {
  opacity: 0.01; }

.calendar-list-enter.calendar-list-enter-active {
  opacity: 1;
  transition: opacity 500ms ease-in; }

.calendar-list-leave {
  opacity: 1; }

.calendar-list-leave.calendar-list-leave-active {
  opacity: 0.01;
  transition: opacity 300ms ease-in; }

.edit-panel {
  width: 45vw;
  min-width: 300px;
  height: 100vh;
  z-index: 99999;
  position: fixed;
  right: 0;
  top: 0;
  background: white;
  color: black;
  -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
  overflow: scroll;
  padding: 15px; }

.edit-panel.panel-enter {
  width: 0vw;
  opacity: 0.01;
  transition: width 500ms ease-out,opacity 500ms ease-out; }
  .edit-panel.panel-enter .contents {
    opacity: 0;
    transition: opacity 500ms ease-in; }

.stop-child-panel.panel-enter.panel-enter-active {
  width: 43vw;
  opacity: 1; }
  .stop-child-panel.panel-enter.panel-enter-active .contents {
    opacity: 1; }

.stop-child-panel.panel-appear {
  width: 0vw;
  opacity: 0.01;
  transition: width 500ms ease-out,opacity 500ms ease-out; }
  .stop-child-panel.panel-appear .contents {
    opacity: 0;
    transition: opacity 500ms ease-in; }

.stop-child-panel.panel-appear.panel-appear-active {
  width: 43vw;
  opacity: 1; }
  .stop-child-panel.panel-appear.panel-appear-active .contents {
    opacity: 1; }

.stop-child-panel.panel-leave {
  width: 43vw;
  opacity: 1;
  transition: width 500ms ease-out,opacity 500ms ease-out; }
  .stop-child-panel.panel-leave .contents {
    opacity: 1;
    transition: opacity 300ms ease-in;
    overflow: hidden; }

.stop-child-panel.panel-leave.panel-leave-active {
  width: 0vw;
  opacity: 0.01; }
  .stop-child-panel.panel-leave.panel-leave-active .contents {
    opacity: 0; }

.pattern-table {
  border-collapse: separate;
  border: 1pt solid #e7e7e7; }

.route-page .fa-times {
  font-size: 1em;
  cursor: pointer;
  opacity: .6; }
.route-page .fa-times:hover {
  color: red;
  opacity: 1; }
.route-page .fullscreen-link {
  float: right; }
.route-page .map-holder {
  position: relative; }
  .route-page .map-holder .map-tools {
    z-index: 99999;
    display: inline-block;
    border-radius: 5px;
    float: left;
    position: relative;
    clear: left;
    margin-top: 13px; }
    .route-page .map-holder .map-tools span {
      padding: 3px;
      border-top-left-radius: 3px;
      border-bottom-left-radius: 3px; }
    .route-page .map-holder .map-tools a {
      background: white;
      padding: 3px; }
    .route-page .map-holder .map-tools a:first-of-type {
      padding-left: 5px;
      padding-right: 6px;
      border-right: 1px solid #0080ED; }
    .route-page .map-holder .map-tools a:last-of-type {
      padding-left: 5px;
      padding-right: 6px;
      border-top-right-radius: 3px;
      border-bottom-right-radius: 3px; }
    .route-page .map-holder .map-tools a.active {
      background: #c0eaf8;
      color: black;
      text-decoration: none; }
  .route-page .map-holder .map-options {
    z-index: 99999;
    display: inline-block;
    background: white;
    padding: 3px;
    border-radius: 5px;
    float: left;
    position: relative;
    margin-top: 8px;
    margin-left: 15px; }
    .route-page .map-holder .map-options a {
      margin-right: 6px; }
    .route-page .map-holder .map-options a.active {
      background: grey; }
.route-page #map {
  position: absolute;
  top: -10000px;
  height: 650px;
  width: 95%;
  margin-left: 2.5%;
  margin-bottom: 30px;
  margin-top: 250px; }

.route-page .tooltip {
  display: none; }

.route-page.map #map,
.route-page.order #map,
.route-page.alignments #map {
  position: absolute;
  top: 210px;
  background: #e6e6e6; }
.route-page.map .tooltip,
.route-page.order .tooltip,
.route-page.alignments .tooltip {
  position: absolute;
  z-index: 9999999;
  background: none;
  color: black;
  height: 20px;
  width: 14px;
  width: 140px; }

.route-children {
  min-height: 400px; }

.route-details {
  display: inherit; }

.route-details-minimised {
  display: none; }

.edit .route-details,
.schedules .route-details,
.patterns .route-details,
.list .route-details,
.order .route-details,
.alignments .route-details,
.map .route-details {
  display: none; }
.edit .route-details-minimised,
.schedules .route-details-minimised,
.patterns .route-details-minimised,
.list .route-details-minimised,
.order .route-details-minimised,
.alignments .route-details-minimised,
.map .route-details-minimised {
  display: inherit; }

.tab-holder-large .tab.first {
  padding: 15px;
  padding-right: 14px; }

.tab-holder-large .tab.first.active {
  padding: 15px;
  padding-right: 15px;
  border-right: 0; }

#editor-save,
.pattern-editor-undo,
.pattern-editor-redo {
  float: right;
  margin-top: 35px; }

.top-options-btn.pattern-editor-undo,
.top-options-btn.pattern-editor-redo {
  color: #c6d6ec; }

.top-options-btn.pattern-editor-undo.avail,
.top-options-btn.pattern-editor-redo.avail {
  color: white; }

.stop_pattern_row {
  position: relative; }
  .stop_pattern_row td {
    padding: 8px !important; }

.stop_pattern_row:hover {
  cursor: grab; }
  .stop_pattern_row:hover td {
    background: green; }

.dragging .stop_pattern_row.is-over .hover,
.dragging .stop_pattern_row.is-over .hover {
  content: ' ';
  left: -11px;
  position: absolute;
  z-index: 99999;
  border-style: solid;
  border-width: 6px 0 6px 10px;
  border-color: transparent transparent transparent #0080ED; }

.dragging .stop_pattern_row.is-over.drag-before .hover {
  top: -6px; }

.dragging .stop_pattern_row.is-over.drag-after .hover {
  bottom: -6px; }

td.hover-holder {
  position: relative; }

div.hover-holder {
  position: relative; }

.stop_pattern_row td {
  border-bottom: 1pt solid #e7e7e7; }

.dragging .stop_pattern_row.is-over .hover-right,
.dragging .stop_pattern_row.is-over .hover-right {
  content: ' ';
  right: -11px;
  position: absolute;
  z-index: 99999;
  border-style: solid;
  border-width: 6px 10px 6px 0;
  border-color: transparent #0080ED transparent transparent; }

.dragging .stop_pattern_row.is-over.drag-before .hover-right {
  top: -6px; }

.dragging .stop_pattern_row.is-over.drag-after .hover-right {
  bottom: -6px; }

.dragging .stop_pattern_row.is-over.drag-before .hover-left {
  top: -6px; }

.dragging .stop_pattern_row.is-over.drag-after .hover-left {
  bottom: -6px; }

.dragging .stop_pattern_row.is-over tr {
  padding-top: 10px; }

.dragging .stop_pattern_row.is-over .hover-line,
.dragging .stop_pattern_row.is-over .hover-line {
  content: ' ';
  left: -2px;
  position: absolute;
  z-index: 99999;
  width: 500px;
  height: 2px;
  background: #0080ED; }

.dragging .stop_pattern_row.is-over.drag-after .hover-line {
  bottom: -1px; }

.dragging .stop_pattern_row.is-over.drag-before .hover-line {
  top: -1px; }

.dragging .stop_pattern_row.is-over .hover-line-right,
.dragging .stop_pattern_row.is-over .hover-line-right {
  content: ' ';
  right: -2px;
  position: absolute;
  z-index: 99999;
  width: 500px;
  height: 2px;
  background: #0080ED; }

.dragging .stop_pattern_row.is-over.drag-after .hover-line-right {
  bottom: -1px; }

.dragging .stop_pattern_row.is-over.drag-before .hover-line-right {
  top: -1px; }

.hover-spacer-row td {
  height: 30px;
  background: green; }

.stop-selector-popup {
  position: absolute;
  z-index: 999;
  background: white;
  width: 300px;
  border: 1px solid black;
  padding: 15px; }

.remove-row {
  cursor: pointer; }

.remove-row:hover {
  text-decoration: underline; }

.map-padder {
  height: 755px; }

.alignment-header-box {
  z-index: 99999;
  float: left;
  position: relative;
  clear: both;
  margin-top: 30px;
  font-size: .8em;
  font-weight: light; }
  .alignment-header-box .inner {
    background: white;
    padding: 8px 12px;
    border-radius: 3px;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    -webkit-box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.38);
    -moz-box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.38);
    box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.38); }
  .alignment-header-box .seg-use-box {
    background: white;
    border-left: 1px solid #d9d9d9;
    padding-left: 10px;
    margin-left: 0px;
    padding: 8px 12px;
    border-radius: 3px;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    -webkit-box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.38);
    -moz-box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.38);
    box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.38); }
  .alignment-header-box .seg-use-box.custom {
    background: #1df2ff; }

.map-mode-options {
  z-index: 99999;
  float: left;
  position: relative;
  clear: both;
  font-size: .8em;
  margin-top: 20px;
  background: white;
  width: 200px;
  border-radius: 3px;
  -webkit-box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.38);
  -moz-box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.38);
  box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.38); }
  .map-mode-options .btn {
    font-size: 1em;
    width: 100%;
    margin-bottom: 10px; }
  .map-mode-options .title {
    margin: 15px;
    font-size: 20px;
    border-top-right-radius: 3px;
    border-top-left-radius: 3px;
    position: relative; }
    .map-mode-options .title .fa-times {
      position: absolute;
      right: -7px;
      top: -9px;
      font-size: .8em;
      cursor: pointer;
      opacity: .6; }
    .map-mode-options .title .fa-times:hover {
      color: red; }
  .map-mode-options .inner {
    padding-top: 0px; }
  .map-mode-options .bottom {
    text-align: center; }
    .map-mode-options .bottom .no-changes,
    .map-mode-options .bottom .has-changes,
    .map-mode-options .bottom .staged-changes {
      padding: 5px;
      border-bottom-right-radius: 3px;
      border-bottom-left-radius: 3px; }
    .map-mode-options .bottom .no-changes {
      background: #d8eeff; }
    .map-mode-options .bottom .has-changes {
      background: #d8eeff; }
    .map-mode-options .bottom .staged-changes {
      background: #d8eeff; }
    .map-mode-options .bottom .btn.btn-success {
      clear: both;
      display: block;
      margin: 0 auto;
      width: auto;
      margin-bottom: 10px;
      background: #f6fb38;
      border: 0;
      color: black;
      -webkit-box-shadow: 0px 3px 0px 0px #b9d053;
      -moz-box-shadow: 0px 3px 0px 0px #b9d053;
      box-shadow: 0px 3px 0px 0px #b9d053; }
  .map-mode-options .autogen-spacer {
    width: 15px;
    height: 15px;
    display: inline-block; }

.map-mode-toolbar {
  float: left;
  position: relative;
  margin-top: 8px;
  background: white;
  padding: 3px;
  border-radius: 3px; }

.map-mode-legend {
  z-index: 99999;
  position: fixed;
  bottom: 15px;
  left: 15px;
  margin-top: 10px;
  background: white;
  padding: 3px;
  border-radius: 3px; }

/* fix for weird chrome bug */
.mapboxgl-popup-content {
  max-width: 400px; }

.top-options-btn {
  font-size: .8em;
  background: #0080ED;
  padding: 3px 6px;
  color: white; }

.top-options-btn#editor-save {
  background: #4bd78a;
  border: 0;
  width: 100px; }

.top-options-btn#editor-save.no-changes {
  background: #dadddb;
  border: 0;
  color: black; }

.top-options-btn.pattern-editor-undo {
  border: 0;
  background: #7fa8d7; }

.top-options-btn.pattern-editor-undo.last {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  margin-right: 9px; }

.top-options-btn.pattern-editor-undo.first {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-right: 1px solid #6c8fb7; }

.top-options-btn i.first {
  font-size: .9em; }
.top-options-btn i.second {
  font-size: .7em; }

.save-panel-holder {
  float: right;
  margin-top: 57px; }

.long-arrow-holder {
  display: inline-block;
  position: relative;
  width: 60px;
  margin-left: 10px;
  margin-right: 10px;
  top: -4px; }
  .long-arrow-holder .long-arrow-dot {
    position: absolute;
    left: -2px;
    top: -1px;
    width: 4px;
    height: 4px;
    border-radius: 4px; }
  .long-arrow-holder .long-arrow-line {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px; }
  .long-arrow-holder .long-arrow-triangle {
    top: -2px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 0 4px 5px;
    position: absolute;
    right: -3px; }

.long-arrow-holder.staged .long-arrow-dot,
.long-arrow-holder.staged .long-arrow-line {
  background: #4bd78a; }

.long-arrow-holder.staged .long-arrow-triangle {
  border-color: transparent transparent transparent #4bd78a; }

.long-arrow-holder.not-staged .long-arrow-dot,
.long-arrow-holder.not-staged .long-arrow-line {
  background: #f5ad00; }

.long-arrow-holder.not-staged .long-arrow-triangle {
  border-color: transparent transparent transparent #f5ad00; }

.long-arrow-holder.error .long-arrow-dot,
.long-arrow-holder.error .long-arrow-line {
  background: #f50000; }

.long-arrow-holder.error .long-arrow-triangle {
  border-color: transparent transparent transparent #f50000; }

.default-select {
  font-size: 1em !important; }

.add-stop-to-end-link {
  text-align: left;
  font-size: 1.2em;
  padding: 10px !important; }
  .add-stop-to-end-link a {
    cursor: pointer; }

.timed-pattern-header-padding {
  padding: 20px;
  text-align: center; }
  .timed-pattern-header-padding i {
    position: relative;
    left: 5px;
    top: 0px !important; }
  .timed-pattern-header-padding .timed-pattern-header-label {
    position: relative;
    left: -6px;
    top: -1px; }

.add-stop-to-end-link {
  background: white !important; }

.Select-control {
  min-width: 300px; }

.no-timed-patterns .header-headsign,
.no-timed-patterns .header-arrive,
.no-timed-patterns .header-depart,
.no-timed-patterns .header-drop-off,
.no-timed-patterns .header-pick-up {
  opacity: .5; }

td.arrival_time {
  font-weight: bold;
  font-size: 1.3em; }

td.departure_time {
  font-weight: bold;
  font-size: 1.3em; }

td.departure_time,
td.arrival_time {
  position: relative; }
  td.departure_time .disabled,
  td.arrival_time .disabled {
    pointer-events: none;
    color: #3c3c3c !important; }
  td.departure_time .hide-time,
  td.arrival_time .hide-time {
    position: relative; }
  td.departure_time .hide-time::before,
  td.arrival_time .hide-time::before {
    content: '';
    position: absolute;
    top: 5px;
    width: 10px;
    background: black;
    height: 2px; }
  td.departure_time input,
  td.arrival_time input {
    width: 90px !important; }
  td.departure_time input.show-time,
  td.arrival_time input.show-time {
    color: black; }
  td.departure_time input.hide-time,
  td.arrival_time input.hide-time {
    opacity: 0; }

.input-dash {
  cursor: pointer; }

.sortable-table .fa-files-o {
  cursor: pointer; }

.map-link i {
  color: #f30050;
  font-size: 1.5em; }
.map-link i.isSet {
  color: #4bd78a; }

a.delete-timed-pattern-link {
  font-size: .8em;
  font-weight: normal;
  color: grey;
  margin-left: 10px; }

img.edit-pattern-name-icon {
  width: 13px;
  opacity: .7;
  margin-left: 5px;
  cursor: pointer; }

.pattern-name-input {
  padding: 5px;
  border-radius: 3px;
  border: 1px solid #ccc; }

.pattern-name-save-status {
  margin-left: 5px;
  color: grey;
  font-size: .8em;
  font-weight: normal; }

.time-offset {
  position: relative;
  left: -17px; }
  .time-offset .input-label-minor {
    padding-left: 0;
    font-size: 1.4em; }
  .time-offset .show-time input {
    padding: 4px;
    border-radius: 3px;
    border: 1px solid #97d0f8;
    margin-top: 4px;
    font-size: 1.4em; }

.row-drag-hotspot {
  cursor: move;
  font-size: 1.4em; }

.fa-exclamation-triangle {
  color: red; }

.solo-segment-select.Select--single {
  float: right;
  position: relative;
  top: -7px;
  margin-left: 28px; }

.timed-pattern-header-padding .fa-bars {
  cursor: pointer;
  font-size: 1.3em;
  opacity: .6;
  position: relative;
  left: 9px;
  top: 4px !important; }

.rc-dropdown-menu > .rc-dropdown-menu-item-selected:after {
  content: '' !important; }

.rc-dropdown-menu > .rc-dropdown-menu-item-selected {
  background-color: white; }

.timed-pattern-trip-select {
  margin-top: 31px; }
  .timed-pattern-trip-select .Select-placeholder {
    color: #0095c9;
    font-weight: normal;
    font-size: .8em; }
  .timed-pattern-trip-select .Select-control {
    border: 1px solid #97d0f8; }

.gtfsm-title {
  display: inline-block;
  margin-top: 30px; }

.home .upper-links, .login .upper-links {
  margin-top: 28px; }
.home .user-agency-list, .login .user-agency-list {
  list-style: none;
  padding: 0;
  margin: 0; }
  .home .user-agency-list li, .login .user-agency-list li {
    padding: 0;
    margin: 0; }
.home .welcome-top, .login .welcome-top {
  border-top: 1px solid grey;
  margin: 15px;
  margin-top: 0; }

.login .password-reset-message {
  margin-top: 25px;
  margin-bottom: 25px;
}

.login input {
  margin-bottom: 20px; }
.login .checkbox label {
  padding-left: 0; }

.login .reset-password-link {
  display: inline;
  padding-left: 15px;
}

.agency-headsigns .box.new-headsign {
  width: auto;
  min-width: 0;
  display: table;
  border-radius: 2px; }
  .agency-headsigns .box.new-headsign h2 {
    border-top-left-radius: 2px;
    border-top-right-radius: 2px; }
  .agency-headsigns .box.new-headsign h2 span {
    font-size: .6em;
    float: right;
    position: relative;
    top: 5px;
    text-transform: none; }

@keyframes pulse {
  50% {
    background-color: #ccc; } }
tr.filter-row.minimized {
  height: 0;
  border: 1px solid transparent !important; }

.table-filter.minimized {
  position: absolute;
  display: inline-block;
  position: absolute;
  right: 20px;
  top: -18px;
  height: 20px;
  font-size: .7em;
  line-height: 1.5em;
  padding: 3px 5px 0 5px;
  border-top-right-radius: 3px;
  border-top-left-radius: 3px;
  background: #B799CA !important;
  color: white; }

.table-filter.active {
  display: table-cell; }
  .table-filter.active input {
    border: 0;
    border-radius: 5px;
    height: 29px;
    margin-top: 3px;
    margin-left: 3px;
    border: 1px solid rgba(0, 0, 0, 0.5);
    padding-left: 8px; }

.close-filter {
  position: absolute;
  font-size: 1em;
  right: 14px;
  top: 24px; }

table.dense.sortable-table td {
  margin: 4px;
  padding: 7px 5px;
  text-align: left;
  font-size: .8em; }

table.sortable-table {
  position: relative;
  border: 0;
  /* -webkit-box-shadow: 0px 3px 4px 0px rgba(0, 0, 0, 0.17);
  -moz-box-shadow: 0px 3px 4px 0px rgba(0, 0, 0, 0.17);
  box-shadow: 0px 3px 4px 0px rgba(0, 0, 0, 0.17); */
  min-width: 350px; }
  table.sortable-table .hasRowClick {
    cursor: pointer; }
  table.sortable-table th {
    background: #f8f3fb;
    cursor: pointer;
    text-align: left;
    color: black;
    font-size: 1em;
    border-bottom: 4px #acacac solid;
    border-top: 1px solid #acacac;
    -webkit-touch-callout: none;
    /* iOS Safari */
    -webkit-user-select: none;
    /* Chrome/Safari/Opera */
    -khtml-user-select: none;
    /* Konqueror */
    -moz-user-select: none;
    /* Firefox */
    -ms-user-select: none;
    /* Internet Explorer/Edge */
    user-select: none; }
  table.sortable-table th.active {
    padding-right: 10px; }
  table.sortable-table th span.header-container {
    padding: 10px 10px 10px 0; }
  table.sortable-table th.active span.header-container {
    background: #f3e0f3;
    display: table-cell;
    position: relative;
    padding: 10px 19px 10px 10px; }
  table.sortable-table th.active.asc span.header-container::after {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    content: '';
    width: 0;
    height: 0;
    right: 8px;
    border-style: solid;
    border-width: 6px 4.5px 0 4.5px;
    border-color: black transparent transparent transparent; }
  table.sortable-table th.active.desc span.header-container::after {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    content: '';
    width: 0;
    right: 8px;
    height: 0;
    border-style: solid;
    border-width: 0 4.5px 6px 4.5px;
    border-color: transparent transparent black transparent; }
  table.sortable-table th:last-of-type {
    border-right: 1px solid #acacac; }
  table.sortable-table th:first-of-type {
    border-left: 1px solid #acacac; }
    table.sortable-table th:first-of-type span.header-container {
      padding: 10px 10px 10px 10px; }
  table.sortable-table th:first-of-type.active span.header-container {
    background: #f3e0f3;
    display: table-cell;
    position: relative;
    padding: 10px 19px 10px 10px; }
  table.sortable-table th.table-filter.active {
    padding: 15px; }
  table.sortable-table th.table-filter {
    border-bottom: 0;
    background: #B799CA; }
    table.sortable-table th.table-filter i {
      color: white; }
  table.sortable-table .route-list-icon {
    width: 10px;
    height: 10px;
    border-radius: 10px;
    display: inline-block;
    margin-right: 4px; }
  table.sortable-table .fa-times {
    color: #ccc;
    cursor: pointer; }
  table.sortable-table tr.route-row.is-over.drag-before {
    border-top: 3px solid #0080ED; }
  table.sortable-table tr.route-row.is-over.drag-after {
    border-bottom: 3px solid #0080ED; }
  table.sortable-table tr:nth-child(even) td {
    background: #F2F2F2; }
  table.sortable-table tbody {
    border: #95989A solid 1px; }
    table.sortable-table tbody tr:hover {
      background: #eff9fc; }
      table.sortable-table tbody tr:hover td {
        background: 0; }
      table.sortable-table tbody tr:hover .fa-times {
        color: red; }
  table.sortable-table tbody tr {
    list-style: none;
    margin: 4px;
    -webkit-transition: margin 2s;
    transition: margin 2s; }
    table.sortable-table tbody tr td.headsign {
      text-align: left; }
    table.sortable-table tbody tr .route-circle {
      position: relative;
      bottom: 1px;
      vertical-align: middle;
      margin-right: 5px; }
    table.sortable-table tbody tr td {
      margin: 4px;
      padding: 14px 10px;
      text-align: left; }
  table.sortable-table tr.pending {
    opacity: .6;
    animation: pulse .5s ease-out 2; }
  table.sortable-table tr.route-row.dragable {
    cursor: ns-resize;
    border: 1px solid #ccc;
    padding: 5px;
    list-style: none; }

.trip-preview-panel {
  width: 30%;
  min-width: 500px;
  position: fixed;
  height: 100vh;
  right: 0;
  display: inline-block;
  top: 0;
  background: white;
  z-index: 9999999;
  -webkit-box-shadow: 0px 0px 43px 0px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 0px 43px 0px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 0px 43px 0px rgba(0, 0, 0, 0.75); }
  .trip-preview-panel .trip-preview-header {
    background: #BDEAFE;
    padding: 0 25px 25vh 25px;
    height: 25vh; }
    .trip-preview-panel .trip-preview-header h4 {
      padding-top: 10px; }
      .trip-preview-panel .trip-preview-header h4 span {
        font-size: .7em;
        float: right;
        cursor: pointer; }
    .trip-preview-panel .trip-preview-header ul {
      list-style-type: none;
      padding: 0;
      margin: 0; }
      .trip-preview-panel .trip-preview-header ul li {
        padding: 0;
        margin: 0;
        margin-bottom: 10px; }
      .trip-preview-panel .trip-preview-header ul li:last-of-type {
        margin-bottom: 0; }
    .trip-preview-panel .trip-preview-header .category {
      font-weight: bold; }
  .trip-preview-panel .trip-preview-inner {
    padding: 5vh 25px;
    overflow: scroll;
    height: 75vh; }
    .trip-preview-panel .trip-preview-inner table td, .trip-preview-panel .trip-preview-inner table th {
      padding: 10px; }
    .trip-preview-panel .trip-preview-inner table i.preview-stop-circle {
      display: inline-block;
      width: 0px; }
    .trip-preview-panel .trip-preview-inner table td.stop-icon {
      position: relative; }
    .trip-preview-panel .trip-preview-inner table tr:hover td {
      background: rgba(0, 0, 255, 0.1); }
    .trip-preview-panel .trip-preview-inner table i.preview-stop-circle:after {
      content: '';
      width: 16px;
      height: 16px;
      border: 3px solid black;
      border-radius: 10px;
      background: white;
      position: absolute;
      left: 50%;
      margin-left: -8px;
      top: 35%; }
    .trip-preview-panel .trip-preview-inner table i.preview-stop-circle:before {
      content: '';
      width: 4px;
      height: 90px;
      background: black;
      position: absolute;
      left: 50%;
      margin-left: -2px;
      top: 35%; }
    .trip-preview-panel .trip-preview-inner table tr:last-of-type i.preview-stop-circle:before {
      background: white;
      width: 6px;
      margin-left: -3px; }
    .trip-preview-panel .trip-preview-inner table td.preview-stop-arrival-time,
    .trip-preview-panel .trip-preview-inner table td.preview-stop-departure-time {
      font-family: "Courier New", Courier, "Lucida Sans Typewriter", "Lucida Typewriter", monospace;
      font-weight: bold; }

.block-color-holder {
  width: 15%;
  float: left; }
  .block-color-holder .block-color {
    width: 10px;
    height: 10px;
    border-radius: 10px;
    display: inline-block; }

.block-color-name-holder {
  width: 85%;
  float: left; }

.dark-focus {
  position: fixed;
  padding: 0;
  margin: 0;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.3); }
  .dark-focus .dark-focus-inner {
    width: auto;
    min-width: 0;
    display: table;
    margin: 0 auto;
    position: fixed;
    top: 50%;
    left: 50%;
    /* bring your own prefixes */
    transform: translate(-50%, -50%); }

.route-details-form-holder {
  border: #ccc 1px solid;
  padding: 15px; }

.route-header-route {
  border-right: 1px solid #ccc;
  padding-right: 23px; }

.route-page-circle {
  top: 7px !important; }

.route-page-circle.square {
  top: 7px !important;
  border-radius: 0 !important; }

.color-picker-holder .picker-preview {
  border: #ccc 1px solid;
  width: 14px;
  height: 14px;
  border-radius: 14px;
  display: inline-block; }

.list-of-service-periods {
  border-right: 1px solid #ccc; }
  .list-of-service-periods ul, .list-of-service-periods li {
    padding: 0;
    margin: 0;
    list-style: none; }
  .list-of-service-periods i.fa {
    cursor: pointer; }
  .list-of-service-periods ul.service-periods {
    margin-bottom: 15px; }
  .list-of-service-periods input {
    border-radius: 0px;
    border: 1px solid #ccc;
    border: 0;
    background: #F5FFFF;
    padding: 1px 0px 1px;
    font-size: 1.2em;
    text-align: center;
    border-bottom: 2px solid #ccc;
    cursor: pointer; }

ul.exceptions-services {
  display: inline; }
  ul.exceptions-services li {
    padding: 4px;
    background: white;
    border-radius: 4px;
    margin: 2px;
    display: inline-block;
    clear: both;
    float: left; }

ul.exceptions-services.added {
  list-style: none;
  list-style-type: none; }
  ul.exceptions-services.added li {
    list-style: none;
    border: 2px solid rgba(0, 255, 0, 0.4); }

ul.exceptions-services.removed li {
  border: 2px solid rgba(255, 0, 0, 0.4); }

.services-box {
  padding: 20px;
  border-top-right-radius: 4px;
  border-top-left-radius: 4px; }
  .services-box .services-box-title {
    font-weight: bold;
    font-size: 1.3em; }
  .services-box .services-box-select-holder {
    padding-top: 20px; }
  .services-box ul, .services-box li {
    list-style: none;
    list-style-type: none; }
  .services-box ul.services-box-list {
    margin: 0;
    padding: 0; }
    .services-box ul.services-box-list .exception-list-item-holder {
      display: block;
      margin-bottom: 10px;
      padding: 5px;
      background: white;
      border-radius: 3px;
      font-weight: bold;
      position: relative; }
      .services-box ul.services-box-list .exception-list-item-holder span.exception_id {
        position: absolute;
        bottom: 2px;
        right: 4px;
        color: #999; }
      .services-box ul.services-box-list .exception-list-item-holder hr {
        margin-top: 5px;
        margin-bottom: 5px; }
      .services-box ul.services-box-list .exception-list-item-holder .flag-exception {
        position: absolute;
        right: 2px;
        top: 50%; }
      .services-box ul.services-box-list .exception-list-item-holder .fa-times {
        float: right; }
      .services-box ul.services-box-list .exception-list-item-holder .fa-times:hover {
        color: red;
        cursor: pointer; }
      .services-box ul.services-box-list .exception-list-item-holder ul.exception-day-buttons {
        margin: 0;
        padding: 0; }
        .services-box ul.services-box-list .exception-list-item-holder ul.exception-day-buttons li {
          font-size: .9em; }
        .services-box ul.services-box-list .exception-list-item-holder ul.exception-day-buttons li.disabled {
          opacity: .3;
          pointer-events: none; }
    .services-box ul.services-box-list li.exception-list-item-holder:first-of-type {
      margin-top: 16px; }
    .services-box ul.services-box-list li.exception-list-item-holder:last-of-type {
      margin-bottom: 24px; }
  .services-box .no-services-blurb {
    margin: 15px 0 15px 0; }

.services-removed-box {
  background: #FFEDED;
  border: 1px solid #FF9A9A; }
  .services-removed-box .services-box-select-holder {
    border-top: 1px solid #FF9A9A; }
  .services-removed-box li {
    border: 1px solid #D60000; }

.services-added-box {
  background: #F0FFF1;
  border: 1px solid #9AFFA1; }
  .services-added-box .services-box-select-holder {
    border-top: 1px solid #9AFFA1; }
  .services-added-box li {
    border: 1px solid #00A520; }

.exceptions-box {
  border: 1px solid #eee;
  padding: 15px;
  margin-top: 15px; }
  .exceptions-box h2 {
    margin-top: 0; }

ul.exception-day-buttons {
  margin: 0;
  padding: 0; }
  ul.exception-day-buttons li {
    float: left;
    color: black;
    font-weight: bold;
    padding: 6px 13px;
    margin-right: 4px;
    border-radius: 3px;
    font-size: 1.4em;
    cursor: pointer; }

.push-exception-button {
  background: #2DBCF0;
  border-radius: 4px;
  cursor: pointer;
  border: none;
  float: right;
  padding: 6px 12px;
  font-size: 1.6em;
  color: white; }

.services-removed-menu {
  position: relative;
  float: right;
  cursor: pointer; }
  .services-removed-menu .services-removed-menu-dropdown {
    position: absolute;
    top: 22px;
    right: 0;
    width: 250px;
    z-index: 999;
    background: white;
    -webkit-box-shadow: 0px 4px 5px 0px rgba(0, 0, 0, 0.32);
    -moz-box-shadow: 0px 4px 5px 0px rgba(0, 0, 0, 0.32);
    box-shadow: 0px 4px 5px 0px rgba(0, 0, 0, 0.32); }
    .services-removed-menu .services-removed-menu-dropdown span {
      display: inline-block;
      clear: both;
      font-size: 15px;
      font-weight: normal;
      border-bottom: 1px solid grey;
      padding: 5px; }
    .services-removed-menu .services-removed-menu-dropdown span:hover {
      background: #BFEAFA;
      cursor: pointer; }
    .services-removed-menu .services-removed-menu-dropdown span:last-of-type {
      border: 0; }

.calendar-title {
  cursor: pointer;
  display: inline; }
  .calendar-title .fa-pencil {
    font-size: .7em;
    opacity: .8;
    position: relative;
    top: -3px;
    left: 5px; }

#map {
  position: absolute;
  top: -9999999px;
  height: 400px;
  width: 100%;
  margin: 0 auto;
  background: white; }

.map-style-controls {
  bottom: -999999px;
  display: none;
  position: absolute; }

.map-style-controls.active {
  z-index: 999999;
  position: absolute;
  top: 20px;
  right: 68px;
  height: 30px;
  display: inherit; }

#map.active {
  position: relative;
  top: 0; }

.stop-action-menu {
  padding: 15px 15px 15px 0; }
  .stop-action-menu button, .stop-action-menu a {
    margin-right: 10px; }

.filter-ctrl {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 1;
  width: 180px; }

.filter-ctrl input[type=text] {
  font: 12px/20px 'Helvetica Neue', Arial, Helvetica, sans-serif;
  width: 100%;
  border: 0;
  background-color: #fff;
  height: 40px;
  margin: 0;
  color: rgba(0, 0, 0, 0.5);
  padding: 10px;
  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.1);
  border-radius: 3px; }

.col-header.current {
  background: #c7deff; }

.col-arrow {
  display: inline-block;
  margin-left: 5px;
  position: relative;
  top: -3px;
  margin-top: 10px; }

.col-arrow.asc {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 4px 0 4px;
  border-color: white transparent transparent transparent; }

.col-arrow.desc {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 4px 5px 4px;
  border-color: transparent transparent white transparent; }

.loading .map-holder {
  opacity: 0; }

.map-holder {
  position: relative;
  width: 100%;
  float: left;
  min-width: 600px; }
  .map-holder .map-tooltip {
    position: absolute;
    z-index: 9999999;
    background: none;
    color: black;
    height: 20px;
    width: 14px;
    width: 140px; }
  .map-holder .map-legend {
    display: none; }
  .map-holder .map-legend.active {
    display: inherit;
    padding: 10px;
    background: white;
    z-index: 999999;
    position: absolute;
    left: 10px;
    bottom: 74px; }
  .map-holder .tooltip-stop-id {
    background: #f3f1ff;
    /* padding: 3px; */
    width: 95%;
    margin: 0 auto;
    margin-top: 3px;
    cursor: pointer; }
  .map-holder .map-tooltip {
    display: inline; }
  .map-holder .map-tooltip .stop-map-hover-tooltip {
    position: absolute;
    top: 15px;
    width: 140px;
    color: #000000;
    background: #FFFFFF;
    border: 2px solid #6d6d6d;
    line-height: 30px;
    border-radius: 2px;
    box-shadow: 0px 0px 4px #666666; }
  .map-holder .map-tooltip .stop-map-hover-tooltip:before {
    content: '';
    position: absolute;
    bottom: 100%;
    left: 50%;
    margin-left: -12px;
    width: 0;
    height: 0;
    border-bottom: 12px solid #6d6d6d;
    border-right: 12px solid transparent;
    border-left: 12px solid transparent; }
  .map-holder .map-tooltip .stop-map-hover-tooltip:after {
    content: '';
    position: absolute;
    bottom: 100%;
    left: 50%;
    margin-left: -8px;
    width: 0;
    height: 0;
    border-bottom: 8px solid #FFFFFF;
    border-right: 8px solid transparent;
    border-left: 8px solid transparent; }
  .map-holder .map-menu {
    position: absolute;
    z-index: 99999;
    background: white;
    color: black;
    -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
    -moz-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
    box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
    border-radius: 0 10px 10px 10px; }
    .map-holder .map-menu ul {
      margin: 0;
      padding: 0; }
      .map-holder .map-menu ul li {
        list-style: none;
        margin: 0;
        padding: 10px; }
      .map-holder .map-menu ul li:hover {
        text-decoration: underline; }

table.stop-table {
  border: 1px solid #ccc; }
  table.stop-table th.stop_id-col input {
    width: 60px; }
  table.stop-table th.stop_list_order-col input {
    width: 60px; }
  table.stop-table th.stop_code-col input {
    width: 60px; }
  table.stop-table tr:nth-child(even) {
    background: #ebedf8; }
  table.stop-table td {
    font-size: .8em; }
  table.stop-table .edit-stop img {
    opacity: .3; }
  table.stop-table tr:hover {
    background: #d4e3ff; }
    table.stop-table tr:hover .fa.fa-times {
      color: red;
      margin: 3px; }
    table.stop-table tr:hover .edit-stop img {
      opacity: 1; }
  table.stop-table .stop-row.selected {
    background: #ebebff; }
  table.stop-table .fa.fa-times {
    color: grey;
    margin: 3px; }

.edit-stop-panel {
  width: 45vw;
  min-width: 300px;
  height: 100vh;
  z-index: 10;
  position: fixed;
  right: 0;
  top: 0;
  background: white;
  color: black;
  -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
  overflow: scroll; }
  .edit-stop-panel .btn {
    float: left; }
  .edit-stop-panel .transfer-options {
    background: rgba(240, 248, 255, 0.72);
    padding: 5px;
    padding-top: 1px; }
  .edit-stop-panel .title-link {
    display: inline-block;
    margin-top: 13px; }

select.bulk-actions {
  height: 35px;
  display: inline-block;
  width: 150px;
  padding: 10px; }

.stop-close-button {
  position: absolute;
  right: 10px;
  top: 10px; }
  .stop-close-button .fa-times {
    margin-left: 4px; }

.stops-list.edit .map-holder,
.stops-list.new .map-holder {
  width: 55vw;
  height: 100vh;
  z-index: 10;
  position: fixed;
  left: 0;
  top: 0;
  background: white; }
  .stops-list.edit .map-holder #map,
  .stops-list.new .map-holder #map {
    width: 100%;
    height: 100%;
    top: 0;
    z-index: 20;
    position: relative; }
  .stops-list.edit .map-holder .map-overlay,
  .stops-list.new .map-holder .map-overlay {
    display: inherit; }

.map-holder .map-overlay {
  display: none;
  position: absolute;
  left: 40px;
  top: 40px;
  padding: 15px;
  font-size: 1.2em;
  -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
  background: #d8feff;
  z-index: 99999; }

.stops-list.edit #map .map-holder .map-overlay,
.stops-list.new #map .map-holder .map-overlay {
  display: inherit; }

.stops-list.zones {
  width: 50%;
  min-width: 500px; }

.edit-stop-panel {
  padding: 15px; }

.stop-child-panel.panel-enter {
  width: 0vw;
  opacity: 0.01;
  transition: width 500ms ease-out,opacity 500ms ease-out; }
  .stop-child-panel.panel-enter .contents {
    opacity: 0;
    transition: opacity 500ms ease-in; }

.stop-child-panel.panel-enter.panel-enter-active {
  width: 43vw;
  opacity: 1; }
  .stop-child-panel.panel-enter.panel-enter-active .contents {
    opacity: 1; }

.stop-child-panel.panel-appear {
  width: 0vw;
  opacity: 0.01;
  transition: width 500ms ease-out,opacity 500ms ease-out; }
  .stop-child-panel.panel-appear .contents {
    opacity: 0;
    transition: opacity 500ms ease-in; }

.stop-child-panel.panel-appear.panel-appear-active {
  width: 43vw;
  opacity: 1; }
  .stop-child-panel.panel-appear.panel-appear-active .contents {
    opacity: 1; }

.stop-child-panel.panel-leave {
  width: 43vw;
  opacity: 1;
  transition: width 500ms ease-out,opacity 500ms ease-out; }
  .stop-child-panel.panel-leave .contents {
    opacity: 1;
    transition: opacity 300ms ease-in;
    overflow: hidden; }

.stop-child-panel.panel-leave.panel-leave-active {
  width: 0vw;
  opacity: 0.01; }
  .stop-child-panel.panel-leave.panel-leave-active .contents {
    opacity: 0; }

table.stop-table > thead > tr > th {
  background: #f8f7ff;
  padding: 1px;
  border-right: 1px solid #e7e4ff; }
table.stop-table > thead > tr > th:last-of-type {
  padding: 1px;
  font-weight: 1.1em;
  border-right: 0; }
table.stop-table > tbody > tr > td {
  padding: 1px;
  font-weight: 1.1em;
  border-right: 1px solid #eee; }
table.stop-table > tbody > tr > td:last-of-type {
  padding: 1px;
  font-weight: 1.1em;
  border-right: 0; }

.stop-child-panel {
  padding: 15px;
  width: 43vw;
  height: 100vh;
  z-index: 100000;
  position: fixed;
  right: 0;
  top: 0;
  background: white;
  color: black;
  -webkit-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.75);
  overflow: scroll; }
  .stop-child-panel .contents {
    width: 100%;
    overflow: auto; }

.sk-fading-circle {
  margin: 10px auto;
  width: 40px;
  height: 40px;
  position: relative; }

.sk-fading-circle .sk-circle {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0; }

.sk-fading-circle .sk-circle:before {
  content: '';
  display: block;
  margin: 0 auto;
  width: 15%;
  height: 15%;
  background-color: #333;
  border-radius: 100%;
  -webkit-animation: sk-circleFadeDelay 1.2s infinite ease-in-out both;
  animation: sk-circleFadeDelay 1.2s infinite ease-in-out both; }

.sk-fading-circle .sk-circle2 {
  -webkit-transform: rotate(30deg);
  -ms-transform: rotate(30deg);
  transform: rotate(30deg); }

.sk-fading-circle .sk-circle3 {
  -webkit-transform: rotate(60deg);
  -ms-transform: rotate(60deg);
  transform: rotate(60deg); }

.sk-fading-circle .sk-circle4 {
  -webkit-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg); }

.sk-fading-circle .sk-circle5 {
  -webkit-transform: rotate(120deg);
  -ms-transform: rotate(120deg);
  transform: rotate(120deg); }

.sk-fading-circle .sk-circle6 {
  -webkit-transform: rotate(150deg);
  -ms-transform: rotate(150deg);
  transform: rotate(150deg); }

.sk-fading-circle .sk-circle7 {
  -webkit-transform: rotate(180deg);
  -ms-transform: rotate(180deg);
  transform: rotate(180deg); }

.sk-fading-circle .sk-circle8 {
  -webkit-transform: rotate(210deg);
  -ms-transform: rotate(210deg);
  transform: rotate(210deg); }

.sk-fading-circle .sk-circle9 {
  -webkit-transform: rotate(240deg);
  -ms-transform: rotate(240deg);
  transform: rotate(240deg); }

.sk-fading-circle .sk-circle10 {
  -webkit-transform: rotate(270deg);
  -ms-transform: rotate(270deg);
  transform: rotate(270deg); }

.sk-fading-circle .sk-circle11 {
  -webkit-transform: rotate(300deg);
  -ms-transform: rotate(300deg);
  transform: rotate(300deg); }

.sk-fading-circle .sk-circle12 {
  -webkit-transform: rotate(330deg);
  -ms-transform: rotate(330deg);
  transform: rotate(330deg); }

.sk-fading-circle .sk-circle2:before {
  -webkit-animation-delay: -1.1s;
  animation-delay: -1.1s; }

.sk-fading-circle .sk-circle3:before {
  -webkit-animation-delay: -1s;
  animation-delay: -1s; }

.sk-fading-circle .sk-circle4:before {
  -webkit-animation-delay: -0.9s;
  animation-delay: -0.9s; }

.sk-fading-circle .sk-circle5:before {
  -webkit-animation-delay: -0.8s;
  animation-delay: -0.8s; }

.sk-fading-circle .sk-circle6:before {
  -webkit-animation-delay: -0.7s;
  animation-delay: -0.7s; }

.sk-fading-circle .sk-circle7:before {
  -webkit-animation-delay: -0.6s;
  animation-delay: -0.6s; }

.sk-fading-circle .sk-circle8:before {
  -webkit-animation-delay: -0.5s;
  animation-delay: -0.5s; }

.sk-fading-circle .sk-circle9:before {
  -webkit-animation-delay: -0.4s;
  animation-delay: -0.4s; }

.sk-fading-circle .sk-circle10:before {
  -webkit-animation-delay: -0.3s;
  animation-delay: -0.3s; }

.sk-fading-circle .sk-circle11:before {
  -webkit-animation-delay: -0.2s;
  animation-delay: -0.2s; }

.sk-fading-circle .sk-circle12:before {
  -webkit-animation-delay: -0.1s;
  animation-delay: -0.1s; }

@-webkit-keyframes sk-circleFadeDelay {
  0%, 39%, 100% {
    opacity: 0; }
  40% {
    opacity: 1; } }
@keyframes sk-circleFadeDelay {
  0%, 39%, 100% {
    opacity: 0; }
  40% {
    opacity: 1; } }
.route-usage-icon {
  background: #e1e1e1;
  display: inline-block;
  margin-right: 3px;
  padding: 1px; }

.transfer-header {
  border-radius: 17px;
  height: 17px;
  width: 17px;
  background: white;
  border: 2px solid black;
  color: black;
  display: inline-block;
  font-size: .7em;
  text-align: center;
  padding: 2px;
  line-height: 11px; }

.row-sel.selected .inner,
.select-stop-header.selected .inner {
  border: 1px solid grey;
  background: #567eff; }

.row-sel {
  padding: 5px; }
  .row-sel .inner {
    margin: 5px 5px;
    border: 1px solid grey;
    background: white;
    width: 20px;
    height: 20px;
    cursor: pointer;
    border-radius: 2px; }

.select-stop-header {
  padding: 10px; }
  .select-stop-header .inner {
    cursor: pointer;
    margin: 5px;
    width: 10px;
    height: 10px;
    border: 1px solid grey;
    background: white; }

td.delete-stop {
  color: red;
  font-weight: bold;
  cursor: pointer; }

.stop-count-desc {
  position: relative;
  top: 33px;
  color: grey;
  float: right;
  right: 80px; }

.stop-action-menu {
  float: left; }
  .stop-action-menu .top-options-btn {
    margin-left: 10px;
    height: 33px; }

.usage-route-icon {
  width: 20px;
  height: 20px;
  border-radius: 20px;
  display: inline-block; }

.add-new-empty {
  font-size: 1.5em;
  color: #1e1e1e;
  text-align: center; }
  .add-new-empty .fa-plus {
    position: relative;
    left: 4px;
    top: 2px; }

.map-instructions {
  display: inline-block;
  position: absolute;
  z-index: 100;
  left: 10px;
  top: 10px;
  background: white;
  padding: 0 2px;
  border-radius: 2px; }

.stops-list {
  display: table; }

.sortable-row .edit_icon img {
  opacity: .3; }
.sortable-row .fa-times {
  margin-left: 5px;
  font-size: 15px; }

.sortable-row:hover .edit_icon img {
  opacity: 1; }

#Stops-holder {
  margin-top: 6px; }
  #Stops-holder table.dense.sortable-table td {
    padding: 0;
    padding-right: 6px; }
  #Stops-holder .tab-holder {
    margin-bottom: 37px; }

.delete_stop {
  padding-right: 10px; }

.child-stop-table td, .child-stop-table th {
  padding: 10px;
  background: #eee;
  border: 1px solid #ccc; }

.stop-noneditable-info {
  padding: 10px;
  background: #eee;
  margin-bottom: 15px; }

.usage-panel h3 {
  border-bottom: 1px solid #eee;
  padding-bottom: 10px; }
.usage-panel .route-page-circle {
  width: 14px;
  height: 14px;
  border-width: 1px;
  top: 0 !important; }

.stop-list-popup-wrapper {
  padding: 10px; }

.copy-lat-lon {
  cursor: pointer; }

.stops-list.zones .map-holder {
  position: absolute;
  top: -9999999px; }

.fares-box {
  padding: 15px;
  border: 1px solid #d4d4d4; }
  .fares-box h2 {
    margin-top: 0; }
  .fares-box .sortable-table {
    width: 100%; }
  .fares-box .Select-control {
    min-width: 100px; }
  .fares-box h3.sectional {
    margin-bottom: 28px; }
  .fares-box h2 {
    margin-bottom: 29px; }

.currency.form-control {
  padding-left: 20px; }

.currency-input-wrapper::before {
  content: '$';
  position: absolute;
  left: 16px;
  top: 7px; }

.additional-category-holder ul {
  list-style: none;
  list-style-type: none;
  margin: 0;
  padding: 0;
  margin-top: 10px; }
  .additional-category-holder ul li {
    list-style: none;
    list-style-type: none;
    margin: 0;
    padding: 1px 3px;
    border: 1px solid #eee;
    border-radius: 3px;
    cursor: pointer;
    display: inline;
    margin: 3px;
    /* padding: 10px; */
    clear: both;
    float: left; }

.agency-transfers .arrow-holder {
  font-size: 1.8em;
  color: #488aeb;
  position: relative;
  top: -9px;
  left: 23px; }

.stop-transfers-panel {
  background: rgba(240, 248, 255, 0.72);
  padding: 5px;
  padding-top: 1px; }
  .stop-transfers-panel ul, .stop-transfers-panel li {
    margin: 0;
    padding: 0; }
  .stop-transfers-panel .stop-transfer-panel-item {
    background: white;
    border: 1px solid #95989A;
    margin-bottom: 15px;
    display: table;
    -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.48);
    -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.48);
    box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.48); }
    .stop-transfers-panel .stop-transfer-panel-item .stop-transfer-panel-icon-column {
      background: #7BF5FF;
      width: 7.6%;
      display: table-cell;
      text-align: center;
      vertical-align: middle; }
      .stop-transfers-panel .stop-transfer-panel-item .stop-transfer-panel-icon-column img {
        width: 27px;
        margin: 10px; }
    .stop-transfers-panel .stop-transfer-panel-item .stop-transfer-panel-icon-column.is-editing {
      vertical-align: top; }
    .stop-transfers-panel .stop-transfer-panel-item .stop-transfer-panel-content-column {
      display: table-cell; }
    .stop-transfers-panel .stop-transfer-panel-item .transfer-edit-panel {
      position: relative; }
      .stop-transfers-panel .stop-transfer-panel-item .transfer-edit-panel .close-transfer-edit-panel {
        position: absolute;
        right: 1px;
        top: 1px;
        background: #eee;
        color: black; }
  .stop-transfers-panel .stop-transfer-panel-item:hover .stop-transfer-panel-content-column {
    background: #DEFFFC;
    cursor: pointer; }
  .stop-transfers-panel .stop-transfer-panel-item:hover .stop-transfer-panel-content-column.is-editing {
    background: white; }

.export-gtfs-table {
  width: 100%;
  font-size: .7em; }
  .export-gtfs-table td, .export-gtfs-table th {
    padding: 5px;
    border: 1px solid grey; }

.no-transition {
  -webkit-transition: none !important;
  -moz-transition: none !important;
  -o-transition: none !important;
  transition: none !important; }

body, html {
  font-size: .9em; }

.loader-bar-page-cover.error {
  background: #dd0000;
  color: white;
  padding: 10px;
  border-radius: 10px;
  min-width: 252px;
  -webkit-box-shadow: 10px 10px 5px 0px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 10px 10px 5px 0px rgba(0, 0, 0, 0.75);
  box-shadow: 10px 10px 5px 0px rgba(0, 0, 0, 0.75);
  -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.75); }
  .loader-bar-page-cover.error .loader-bar-bar {
    display: none; }

.loader-bar-page-cover {
  display: none; }
  .loader-bar-page-cover div {
    display: none; }

.loader-bar-page-cover.active {
  display: inherit;
  position: fixed;
  z-index: 99999;
  padding: 0;
  margin: 0;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(255, 255, 255, 0.41); }
  .loader-bar-page-cover.active div {
    display: inherit; }
  .loader-bar-page-cover.active .loader-bar-wrapper {
    top: 50%;
    left: 50%;
    position: absolute;
    margin-left: -100px;
    margin-top: -100px;
    width: 200px;
    height: 200px; }
    .loader-bar-page-cover.active .loader-bar-wrapper .loader-bar-label {
      text-align: center;
      width: 100%; }
    .loader-bar-page-cover.active .loader-bar-wrapper .loader-bar-bar {
      background: #ECE4F1;
      border: black 1px solid;
      width: 100%;
      height: 25px;
      position: relative; }
      .loader-bar-page-cover.active .loader-bar-wrapper .loader-bar-bar .loader-bar-bar-inner {
        background: #26ADE1;
        height: 100%;
        position: absolute;
        left: 0;
        border-right: 1px solid grey;
        width: 0%;
        -webkit-transition: width .5s;
        /* Safari */
        transition: width .5s; }

.main-sidebar.minimized {
  position: relative;
  overflow: visible;
  cursor: pointer; }
  .main-sidebar.minimized .minimized-dropdown-holder {
    position: absolute;
    top: -999999px;
    background: #162D91; }

.main-sidebar.minimized.expanded-menu .minimized-dropdown-holder {
  position: absolute;
  top: 64px;
  padding: 9px;
  width: 200px;
  -webkit-box-shadow: 2px 3px 3px 0px rgba(0, 0, 0, 0.2);
  -moz-box-shadow: 2px 3px 3px 0px rgba(0, 0, 0, 0.2);
  box-shadow: 2px 3px 3px 0px rgba(0, 0, 0, 0.2); }
  .main-sidebar.minimized.expanded-menu .minimized-dropdown-holder li {
    margin-bottom: 10px;
    font-size: 1.2em; }
  .main-sidebar.minimized.expanded-menu .minimized-dropdown-holder li:last-of-type {
    margin-bottom: 0; }
.main-sidebar.minimized.expanded-menu .minimized-dropdown-holder::before {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 10px 12px 10px;
  border-color: transparent transparent #162D91 transparent;
  position: absolute;
  top: -12px;
  left: 20px; }

html, body {
  width: 100%;
  height: 100%;
  padding: 0;
  margin: 0; }

.agency-stops .loading.edit .map-holder,
.agency-stops .loading.new .map-holder {
  height: 100vh;
  background: white;
  opacity: 1; }

.stop-child-panel::before {
  content: '';
  position: absolute;
  background: green;
  height: 100vh;
  width: 25px;
  left: -25px; }

.stop-delete-btn {
  float: left;
  /* bottom: 0; */
  /* position: absolute; */
  /* left: 50px; */
  margin-top: 36px;
  margin-left: 113px;
  text-decoration: underline;
  opacity: .6;
  color: red;
  cursor: pointer; }

.stop-panel-transfer-icon {
  float: right; }

.btn.btn-primary.btn-show-map {
  background: #0080ED;
  border-color: #0080ED; }

.map-holder .stops-map-ui-panel {
  display: none; }
.map-holder .close-map {
  display: none; }

.map-holder.active {
  margin-top: 54px; }
  .map-holder.active .close-map {
    position: absolute;
    right: 0px;
    top: -35px;
    display: inherit;
    background: white;
    opacity: .7; }
  .map-holder.active .stops-map-ui-panel {
    position: absolute;
    top: -38px;
    height: 50px;
    padding: 5px;
    border: 1px solid #939393;
    border-bottom: 0;
    display: inline-block;
    padding: 0px;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px; }
    .map-holder.active .stops-map-ui-panel .top-options-btn {
      display: inline-block;
      position: relative;
      color: black;
      margin: 6px 8px;
      margin-right: 0px;
      background: #BFEAF9;
      -webkit-box-shadow: 0px 3px 0px 0px rgba(0, 0, 0, 0.26);
      -moz-box-shadow: 0px 3px 0px 0px rgba(0, 0, 0, 0.26);
      box-shadow: 0px 3px 0px 0px rgba(0, 0, 0, 0.26); }
      .map-holder.active .stops-map-ui-panel .top-options-btn img {
        margin-right: 4px;
        width: 12px;
        height: auto;
        position: relative;
        top: -1px; }
    .map-holder.active .stops-map-ui-panel .top-options-btn.hide-transfers img {
      opacity: .6; }
    .map-holder.active .stops-map-ui-panel .top-options-btn.last {
      margin-right: 8px; }
    .map-holder.active .stops-map-ui-panel .no-transfers-message {
      display: inline-block;
      position: relative;
      margin: 5px 8px;
      margin-right: 0px;
      margin-right: 8px;
      opacity: .8; }
    .map-holder.active .stops-map-ui-panel .close-map {
      display: inherit;
      position: absolute;
      background: none;
      border: none;
      display: inline-block;
      position: relative; }
    .map-holder.active .stops-map-ui-panel .map-instructions {
      top: 50px; }

.add-stop-mini-panel {
  position: relative;
  border: 4px solid #0080ED;
  padding: 12px;
  padding-bottom: 16px;
  margin-top: 25px; }
  .add-stop-mini-panel h5 {
    margin-top: 0px;
    padding-top: 0;
    font-weight: bold;
    margin-bottom: 15px; }
  .add-stop-mini-panel .close-add-stop-mini-panel {
    position: absolute;
    top: 11px;
    right: 13px;
    color: grey;
    cursor: pointer;
    font-size: .8em; }
  .add-stop-mini-panel .close-add-stop-mini-panel:hover {
    text-decoration: underline; }
  .add-stop-mini-panel label {
    font-size: .9em; }
  .add-stop-mini-panel .btn.top-options-btn.btn-success.btn-save#editor-save.add-stop-location-button {
    display: inline-block;
    margin: 0;
    margin-left: 10px;
    font-size: 1.4em;
    width: auto;
    padding: 3px 13px 3px 13px;
    border: 2px solid #4bd78a;
    font-size: .95em; }
    .add-stop-mini-panel .btn.top-options-btn.btn-success.btn-save#editor-save.add-stop-location-button i {
      position: relative;
      left: 3px; }
  .add-stop-mini-panel .btn.top-options-btn.btn-success.btn-save#editor-save.add-stop-location-button:hover {
    background: #80e66c; }
  .add-stop-mini-panel .btn.top-options-btn.btn-success.btn-save#editor-save.add-stop-location-button:focus {
    border: 2px solid #0074ff; }

.add-new.stops-list {
  margin-top: 25px; }

.stop-action-menu {
  padding: 15px 15px 0px 0; }

.location-autocomplete-wrapper {
  position: relative; }
  .location-autocomplete-wrapper .results-dropdown {
    position: absolute;
    top: 20px;
    z-index: 500;
    background: white; }

.autocomplete-dropdown-menu.no-items {
  display: none; }

.autocomplete-wrapper {
  position: relative;
  display: inline-block;
  margin-left: 14px;
  padding-bottom: 10px; }
  .autocomplete-wrapper #location-autocomplete {
    height: 35px;
    border: 0;
    border: 1px solid #95989A;
    border-radius: 5px;
    min-width: 300px;
    padding-left: 10px;
    font-size: 1.2em; }
  .autocomplete-wrapper .autocomplete-helper {
    position: absolute;
    color: grey;
    font-size: .8em;
    font-weight: normal;
    top: 42px; }

.transfers-quicklink {
  font-size: .9em;
  opacity: .9;
  margin-bottom: 10px;
  display: block; }

.minimized .main-sidebar {
  z-index: 1; }

.stops-list.edit .map-instructions, .stops-list.new .map-instructions {
  display: none; }
.stops-list.edit .map-holder.active, .stops-list.new .map-holder.active {
  margin-top: 0; }
  .stops-list.edit .map-holder.active .stops-map-ui-panel, .stops-list.new .map-holder.active .stops-map-ui-panel {
    display: none; }
.stops-list.edit .map-holder .stops-map-ui-panel, .stops-list.new .map-holder .stops-map-ui-panel {
  display: none; }

.stops-list.edit .top-options-btn.btn-save#editor-save, .stops-list.new .top-options-btn.btn-save#editor-save {
  float: left;
  display: inline-block;
  width: auto;
  padding-left: 20px;
  padding-right: 20px; }
.stops-list.edit .stop-delete-btn, .stops-list.new .stop-delete-btn {
  margin-top: 13px; }

.stops-list .hover-legend {
  left: 15px;
  width: auto;
  display: inline-block;
  z-index: 99999;
  background: white;
  padding: 15px; }

.stops-list.index .hover-legend {
  position: absolute;
  top: 313px; }

.stops-list.edit .hover-legend, .stops-list.new .hover-legend {
  position: fixed;
  bottom: 15px; }

.agency-stops .loading .map-holder {
  height: 0; }
.agency-stops .loading .stop-action-menu {
  height: 0; }
.agency-stops #Stops-holder .tab-holder {
  margin-bottom: 20px; }
.agency-stops .sk-fading-circle {
  margin-top: 20px; }
.agency-stops .stop-noneditable-info {
  border-radius: 3px;
  border: 1px solid #ccc; }

.pattern-editor-name-label {
  width: 100%;
  /**/ }

.create-alignments .cssload-container {
  display: inline-block;
  position: relative;
  /* top: 2px; */
  top: 0;
  /* left: 3px; */
  height: 10px;
  margin-right: 10px;
  text-align: center;
  margin-right: 16px; }
.create-alignments .cssload-speeding-wheel {
  width: 6px;
  float: left;
  position: absolute;
  height: 9px;
  margin: 0;
  border: 1px solid white;
  border-radius: 50%;
  border-left-color: transparent;
  border-right-color: transparent; }

.top-options-btn:hover, .top-options-btn:active {
  background: #6cd8fd; }

.top-options-btn:hover, .top-options-btn:active,
.top-options-btn:focus {
  color: white; }

.pattern-name-input {
  min-width: 100%;
  margin-top: 10px;
  padding: 15px; }

.map-mode-toolbar .Select-control {
  min-width: 190px; }

.map-order-tooltip ul {
  margin: 0;
  padding: 0;
  list-style: none;
  margin-top: 5px; }
  .map-order-tooltip ul a {
    cursor: pointer; }

.Select-menu-outer {
  z-index: 9999999; }

.map-mode-options {
  left: 30px; }

.alignment-header-box {
  left: 30px;
  margin-top: -16px; }

.save-panel-holer {
  position: relative;
  right: 1.19%; }

.map-tools {
  position: absolute;
  top: 291px;
  left: 2.5%; }

.create-missing-alignments-menu-item .cssload-speeding-wheel,
.route-page .map-holder .status-holder .cssload-speeding-wheel {
  border: 1px solid grey;
  border-left-color: transparent;
  border-right-color: transparent;
  position: relative;
  top: 4px;
  right: 3px; }

.map-action-menu hr {
  margin: 0; }
.map-action-menu .map-action-menu-item {
  background: white;
  padding: 10px 15px;
  width: 100%;
  display: inline-block;
  cursor: pointer; }
.map-action-menu .map-action-menu-item.disabled {
  cursor: not-allowed; }
.map-action-menu .map-action-menu-item:hover {
  background: #F0FDFF; }
.map-action-menu .rc-dropdown-menu-item {
  padding: 0;
  margin: 0; }

.route-page .map-holder .status-holder {
  position: absolute;
  top: 426px;
  left: 397px;
  color: grey; }

.route-page .map-holder .map-tools {
  float: none;
  padding: 0;
  margin: 0;
  position: absolute;
  border: 1px solid rgba(128, 128, 128, 0.69);
  border-bottom: 0;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  padding-left: 7px;
  padding-right: 19px;
  padding-bottom: 10px;
  top: 291px; }
  .route-page .map-holder .map-tools .fa-bars {
    font-size: 1.4em;
    position: relative;
    top: 3px;
    left: 4px; }
  .route-page .map-holder .map-tools .map-options {
    float: none; }
  .route-page .map-holder .map-tools .map-mode-button .map-mode-line-1, .route-page .map-holder .map-tools .map-mode-button .map-mode-line-2 {
    display: none; }
  .route-page .map-holder .map-tools .map-mode-button.active {
    position: relative; }

.map-mode-toolbar {
  z-index: 500;
  background: none;
  position: relative;
  top: 15px;
  right: 280px;
  clear: right;
  float: right; }

.minor-header th {
  border-top: 1px solid rgba(204, 204, 204, 0.64);
  padding-top: 10px !important;
  border-bottom: 1px solid rgba(204, 204, 204, 0.65);
  padding-bottom: 10px !important; }

.rc-dropdown {
  z-index: 999999; }

.save-button-sticky-padder {
  display: block;
  height: 56px;
  float: left;
  width: 100%;
  position: relative;
  z-index: 50; }
  .save-button-sticky-padder .middle-padder {
    width: 100%;
    display: block;
    height: 15px; }

.save-panel-holder {
  margin-top: 0; }

.sticky .save-panel-holder {
  margin-top: 0;
  background: white;
  z-index: 500;
  padding: 0 10px 3px 10px;
  position: relative;
  right: -10px;
  -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.75);
  -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.75);
  box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.75);
  border-bottom-right-radius: 3px;
  border-bottom-left-radius: 3px; }

.top-options-btn#editor-save {
  width: inherit; }

#editor-save, .pattern-editor-undo, .pattern-editor-redo {
  float: right;
  margin-top: 10px; }

.stop_pattern_row .insert-stop-hover-button {
  display: none;
  width: 22px;
  height: auto; }

.stop_pattern_row:hover .stop-order-list-holder {
  position: relative; }
.stop_pattern_row:hover .insert-stop-hover-button {
  display: inherit;
  position: absolute;
  top: -10px;
  opacity: .7; }
.stop_pattern_row:hover .insert-stop-hover-button:hover {
  cursor: pointer;
  opacity: 1; }

.inserting-stop-dummie-row {
  background: white;
  border-bottom: 1px solid #eee;
  padding: 0 !important;
  margin: 0 !important; }

.insert-stop-list-panel {
  border: 5px solid #21BCEA;
  border-right: 0;
  position: relative;
  left: -1px;
  padding: 0;
  background: white; }
  .insert-stop-list-panel span.right-border {
    height: 100%;
    width: 5px;
    background: #21BCEA;
    position: absolute;
    right: -1px;
    top: -5px; }
  .insert-stop-list-panel span.bottom-right-corner {
    height: 10px;
    width: 5px;
    background: #21BCEA;
    position: absolute;
    right: -1px;
    bottom: -5px; }
  .insert-stop-list-panel h3 {
    margin-top: 0;
    padding-top: 0;
    font-size: 1.4em; }
  .insert-stop-list-panel table {
    width: 100%;
    margin-left: -5px; }

.insert-stop-list-panel-row .insert-stop-left-cell {
  font-size: 1.2em;
  font-weight: bold;
  min-width: 30px;
  vertical-align: top;
  position: relative; }
  .insert-stop-list-panel-row .insert-stop-left-cell .break-out-panel-label {
    position: absolute;
    top: 18px;
    left: 20px;
    z-index: 9999;
    width: 100px; }
.insert-stop-list-panel-row .stop-select-cell {
  padding: 8px;
  padding-top: 22px;
  padding-bottom: 19px; }
.insert-stop-list-panel-row .icon-holder {
  padding: 8px; }
  .insert-stop-list-panel-row .icon-holder img {
    width: 10px; }
.insert-stop-list-panel-row .order-holder {
  padding: 8px; }
.insert-stop-list-panel-row td {
  background: white !important;
  position: relative;
  border-top: 5px solid #21BCEA;
  border-bottom: 5px solid #21BCEA; }
  .insert-stop-list-panel-row td .left-fake-border {
    height: 100%;
    width: 5px;
    background: #21BCEA;
    position: absolute;
    left: -1px;
    top: 0; }
  .insert-stop-list-panel-row td .left-fake-border::before {
    content: '';
    width: 0;
    height: 0;
    border-width: 12.5px 0 12.5px 12.5px;
    border-color: transparent transparent transparent #21BCEA;
    border-style: solid;
    position: absolute;
    left: 5px;
    top: 50%;
    margin-top: -12.5px; }
  .insert-stop-list-panel-row td .left-fake-border::after {
    content: '';
    width: 5px;
    height: 10px;
    position: absolute;
    background: #21BCEA;
    bottom: -5px;
    left: 0px; }
  .insert-stop-list-panel-row td .left-top-right-border {
    width: 5px;
    height: 10px;
    position: absolute;
    background: #21BCEA;
    top: -5px;
    left: -1px; }
  .insert-stop-list-panel-row td .right-fake-border {
    height: 100%;
    width: 5px;
    background: #21BCEA;
    position: absolute;
    right: -2px;
    top: 0; }
  .insert-stop-list-panel-row td .right-fake-border::before {
    content: '';
    width: 0;
    height: 0;
    border-width: 12.5px 12.5px 12.5px 0;
    border-color: transparent #21BCEA transparent transparent;
    border-style: solid;
    position: absolute;
    right: 3px;
    top: 50%;
    margin-top: -12.5px; }
  .insert-stop-list-panel-row td .right-fake-border::after {
    content: '';
    width: 5px;
    height: 10px;
    position: absolute;
    background: #21BCEA;
    bottom: -5px;
    right: 0px; }
  .insert-stop-list-panel-row td .right-top-right-border {
    width: 5px;
    height: 10px;
    position: absolute;
    background: #21BCEA;
    top: -5px;
    right: -2px; }
.insert-stop-list-panel-row place-selector-wrapper {
  width: 100%;
  display: table; }
.insert-stop-list-panel-row .place-selector {
  width: 100%;
  display: table; }
  .insert-stop-list-panel-row .place-selector .place-selector-item {
    border-top: 1px solid #B7EDFF;
    border-bottom: 1px solid #B7EDFF;
    border-right: 1px solid #B7EDFF;
    background: #F4FCFF;
    padding: 5px;
    font-weight: bold;
    display: table-cell;
    text-align: center; }
    .insert-stop-list-panel-row .place-selector .place-selector-item input {
      height: 25px;
      width: 35px;
      border-radius: 3px;
      border: 0;
      padding-left: 6px; }
  .insert-stop-list-panel-row .place-selector .place-selector-item:hover {
    cursor: pointer;
    background: #E2F7FF; }
  .insert-stop-list-panel-row .place-selector .place-selector-item.first {
    border-left: 1px solid #B7EDFF;
    border-top-left-radius: 5px;
    border-bottom-left-radius: 5px; }
  .insert-stop-list-panel-row .place-selector .place-selector-item.last {
    border-top-right-radius: 5px;
    border-bottom-right-radius: 5px; }
  .insert-stop-list-panel-row .place-selector .place-selector-item.selected {
    background: #B7EDFF; }
  .insert-stop-list-panel-row .place-selector .place-selector-item-1 {
    width: 25%; }
  .insert-stop-list-panel-row .place-selector .place-selector-item-2 {
    width: 25%; }
  .insert-stop-list-panel-row .place-selector .place-selector-item-3 {
    width: 50%; }
.insert-stop-list-panel-row .insert-stop-save-cancel-holder-cell {
  position: relative;
  z-index: 99999; }
  .insert-stop-list-panel-row .insert-stop-save-cancel-holder-cell .insert-stop-save-cancel-breakout {
    position: absolute;
    height: 31px;
    bottom: 25px;
    width: 400px;
    left: 20px; }
    .insert-stop-list-panel-row .insert-stop-save-cancel-holder-cell .insert-stop-save-cancel-breakout .btn.top-options-btn.btn-success.btn-save#editor-save.insert-stop-button {
      float: left;
      margin: 0;
      font-size: 1.4em;
      width: auto;
      padding: 3px 13px 3px 13px;
      border: 2px solid #4bd78a; }
    .insert-stop-list-panel-row .insert-stop-save-cancel-holder-cell .insert-stop-save-cancel-breakout .btn.top-options-btn.btn-success.btn-save#editor-save.insert-stop-button:hover {
      background: #80e66c; }
    .insert-stop-list-panel-row .insert-stop-save-cancel-holder-cell .insert-stop-save-cancel-breakout .btn.top-options-btn.btn-success.btn-save#editor-save.insert-stop-button:focus {
      border: 2px solid #0074ff; }
    .insert-stop-list-panel-row .insert-stop-save-cancel-holder-cell .insert-stop-save-cancel-breakout .btn.top-options-btn.btn-success.btn-save#editor-save.insert-stop-button.first {
      border-top-right-radius: 0;
      border-bottom-right-radius: 0;
      position: relative;
      border-right: 0; }
    .insert-stop-list-panel-row .insert-stop-save-cancel-holder-cell .insert-stop-save-cancel-breakout .btn.top-options-btn.btn-success.btn-save#editor-save.insert-stop-button.first::after {
      content: '';
      width: 2px;
      background: white;
      height: 100%;
      position: absolute;
      right: 0;
      top: 0; }
    .insert-stop-list-panel-row .insert-stop-save-cancel-holder-cell .insert-stop-save-cancel-breakout .btn.top-options-btn.btn-success.btn-save#editor-save.insert-stop-button.last {
      border-top-left-radius: 0;
      border-bottom-left-radius: 0;
      padding-left: 8px;
      border-left: 0; }
      .insert-stop-list-panel-row .insert-stop-save-cancel-holder-cell .insert-stop-save-cancel-breakout .btn.top-options-btn.btn-success.btn-save#editor-save.insert-stop-button.last img {
        width: 16px;
        display: inline-block;
        margin-right: 3px;
        position: relative;
        top: -1px; }
    .insert-stop-list-panel-row .insert-stop-save-cancel-holder-cell .insert-stop-save-cancel-breakout .insert-stop-panel-cancel {
      margin-left: 20px;
      font-size: 1.2em;
      position: relative;
      top: 10px;
      opacity: .8;
      cursor: pointer; }

.insert-stop-list-panel::after {
  content: '';
  width: 0;
  height: 0;
  border-width: 12.5px 12.5px 12.5px 0px;
  border-color: transparent #21BCEA transparent transparent;
  border-style: solid;
  position: absolute;
  right: 4px;
  top: 50%;
  margin-top: -12.5px; }

.stop-pattern-major-header {
  position: relative;
  padding-bottom: 59px; }

.add-stop-top-of-list {
  position: absolute;
  left: 0;
  bottom: 0;
  text-align: left;
  font-size: .7em;
  font-weight: normal;
  cursor: pointer;
  padding: 10px !important; }

.stop_pattern_row.is-modified td:first-of-type {
  position: relative; }
.stop_pattern_row.is-modified td:first-of-type::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 15px 15px 0 0;
  border-color: orange transparent transparent transparent; }

.pattern-edit-panel {
  margin-top: 15px;
  padding: 12px;
  position: relative; }
  .pattern-edit-panel .Select-control {
    max-width: 313px; }
  .pattern-edit-panel .Select {
    display: inline-block; }
  .pattern-edit-panel hr {
    margin-bottom: 7px; }
  .pattern-edit-panel .pattern-options-row {
    position: relative;
    width: 100%;
    border-top: 1px solid #eee;
    border-bottom: 1px solid #eee;
    padding-top: 12px;
    padding-bottom: 3px;
    margin-top: 20px; }
    .pattern-edit-panel .pattern-options-row label {
      margin-right: 15px;
      margin-left: 15px;
      font-weight: strong;
      position: relative;
      top: -14px; }
    .pattern-edit-panel .pattern-options-row label.first {
      margin-left: 0; }
  .pattern-edit-panel .pattern-title-holder {
    font-size: 1.6em;
    font-weight: 400; }
    .pattern-edit-panel .pattern-title-holder i {
      font-size: .7em;
      position: relative;
      top: -2px;
      left: 2px;
      opacity: .8; }
    .pattern-edit-panel .pattern-title-holder .pattern-title {
      display: inline-block;
      cursor: pointer; }
    .pattern-edit-panel .pattern-title-holder .pattern-title-input {
      width: 100%;
      clear: both;
      display: block; }

.pattern-edit-panel.saving {
  opacity: .5;
  pointer-events: none; }

.pattern-edit-panel.has-saved::after {
  content: 'Pattern details saved';
  position: absolute;
  right: 15px;
  top: -18px;
  line-height: 16px;
  color: #73dd75;
  background: white;
  border-right: 4px solid white;
  border-left: 4px solid white; }

.pattern-edit-panel.saving::after {
  content: 'Saving pattern details...';
  position: absolute;
  right: 15px;
  top: -18px;
  color: grey; }

.pattern-edit-panel.saving::before {
  display: none; }

.pattern-edit-panel.saving {
  border: 0; }

.route-page.map #map, .route-page.order #map, .route-page.alignments #map {
  top: 86px; }

.agency-route .map-style-controls {
  position: absolute;
  top: 346px;
  display: inherit;
  right: 84px;
  z-index: 999;
  bottom: inherit; }

.stop-id-td {
  position: relative; }
  .stop-id-td .stop-edit-link {
    display: block;
    position: absolute;
    bottom: 1px;
    width: 100%;
    font-size: .8em;
    left: 0;
    text-align: center;
    opacity: 0; }

.stop_pattern_row:hover .stop-id-td {
  position: relative; }
  .stop_pattern_row:hover .stop-id-td .stop-edit-link {
    display: block;
    opacity: 1; }

.agency-route .duplicate-pattern-group {
  border-bottom: 1px solid #ccc;
  margin-bottom: 8px;
  padding-bottom: 8px; }
.agency-route .duplicate-pattern-group:last-of-type {
  border-bottom: 0; }
.agency-route .duplicate-pattern-groups-list {
  list-style: none;
  padding: 0;
  margin: 0;
  margin-top: 15px; }
  .agency-route .duplicate-pattern-groups-list ul {
    list-style: none;
    margin: 0;
    padding: 0; }
.agency-route .box > .warning-bubble-container {
  margin: 15px 15px; }
.agency-route .stop-pattern-major-header .warning-bubble-container {
  font-weight: normal;
  font-size: 15px;
  margin-bottom: 22px;
  margin-top: 15px;
  margin-right: 2px; }
.agency-route .duplicate-timed-pattern-warning-holder {
  font-weight: normal;
  text-align: left;
  font-size: 16px; }
  .agency-route .duplicate-timed-pattern-warning-holder .warning-bubble-container {
    margin-top: 18px;
    margin-bottom: 11px; }
.agency-route .no-timed-patterns .header-arrive,
.agency-route .no-timed-patterns .header-depart,
.agency-route .no-timed-patterns .header-drop-off,
.agency-route .no-timed-patterns .header-pick-up,
.agency-route .no-timed-patterns .header-headsign,
.agency-route .no-timed-patterns .header-timepoint,
.agency-route .no-timed-patterns .header-continuous-stops,
.agency-route .no-timed-patterns .header-service-area-radius {
  color: white;
  opacity: 1;
  border-top: 1px solid rgba(204, 204, 204, 0.64) !important;
  border-bottom: 1px solid rgba(204, 204, 204, 0.65) !important; }

.has-timed-point::after {
  content: '';
  position: absolute;
  background: yellow;
  top: 18px;
  left: 9px;
  width: 7px;
  height: 7px;
  border-radius: 4px; }

.map-link img {
  width: 10px; }

/* .compare-patterns-link {
  position: absolute;
  right: 20px;
  top: 20px; } */

.pattern-compare-table {
  margin-top: 25px;
  position: relative;
  z-index: 0;
  font-size: .8em;
  font-weight: bold; }
  .pattern-compare-table th span {
    padding: 1px;
    display: inline-block; }
  .pattern-compare-table th {
    border-top: 1px solid grey;
    border-bottom: 1px solid grey;
    border-right: 1px solid grey; }
  .pattern-compare-table th .is-sticky .sticky-header {
    border-left: 0; }
  .pattern-compare-table th:first-of-type {
    border-left: 1px solid grey;
    border-top-left-radius: 3px; }
  .pattern-compare-table th:first-of-type .is-sticky .sticky-header {
    border-left: 0;
    border-bottom: 1px solid grey; }
  .pattern-compare-table th:last-of-type {
    border-right: 1px solid grey;
    border-top-right-radius: 3px; }
  .pattern-compare-table td {
    border-left: 1px solid grey;
    padding: 5px;
    background: #5FE688;
    position: relative;
    z-index: 0; }
  .pattern-compare-table td:last-of-type {
    border-right: 1px solid grey; }
  .pattern-compare-table tr td:first-of-type {
    border-bottom: 1px solid grey;
    background: white; }
  .pattern-compare-table td.added span {
    width: 10px;
    display: inline-block; }
  .pattern-compare-table td.added {
    background: #5FE688; }
  .pattern-compare-table td.removed {
    background: orange; }
  .pattern-compare-table td.has-stop::before {
    content: '';
    width: 16px;
    height: 16px;
    background: white;
    border: 3px solid black;
    position: absolute;
    left: 50%;
    border-radius: 16px;
    margin-left: -8px;
    top: 50%;
    margin-top: -8px;
    z-index: 600; }
  .pattern-compare-table td.started::after {
    content: '';
    width: 6px;
    height: 100%;
    background: white;
    border: 1px solid black;
    position: absolute;
    left: 50%;
    top: 0;
    border-bottom: 0;
    border-top: 0;
    margin-left: -3px;
    z-index: 500; }
  .pattern-compare-table td.is-end::after {
    height: 50%; }
  .pattern-compare-table td.is-start::after {
    height: 50%;
    top: 50%; }
  .pattern-compare-table td.ended::after {
    display: none; }
  .pattern-compare-table .sticky-header {
    display: none;
    background: white;
    height: 90px;
    width: 100%;
    border-left: 1px solid grey; }
  .pattern-compare-table .is-sticky {
    z-index: 9999; }
  .pattern-compare-table .is-sticky .sticky-header {
    display: block;
    position: relative;
    z-index: 999; }
  .pattern-compare-table tr:hover td:first-of-type {
    background: #B8F7FC; }
  .pattern-compare-table tr:hover td.removed {
    background: #ffc966; }
  .pattern-compare-table tr:hover td {
    background: #b7f4ca; }
  .pattern-compare-table th.is-hovered-col, .pattern-compare-table th.is-hovered-col .sticky-header {
    background: #B8F7FC; }

.pattern-comparer-legend-items-holder {
  position: relative;
  top: 15px; }

.pattern-comparer-legend-item {
  display: inline-block;
  padding-right: 8px;
  font-size: .8em; }

.pattern-comparer-legend-item-label {
  font-weight: bold;
  padding-right: 30px; }

.pattern-comparer-legend-holder {
  position: relative; }

.schedules-exception-calendar-icon {
  padding: 2px;
  border-radius: 2px;
  display: inline;
  width: auto;
  height: 14px;
  position: relative;
  margin-right: 2px; }
  .schedules-exception-calendar-icon img {
    width: 14px;
    height: auto;
    position: relative;
    top: -1px; }

.schedule-calendar .no-trip-add-panel-holder .trip-panel-holder {
  top: -41px; }
.schedule-calendar .no-trip-add-panel-holder .trip-panel-holder .panel::before {
  content: '';
  position: absolute;
  left: 0;
  top: -20px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 20px 0 0 20px;
  border-color: transparent transparent transparent #03C5FF; }
.schedule-calendar .fa.fa-bars {
  opacity: .9;
  font-size: 1em;
  position: relative;
  top: 2px;
  left: 10px;
  color: white;
  text-shadow: none; }

.filter-box {
  padding-right: 0;
  margin-bottom: 15px; }

.start-times-menu-option {
  padding-bottom: 7px !important;
  margin-bottom: 5px !important;
  border-bottom: 1px solid #eee; }

.schedule-calendar .schedule-pattern-group .schedule-pattern-title {
  padding: 0;
  background: blue;
  z-index: 999;
  position: relative;
  border-left: 15px solid #cccccc; }
  .schedule-calendar .schedule-pattern-group .schedule-pattern-title span {
    background: #51A6E5;
    position: relative;
    z-index: 999;
    width: 100%;
    padding-left: 10px;
    padding-top: 3px;
    left: 0; }

.time-axis.has-times .move-time-span-button {
  position: absolute;
  top: 2px;
  width: 15px;
  height: 15px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  cursor: pointer; }
.time-axis.has-times .move-time-span-button:hover {
  background: #94c9f1; }
.time-axis.has-times .move-time-span-button.move-time-span-left {
  left: 2px; }
.time-axis.has-times .move-time-span-button.move-time-span-right {
  right: 2px; }
.time-axis.has-times .move-time-span-button.move-time-span-left::after {
  position: absolute;
  top: 2px;
  left: 2px;
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 8px 4.5px 0;
  border-color: transparent #ffffff transparent transparent; }
.time-axis.has-times .move-time-span-button.move-time-span-right::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4.5px 0 4.5px 8px;
  border-color: transparent transparent transparent #ffffff; }

.trip-short-name-row {
  margin-top: 20px; }
  .trip-short-name-row input {
    margin-left: 12px; }

.agency-calendars .row-fluid .add-new {
  float: left;
  margin-right: 20px; }
.agency-calendars .name_input .form-group {
  margin-bottom: 0px; }
.agency-calendars .__react_component_tooltip.show.type-info {
  width: 244px; }
.agency-calendars .exception-calendar-holder .box-with-no-close h2 {
  background: #ffd400; }
.agency-calendars .calendar-route-usage .route-usage-icon {
  display: inline-block;
  margin-right: 3px;
  padding: 2px;
  margin-bottom: 3px;
  border-radius: 2px;
  cursor: pointer; }
  .agency-calendars .calendar-route-usage .route-usage-icon a {
    cursor: pointer; }
.agency-calendars .calendar-summary-row {
  position: relative; }
  .agency-calendars .calendar-summary-row .service-periods li {
    margin-bottom: 10px; }
  .agency-calendars .calendar-summary-row .list-of-service-periods::before {
    content: '';
    height: 100%;
    width: 1px;
    right: 0; }
  .agency-calendars .calendar-summary-row .list-of-service-periods {
    padding-right: 15px; }
    .agency-calendars .calendar-summary-row .list-of-service-periods .add-new {
      float: none;
      margin-top: 10px; }
  .agency-calendars .calendar-summary-row .list-of-service-periods input {
    border: 2px solid #ccc;
    margin: 3px; }
.agency-calendars .calendar-usage {
  border-left: 1px solid #ccc;
  position: relative;
  left: -1px;
  padding: 0 15px; }
  .agency-calendars .calendar-usage legend {
    margin-bottom: 12px; }
  .agency-calendars .calendar-usage ul {
    padding-left: 24px; }
.agency-calendars .new-service-period-holder {
  width: 100%;
  background: white;
  border: 1px solid #95989A;
  margin-bottom: 15px;
  display: table;
  -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.48);
  -moz-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.48);
  box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.48);
  padding: 5px 15px 5px 15px;
  margin-top: 15px; }
  .agency-calendars .new-service-period-holder .top-options-btn.btn-success.btn-save#editor-save {
    float: right;
    display: inline-block;
    width: auto;
    padding-left: 20px;
    padding-right: 20px; }
.agency-calendars .cancel-add-service-period {
  opacity: .6;
  position: absolute;
  bottom: 30px;
  left: 25px;
  cursor: pointer; }
.agency-calendars .cancel-add-service-period:hover {
  opacity: .9; }
.agency-calendars .calendar-menu {
  float: right;
  font-size: 1em;
  position: relative;
  top: 0px; }
.agency-calendars .focused.box-with-no-close h2 {
  background: #FFFB6F; }
.agency-calendars .box-with-no-close {
  position: relative; }
  .agency-calendars .box-with-no-close .delete-calendar-warning-panel {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: table-row;
    height: 100%;
    z-index: 999; }
    .agency-calendars .box-with-no-close .delete-calendar-warning-panel .delete-calendar-warning-inner {
      font-size: 1.3em;
      background: white;
      text-align: center;
      margin: 5px;
      min-height: 100%;
      padding: 15px;
      border: 2px solid #9D0000;
      -webkit-box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.19);
      -moz-box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.19);
      box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.19); }
    .agency-calendars .box-with-no-close .delete-calendar-warning-panel .btn {
      padding: 10px 15px;
      background: white;
      border: 1px solid #95989A;
      color: black;
      -webkit-box-shadow: 0px 2px 0px 0px rgba(0, 0, 0, 0.19);
      -moz-box-shadow: 0px 2px 0px 0px rgba(0, 0, 0, 0.19);
      box-shadow: 0px 2px 0px 0px rgba(0, 0, 0, 0.19);
      margin-right: 15px;
      color: #009F5B; }
    .agency-calendars .box-with-no-close .delete-calendar-warning-panel .btn.btn-outline-danger {
      color: #AA0000; }
      .agency-calendars .box-with-no-close .delete-calendar-warning-panel .btn.btn-outline-danger i {
        color: #C30000; }
.agency-calendars .calendar-menu, .agency-calendars .rc-dropdown-menu-item {
  cursor: pointer; }

.agency-dashboard .dashboard-message.box-holder .box {
  border: 1px solid #ffdea6; }
  .agency-dashboard .dashboard-message.box-holder .box h2 {
    background: #ffdea6;
    font-weight: 400;
    text-transform: none; }
.agency-dashboard .export-confirmation {
  border: 1px solid #ccc;
  padding: 10px;
  position: relative; }
  .agency-dashboard .export-confirmation .cssload-speeding-wheel {
    float: right;
    position: relative;
    top: 4px;
    left: 7px; }
  .agency-dashboard .export-confirmation .cancel {
    position: absolute;
    bottom: 15px;
    right: 15px;
    color: grey;
    cursor: pointer; }
.agency-dashboard .export-request-success {
  border: 1px solid #5FE688; }
.agency-dashboard .btn.btn-success.btn-save.processing {
  pointer-events: none;
  opacity: .8; }
.agency-dashboard .btn.btn-success.btn-save img {
  position: relative;
  left: 6px;
  top: -1px; }

.autocomplete-dropdown-item {
  background: white;
  padding: 6px; }

.autocomplete-dropdown-item.highlighted {
  background: #B5EBFF;
  padding: 6px; }

.autocomplete-dropdown-menu {
  z-index: 500; }

.not-included-in-export-agencies {
  opacity: .7; }
  .not-included-in-export-agencies ul {
    opacity: .5; }
  .not-included-in-export-agencies ul:hover {
    opacity: 1; }

.feed-agency-item {
  padding: 5px; }

.feed-agency-item.included-agency {
  border: 1px solid green; }

.feed-agency-item.excluded-agency {
  border: 1px solid red; }

.stop-import-preview-table tr:hover td {
  background: lightBlue; }
.stop-import-preview-table td {
  padding: 10px;
  border: 1px solid grey; }

.agency-areas h1 {
  margin: 15px;
  margin-top: 50px; }
.agency-areas a {
  cursor: pointer; }
.agency-areas .no-areas-message {
  padding: 15px; }
.agency-areas .areas-map-container {
  position: absolute;
  top: -99999999px; }
.agency-areas .areas-map-container.active {
  position: relative;
  top: 0;
  margin-top: 0; }
.agency-areas .areas-map-tools-container {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 9999; }
.agency-areas .area-edit-panel {
  position: inherit;
  top: 0;
  left: 0;
  z-index: 0;
  border-radius: 0;
  padding: 0;
  background: none; }
.agency-areas .area-edit-panel-top-holder {
  padding: 10px;
  padding-bottom: 0; }
.agency-areas .area-id-holder {
  background: #F0F0F0;
  border-radius: 5px;
  padding: 7px;
  font-size: .85em;
  margin: 10px; }
.agency-areas .area-edit-panel-form-holder {
  padding-left: 10px;
  padding-right: 10px; }
.agency-areas #editor-save {
  float: left;
  padding: 6px 10px;
  margin-left: 10px; }
.agency-areas .area-delete-btn {
  color: grey;
  float: right;
  margin-right: 10px;
  margin-top: 10px;
  text-decoration: none;
  opacity: .6;
  cursor: pointer; }
  .agency-areas .area-delete-btn i {
    margin-right: 5px; }
.agency-areas .area-delete-btn:hover {
  color: red;
  text-decoration: underline; }
.agency-areas hr.after-area-form {
  margin-bottom: 0; }
.agency-areas .area-edit-panel-back-link {
  margin-bottom: 21px;
  display: block; }
.agency-areas .content-header {
  display: none; }
.agency-areas .above-the-map-area {
  padding: 15px; }
.agency-areas .content {
  margin: 0;
  padding: 0; }
.agency-areas .page-content {
  margin: 0;
  padding: 0; }
.agency-areas #map {
  height: 600px; }
.agency-areas .areas-ui-row {
  margin: 0;
  padding: 0; }
.agency-areas .areas-ui-holder {
  border-top: 1px solid #eee;
  margin: 0;
  padding: 0; }
  .agency-areas .areas-ui-holder h3 {
    margin-top: 0;
    padding-left: 10px;
    padding-top: 18px; }
    .agency-areas .areas-ui-holder h3 span {
      font-size: .5em;
      opacity: .7;
      font-weight: normal;
      position: relative;
      top: -2px;
      left: 6px; }
.agency-areas .sortable-table-count-holder {
  font-size: .7em;
  opacity: .7;
  margin-left: 7px;
  margin-bottom: 3px;
  margin-top: 25px; }
.agency-areas .areas-col-map-holder {
  position: relative;
  margin: 0;
  padding: 0; }
.agency-areas table.sortable-table {
  min-width: 0;
  width: 100%;
  -webkit-box-shadow: 0px 3px 4px 0px transparent;
  -moz-box-shadow: 0px 3px 4px 0px transparent;
  box-shadow: 0px 3px 4px 0px transparent; }
  .agency-areas table.sortable-table th.table-filter.minimized {
    background: none !important;
    border-top-right-radius: 2px;
    border-top-left-radius: 2px;
    border-color: #95989A;
    color: #95989A;
    font-weight: normal; }
  .agency-areas table.sortable-table th {
    background: none; }
  .agency-areas table.sortable-table th.active .header-container {
    background: #ececec; }
  .agency-areas table.sortable-table th:first-of-type.active .header-container {
    background: #ececec; }
  .agency-areas table.sortable-table table.sortable-table tbody {
    border-left: 0;
    border-right: 0; }
  .agency-areas table.sortable-table th.table-filter.active {
    background: none;
    border-right: 0;
    border-left: 0; }
  .agency-areas table.sortable-table .close-filter .fa.fa-times {
    color: grey; }
  .agency-areas table.sortable-table .close-filter-text {
    display: none; }
  .agency-areas table.sortable-table td .fa-angle-right {
    font-size: 1.5em;
    font-weight: bold; }
  .agency-areas table.sortable-table .area-row-color {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 10px;
    margin-right: 4px; }
.agency-areas .area-map-tool-buttons-container {
  position: absolute;
  margin: 0;
  padding: 0;
  z-index: 9999;
  list-style: none;
  left: 10px;
  top: 10px; }
  .agency-areas .area-map-tool-buttons-container li {
    margin: 0;
    padding: 0;
    list-style: none; }
  .agency-areas .area-map-tool-buttons-container li.shape-tools-button {
    border: 2px solid #D0D0D0;
    background: white;
    padding: 3px 5px;
    border-radius: 4px;
    font-weight: medium;
    cursor: pointer; }
    .agency-areas .area-map-tool-buttons-container li.shape-tools-button i {
      margin: 0 3px;
      color: grey; }
.agency-areas .shape-tools-panel {
  position: absolute;
  left: 10px;
  top: 50px;
  background: white;
  z-index: 9999;
  -webkit-box-shadow: 0px 3px 3px 0px rgba(0, 0, 0, 0.2);
  -moz-box-shadow: 0px 3px 3px 0px rgba(0, 0, 0, 0.2);
  box-shadow: 0px 3px 3px 0px rgba(0, 0, 0, 0.2);
  border-radius: 8px; }
  .agency-areas .shape-tools-panel .panel-header {
    background: #EBEBEB;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    padding: 8px 15px;
    font-weight: bold;
    position: relative; }
    .agency-areas .shape-tools-panel .panel-header i {
      position: absolute;
      right: 10px;
      opacity: .6;
      top: 8px;
      cursor: pointer; }
    .agency-areas .shape-tools-panel .panel-header i:hover {
      opacity: 1; }
  .agency-areas .shape-tools-panel .area-shape-tool-label {
    font-size: .8em;
    font-weight: normal; }
  .agency-areas .shape-tools-panel .autocomplete-wrapper {
    margin: 0; }
  .agency-areas .shape-tools-panel .inner-panel {
    padding: 15px; }
  .agency-areas .shape-tools-panel .simplification-factor-input {
    height: 35px;
    border: 0;
    border: 1px solid #95989A;
    border-radius: 5px;
    width: 43%;
    padding-left: 10px;
    font-size: 1.2em; }
  .agency-areas .shape-tools-panel .area-admin-boundary-submit {
    background: #26ADE1;
    border: 0;
    border-radius: 10px;
    color: white;
    font-weight: medium;
    padding: 5px 10px;
    margin-top: 10px;
    -webkit-box-shadow: 0px 2px 0px 0px rgba(0, 0, 0, 0.26);
    -moz-box-shadow: 0px 2px 0px 0px rgba(0, 0, 0, 0.26);
    box-shadow: 0px 2px 0px 0px rgba(0, 0, 0, 0.26);
    position: relative;
    top: 0; }
  .agency-areas .shape-tools-panel .area-admin-boundary-submit:active {
    -webkit-box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.26);
    -moz-box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.26);
    box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.26);
    top: 2px; }
.agency-areas .create-new-area-link.greyed-out {
  opacity: .4;
  cursor: default;
  color: grey; }
  .agency-areas .create-new-area-link.greyed-out .plus-icon {
    background: grey; }
.agency-areas .create-new-area-link.greyed-out:hover {
  text-decoration: none; }
.agency-areas .area-index-holder {
  height: 600px;
  overflow: scroll; }
.agency-areas .area-instructions-blurb {
  padding-left: 10px;
  padding-right: 10px; }
.agency-areas .area-color-input {
  margin-top: 10px; }

html, body.agency-areas {
  width: 100%;
  height: 100%;
  margin: 0px;
  padding: 0px; }

.picker-preview-icon {
  display: inline;
  cursor: pointer;
  position: relative;
  margin-right: 10px; }

.no-color-text {
  display: inline;
  color: grey;
  cursor: pointer;
  position: relative;
  top: 1px;
  font-size: .95em; }

.chrome-picker {
  position: absolute;
  z-index: 999;
  top: 27px;
  left: -13px;
  border: 4px solid white; }

.showing-picker .picker-preview-null .chrome-picker {
  top: 30px;
  left: -12px; }

.chrome-picker:after {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 9px 9px 9px;
  border-color: transparent transparent white transparent;
  position: absolute;
  z-index: 1000;
  top: -12px;
  left: 6px; }

.chrome-picker:before {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 9px 9px 9px;
  border-color: transparent transparent #ccc transparent;
  position: absolute;
  z-index: 900;
  top: -13px;
  left: 6px; }

.picker-preview-icon {
  position: abolute; }

.color-picker-text-preview {
  display: inline;
  opacity: .7; }

.color-picker-holder .picker-preview {
  position: relative;
  top: 3px;
  left: 0px; }

.color-picker-holder .color-picker-close-icon {
  cursor: pointer;
  position: relative;
  top: -1px;
  margin-left: 14px; }

.warning-bubble-container {
  border: 1px solid red;
  padding: 14px 14px;
  border-radius: 10px;
  margin-top: 10px;
  background: white;
  font-size: 1em; }
  .warning-bubble-container .warning-bubble-col {
    float: left; }
  .warning-bubble-container .icon-col.warning-bubble-col {
    width: 40px; }
  .warning-bubble-container .message-col.warning-bubble-col {
    max-width: 450px; }


.logged-out-content {
    margin: 30px;
}
