
@import "https://cdn.jsdelivr.net/npm/bulma@0.9.4/css/bulma.min.css";

:root {
  --main-bg-color: #2c6e49;
  --secondary-bg-color: #4c956c;
}

html,
body {
  overflow-y: hidden;
}

.has-background-error
{
  background-color: #fca2a2;
}

.has-background-confirmed
{
  background-color: #b5ebd2;
}

.search-bar
{
  width: 500px;
}

.rate-arrow {
  font-size: 1.2rem;
  margin: auto 0px;
  vertical-align: middle;
}

#rate-display {
  width: fit-content;
  border-radius: 5px;
  background-color: #ededed;
  font-size: small;
}

#inner-rate-display {
  width: fit-content;
  transition: 0.2s;
  display:flex;
  gap: 1.25rem;
  align-items: center;
}

.modal-rate-title {
  text-decoration: underline;
}

#modal-rate-display {
  margin: .3rem auto;
  width: 100%;
  border-radius: 5px;
  background-color: #ededed;
  font-size: medium;
  transition: 0.2s;
  gap: 1.25rem;
  align-items: center;
}

#modal-rate-current {
  font-weight: bold;
  text-align: center;
}

/* #modal-trip-rate, #modal-mile-rate{
  margin-left:1rem;
} */

#rate-display:hover {
  cursor: pointer;
}

#rate-con, #rate-spot, #rate-fsc, #modal-mile-rate-spot, #modal-mile-rate-con, #modal-trip-rate-spot, #modal-trip-rate-con, #modal-trip-rate-fsc, #modal-mile-rate-fsc{
  font-weight: bold;
}

#modal-body-ratecast {
  width:fit-content;
  min-width: 1000px;
  min-height:250px;
}

#chart-no-data {
  color:red;
  font-size: large;
  margin: 0px auto;
}

#chart_lines {
  width: 100%;
  min-height:500px;
}

#modal-ratecast-chart-title {
  display:flex;
  justify-content: space-between;
  align-items: center;
  margin-top:30px; 
}

#modal-ratecast-locations {
  font-size: medium;
  font-weight: bold;
}

#modal-ratecast-type {
  float: right;
  font-size: small;
  color: grey;
}

#rate-expand {
  /* color: blue; */
  font-size: 1rem;
  transition: .05s;
}

.attribution {
  font-size: .7rem;
}

/* #chart-options > * {
  margin: auto;
} */

.is-invisible {
  opacity: 0;
} 

.modal {
  z-index: 4000;
}

pre {
  white-space: pre-wrap;
}
thead {
  position: sticky;
  top:-1px;
  background-color: white !important;
  z-index: 999;
}

table {
  border-collapse: separate !important;
  margin: 0 auto;
}


.tabs {
  min-height: 2.75rem;
  background-color: var(--secondary-bg-color);
}

#tab-row {
  background-color: var(--secondary-bg-color);
}

.material-symbols-outlined {
  font-variation-settings:
    'FILL' 0,
    'wght' 400,
    'GRAD' 0,
    'opsz' 20
}

.material-symbols-outlined.filled {
  /* font-size: unset!important; */
  font-size: 1.25rem;
  font-variation-settings:
  'FILL' 1,
  'wght' 400,
  'GRAD' 0,
  'opsz' 24
}

.material-small {
  font-variation-settings:
    'FILL' 0,
    'wght' 400,
    'GRAD' 0,
    'opsz' 20
}

body {
  margin: auto;
  height: 100vh;
  font-family: "Heebo", sans-serif;
}

.TitleBar {
  font-size: 2.5vh;
  font-weight: bold;
  color: white;
  background-color: var(--main-bg-color);
  justify-content: space-between;
}

.nav-comp-logo
{
  max-height: 90%;
  max-width: 100%;
  width: auto;
  height: auto;
  margin: auto 3px;
}

.nav-comp-logo-container
{
  height: auto;
  display: inline-flex;
  flex-wrap: nowrap;
  /* background-color: lightgray; */
  border-radius: 5px;
  padding: 5px;
  max-height: 4em;
}

.nested.dropdown {
  &:hover > .dropdown-menu {
    display: block;
  }
  .dropdown-menu {
    top: -5px;
    margin-left: 100%;    
    min-width: 6rem !important;
  }

  .dropdown-content{
    background-color: #f5f5f5;
  }

  .dropdown-trigger {
/*     button::after {
      content: '⦠'
    } */
    button {
      padding: 0px 0px;
      border: 0px;
      font-size: 14px;
      font-weight: 400;
      height: 2em;
    }
  }
}

.overflow-visible {
  overflow: visible;
}

/* Add a background color to the button if it is clicked on (add the .active class with JS), and when you move the mouse over it (hover) */
.active, .collapsible:hover {
  background-color: #f2f2f2;
}

/* Style the collapsible content. Note: hidden by default */
.collapsible-content {
  /* padding: 0 18px; */
  /* overflow-x: hidden !important; *//* 
  overflow-y: auto; */
  background-color: white !important;
  max-height: 0;
  transition: max-height 0.2s ease-out !important;
  width:100%;
}
/*End Collapsible Testing*/


/*Table Break Styling*/
.break-line{
  position:relative;
  border-bottom: 4px solid lightgrey;
  flex-grow: 1;
  margin-left: 10px;
  margin-right: 10px;
}

.toggle-break{
  display:flex;
  flex-wrap: nowrap;
  flex-direction: row;
  width:100%;
  overflow: hidden;
  align-items: center;
  background-color: white;
  border-width: 0;
  border-radius: 5px;
}

.table {
  width: 95%;
}

tr {
  width: 100%;
}


.navbar {
  z-index: 4000;
}

.ThemeBG,
.navbar-menu,
.navbar-dropdown {
  color: white;
  background-color: var(--main-bg-color);
}

.navbar-divider {
  background-color: var(--secondary-bg-color);
}

.navbar-dropdown {
  border-top: 2px solid var(--secondary-bg-color);
}

.navbar-item,
.navbar-burger,
.navbar-link {
  color: white;
}

.navbar-link:not(.is-arrowless)::after {
  border-color: white;
}

.navbar-link.is-active,
.navbar-link:focus,
.navbar-link:focus-within,
.navbar-link:hover,
.navbar-item.is-active:not(.company-select),
.navbar-item:focus:not(.company-select),
.navbar-item:focus-within:not(.company-select),
.navbar-item:hover:not(.company-select) {
  background-color: var(--secondary-bg-color) !important;
  color: #f3f3f3 !important;
}

.company-select:hover
{
  background-color: white;
  cursor: pointer;
}

.navbar.is-link .navbar-item.has-dropdown.is-active .navbar-link,
.navbar.is-link .navbar-item.has-dropdown:focus .navbar-link,
.navbar.is-link .navbar-item.has-dropdown:hover .navbar-link {
  background-color: var(--secondary-bg-color);
  color: #f3f3f3;
}

.nav-disabled {
  pointer-events: none;
  opacity: .65;
}

.select:not(.is-multiple):not(.is-loading)::after {
  border-color: #a5a5a5;
}

.TitleLogo {
  align-items: center;
  justify-content: center;
  height: 100%;
}

.TitleIcon {
  font-size: 3vh;
  margin-right: 0.2vw;
}

.TitleBar a {
  color: white;
  cursor: pointer;
  text-decoration: none;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  padding-top: 0.25rem;
}

.TitleBar a:hover {
  background-color: var(--secondary-bg-color);
  color: #f3f3f3;
  cursor: pointer;
  text-decoration: none;
}

.hero {
  background-color: var(--secondary-bg-color);
}

.search-bar-form {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.search-bar-form .label {
  margin-bottom: 0;
}

.header-text {
  letter-spacing: 1px;
  text-transform: uppercase;
}


.tab-gap {
  display: flex;
  gap: 0.5rem;
}

.sortable-header {
  cursor: pointer;
  /* background-color: gainsboro; */
}

.sorted-header-asc {
  background-color: gainsboro;
}
.sorted-header-asc::after {
  content: '▼';
}

.sorted-header-desc {
  background-color: gainsboro;
}
.sorted-header-desc::after {
  content: '▲';
}

.loadResultsBody td {
  white-space: nowrap;
  vertical-align: middle;
  text-overflow: ellipsis;
  overflow: hidden;
  font-size: 14px;
}

td.max-136 {
  max-width: 136px;
}

#level-providers {
  z-index: 1000;
  gap: 2rem;
  /* max-width: 1344px; */
}

#level-providers .level-item {
  display: unset;
  /* max-width: 500px; */
}

#level-providers .progress {
  margin: 0.5rem;
}

.progress {
  border-radius: 4px;
}

.mt-05 {
  margin-top: .125rem !important;
}

.td-image {
  vertical-align: bottom!important;
}

.td-image img {
  max-height: 18px;
}

.detail-logo img {
  max-height: 32px;
}

.AuthUser {
  display: flex;
  align-items: center;
  font-weight: normal;
}

#detail-title {
  font-size: 18;
  font-weight: bold;
}

/* context menu */
.map-context-menu {
  position: absolute;
  top: 0px !important;
  left: 0px !important;
}

.map-context-menu .leaflet-popup-content-wrapper {
  border-radius: 4px;
  border-top-left-radius: 0px;
  overflow: hidden;

}

.map-context-menu .leaflet-popup-tip-container {
  display: none;
}

.map-context-menu .leaflet-popup-content {
  margin: unset;
}

.map-context-menu .menu {
  font-size: 12px
}

.map-context-menu .menu-label {
  text-align: center;
  margin: 2px;
  pointer-events: none;
}

.map-context-menu .menu-list .disabled {
  color: gainsboro;
  pointer-events: none;
}

.map-context-menu .menu-list a:hover {
  background-color: #3695ff;
  color: white;
}


.DetailBar {
  text-align: center;
  /*     height: 100%; */
  /* margin: 1px; */
  border-right: var(--main-bg-color) 0.75rem solid;
  border-left: gainsboro 1px solid;

  color: var(--main-bg-color);
  background-color: white;
  min-width: 8vh;
  flex-direction: column;
  overflow-y: auto;
}

.DetailBar table {
  table-layout:fixed;
}

.pricing-container {
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  gap: 2rem;
}



#user-column {
  height: 100%;
  overflow-y: scroll;
}

.custFooter {
  /* margin: 0.5vh; */
  /* font-size: 10px; */
  color: white;
  background-color: var(--main-bg-color);
}

.grid-overlap {
  display: grid !important;
  justify-content: center;
  align-items: center;
  justify-items: center;
  align-content: center;
}

.overlap {
  grid-area: 1 / 1 / 2 / 2;
}

.icon-overlap {
  filter: drop-shadow(1px -1px 0px white);
}

.UI {
  /* background-color: var(--main-bg-color); */
  height: 100%;
  overflow-y: auto;
}

.MainContainer {
  height: 100%;
  margin: 0px;
  overflow: hidden;
}

.SideBar {
  font-size: 18;
  /* font-weight: bold; */
  color: white;
  background-color: var(--main-bg-color);
  min-width: 8vh;
  /* overflow: hidden; */
  padding-bottom: 0px;
}

.tab-page {
  height: 100%;
  display: none;
  flex-direction: column;
  padding: 0.75rem;
  padding-bottom: 0px;
  position: relative;
}

.tab-page.is-active {
  display: flex;
}

#modal-filter .modal-card {
  position: relative;
  overflow: visible;
}

#modal-location-history .modal-card {
  position: relative;
  overflow: visible;
}

#filter-section {
  margin: 0rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
  align-content: center;
  position: relative;
}

.Filter {
  font-weight: normal;
  /* padding: 0.15rem; */

}

.checkbox:hover {
  /* color: gainsboro; */
  color: unset;
  opacity: 0.8;
}

.AssetList {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: 2px;
  background-color: whitesmoke;
  color: var(--main-bg-color);
  overflow-y: scroll;
  height: 0;
  position: relative;
}

.asset {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  cursor: pointer;
  padding-left: 10px;
}

.asset:hover {
  background-color: lightgray;
}

.asset-name {
  font-weight: bold;
}

.asset-id {
  display: none;
}



.geofence-id {
  display: none;
}

.asset-ico {
  width: 24px;
  height: 24px;
  background-repeat: no-repeat;
  background-size: contain;
  margin-top: -2px;
}

.asset-ico.tractor {
  background-image: url('./assets/images/Tractor Fill.png');
}

.asset-ico.trailer {
  background-image: url('./assets/images/Trailer Fill.png');
}

.asset-driver {
  font-weight: normal;
  font-size: 12px;
  margin-left: 2px;
}

.display-category {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
}

.geofence {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  cursor: pointer;
  padding-left: 10px;
}

.geofence-name {
  overflow-x: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.geofence:hover {
  background-color: lightgray;
}

#login-ehelper {
  word-break: break-word;
  word-wrap: break-word;
  max-width: fit-content;
}

#login-phelper {
  word-break: break-word;
  word-wrap: break-word;
  max-width: fit-content;
}

#AssetSearch {
  flex-grow: 1;
}

#geofence-search {
  flex-grow: 1;
}

#signInFade {
  display: none;
  align-items: center;
  position: absolute;
  top: 0%;
  left: 0%;
  width: 100%;
  height: 100%;
  background-color: #0000007a;
  z-index: 10000;
  color: white;
  flex-direction: column;
  justify-content: space-evenly;
}

#signInBlock {
  position: absolute;
  background-color: var(--main-bg-color);
  z-index: 10000;
  display: flex;
  color: white;
  padding: 3vh;
  flex-direction: column;
  align-items: stretch;
  justify-content: space-evenly;
  filter: drop-shadow(2px 2px 0.15rem black);
  margin: 20px;
}

#signInContent {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  font-weight: normal;
  justify-content: center;
}

#SignOut {
  display: none;
}

.arrow-image {
  width: 22px;
}

/*Booking Modal*/
.wide-modal
{
  height: 90%;
  width: 95%;
}

.is-main-bg-color
{
  background-color: var(--main-bg-color);
}

.is-secondary-bg-color
{
  background-color: var(--secondary-bg-color);
}

.no-border
{
  border-width: 0px;
}

#booking-back-btn {
  position: relative;
  top: 1.5rem;
  left: 2rem;
  border-radius: 4px !important;
  transition: 0.25s ease-in-out;
}

#booking-back-btn:hover {
  scale: 1.1;
}

#booking-back-btn:active {
  scale: 0.95;
}

.booked-status-background {
  border-radius: 4px !important;
  display: flex;
  justify-content: center;
}

.booked-status-text {
  /* color: #f2f2f2; */
  font-weight: bold;
}

/* .border-radius-4 {
  border-radius: 4px p !important;
} */

.modal-submit-btn {
  border-radius: 4px !important;
}

.modal-title-ellipses {
  display: inline-block;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  flex-shrink: revert;
}

.btn {
  display: flex;
  font-weight: normal;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;
  border: 1px solid transparent;
  white-space: nowrap;
  padding: 6px 12px;
  font-size: 14px;
  line-height: 1.42857143;
  border-radius: 0;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.btn-small {
  padding: 1px 6px;
  margin: 3px;
}

.btn-primary {
  color: #fff;
  background-color: #3695ff;
  border-color: #1c88ff;
}

.btn-secondary {
  color: #fff;
  background-color: gray;
  border-color: gray;
}

.btn-disabled {
  color: #fff;
  background-color: darkgray;
  border-color: darkgray;
  cursor: default;
}

/* #mapid { 
height: 100%;
flex-grow: 1;
margin: 1px;
} */
.material-icons.md-64 {
  font-size: 64px;
}

.my-div-icon {
  display: flex;
  align-items: flex-end;
  /* background-color: white; */
  -webkit-transition: transform 0.3s linear;
  -moz-transition: transform 0.3s linear;
  -o-transition: transform 0.3s linear;
  -ms-transition: transform 0.3s linear;
  transition: transform 0.3s linear;
}

.asset-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  width: 100%;
  /* filter: drop-shadow(2px 2px 0.15rem darkgray); */
  transform: translateY(-25%);
  /* transition: transform 0.3s linear; */
  margin: -1px;
  margin-bottom: 3px;
}

.moving-icon {
  -webkit-transition: transform 0.3s linear;
  -moz-transition: transform 0.3s linear;
  -o-transition: transform 0.3s linear;
  -ms-transition: transform 0.3s linear;
  transition: transform 0.3s linear;
}

.oldping {
  background-color: white;
}

.selected-div-icon {
  background-color: rgba(50, 146, 255, 0.5);
  border-radius: 1000px;
  box-shadow: -2px 0 rgb(50 146 255), 0 2px rgb(50 146 255),
    2px 0 rgb(50 146 255), 0 -2px rgb(50 146 255);
}

.moving-pin {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  height: 100%;
  width: 100%;
  /* filter: drop-shadow(2px 2px 0.15rem darkgray); */
  transform: translateY(-25%);
  /* transition: transform 0.3s linear; */
  margin: -1px;
  margin-bottom: 3px;
}

.route-point-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: white;
  border: 1px black solid;
  pointer-events: none !important;
}

.route-preview-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  width: 100%;
  /* filter: drop-shadow(2px 2px 0.15rem darkgray); */
  /* transform: translateY(-25%); */
  /* transition: transform 0.3s linear; */
  margin: -1px;
  margin-bottom: 3px;
  pointer-events: none !important;
  transform-origin: center !important;
  opacity: 0.8;
}


.polygon-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: white;
  border: 1px black solid;
}

.polygon-round {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: black;
  color: white;
  border: 1px black solid;
  border-radius: 100px;
}

.white-polygon {
  background-color: white;
  border-radius: 0px;
}

.polygon-pin {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  color: white;
  height: 100%;
  width: 100%;
  transform: translateY(-25%);
  transition: transform 0.3s linear;
  margin: -1px;
  margin-bottom: 3px;
}

.w-100 {
  width: 100% !important;
}

.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-center-column {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.v-align-middle tr td,
.v-align-middle tr th {
  vertical-align: middle;
}

.action-row {
  cursor: pointer;
}

.action-row:hover {
  background-color: gainsboro;
}
/* 
.action-row img {
  height: 32px;
} */

.faded {
  opacity: 50%;
}

.placeholder {
  opacity: 0.2;
}

.orangered {
  color: orangered;
}

.RTI-color {
  color: rgba(50, 146, 255, 1);
}

.TLI-color {
  color: rgb(255 99 105);
}

.Trailer-color {
  color: rgba(110, 204, 57, 1);
}

.hover-cluster {
  z-index: 2000 !important;
  transition: z-index 0.1s;
  transition-delay: 0.05s;
  transform: scale(1.1);
}

/* .hover-cluster .cluster-icon {
  transform: scale(2);
  transition: transform 0.2s;
  transition-delay: 0.5s;
} */
.hover-cluster>div {
  transform: scale(1.5);
  transition: transform 0.2s;
  transition-delay: 0.5s;
}


/* .cluster-icon:before {
  content: ' ';
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  opacity: 1;
  background: url('./assets/images/Trailer Fill.png') no-repeat center center fixed;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
} */


.truck-cluster img {
  height: 32px;
  /* opacity: 0.8; */
}

.tli-truck-cluster {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  /* color: red; */
  /* font-size: 10px; */
  height: 100%;
  width: 100%;
  /* filter: drop-shadow(1px 1px 0.1rem gray); */
  transform: translateY(-0%);
  background-color: rgba(235, 28, 36, 0.3);
  border-radius: 1000px;
}

.tli-truck-cluster-small {
  background-color: rgba(235, 28, 36, 0.5);
  position: absolute;
  width: 80%;
  height: 80%;
  border-radius: 1000px;
  z-index: -1;
}

.tli-truck-cluster img {
  height: 32px;
  /* opacity: 0.8; */
}

.leaflet-marker-icon {
  box-sizing: content-box;
}

.color-bar {
  background-color: gray;
  height: 1rem;
  width: 0.3rem;
  min-width: 0.3rem;
  margin-right: 0.25rem;
  margin-bottom: 3px;
}

.icon {
  min-width: 1.5rem;
}

.RTI-bar {
  background-color: rgba(50, 146, 255, 1) !important;
}

.TLI-bar {
  background-color: rgba(235, 28, 36, 1) !important;
}

.Trailer-bar {
  background-color: rgba(110, 204, 57, 1) !important;
}

.invert-img {
  filter: invert(1);
}

.truck-img {
  filter: invert(1) sepia(1) saturate(100) brightness(0.4) hue-rotate(150deg);
}

.truck-pin {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  color: blue;
  height: 100%;
  width: 100%;
  filter: drop-shadow(2px 2px 0.15rem darkgray);
  transform: translateY(-50%);
}

.trailer-cluster {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  /* color: red; */
  /* font-size: 10px; */
  height: 100%;
  width: 100%;
  /* filter: drop-shadow(1px 1px 0.1rem gray); */
  transform: translateY(-0%);
  background-color: rgba(110, 204, 57, 0.3);

  border-radius: 1000px;
}

.trailer-cluster-small {
  background-color: rgba(110, 204, 57, 0.5);
  position: absolute;
  width: 80%;
  height: 80%;
  border-radius: 1000px;
  z-index: -1;
}

.trailer-cluster img {
  height: 32px;
  /* opacity: 0.8; */
}

.trailer-img {
  filter: invert(1) sepia(1) saturate(100) brightness(0.5) hue-rotate(50deg);
}

.trailer-pin {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  color: rgba(110, 204, 57, 1);
  height: 100%;
  width: 100%;
  filter: drop-shadow(2px 2px 0.15rem darkgray);
  transform: translateY(-50%);
}

.pin-body {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  height: 100%;
  width: 100%;
  border-radius: 10px;
  /* border: 1px black solid; */
  background-color: rgba(255, 255, 255, 0.9);
}

.pin-point {
  margin-top: -0px;
  width: 0px;
  height: 0px;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-top: 20px solid rgba(255, 255, 255, 0.9);
}

.pin-body:before {
  width: 10px;
  bottom: 0;
  margin-bottom: -12px;
  border-top-color: white;
}

.trailer-number {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  padding: 1px;
  background-color: rgba(250, 250, 250, 1);
  box-shadow: none;
  border: 0px;
}

.pin-label {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  padding: 3px;
  filter: drop-shadow(2px 2px 0.15rem darkgray);
  border: 0px;
  margin-bottom: -2000px;
  font-weight: normal;
}

/* 
.leaflet-tooltip-top:before {
  bottom: 0;
  margin-bottom: -25px;
  border-left: 3px solid transparent;
  border-right: 3px solid transparent;
  border-top: 20px solid transparent;    
}
.truck-label:before {
  bottom: 0;
   margin-bottom: -15px;
  border-top: 10px solid rgba(255, 255, 255, 1);    
} */

/* .leaflet-marker-pane>* {
  -webkit-transition: transform 0.3s linear;
  -moz-transition: transform 0.3s linear;
  -o-transition: transform 0.3s linear;
  -ms-transition: transform 0.3s linear;
  transition: transform 0.3s linear;
} */

.hide {
  display: none;
}

.strike {
  text-decoration: line-through;
}

.selected {
  background-color: #3390ff;
  color: white;
}

.noselect {
  -webkit-touch-callout: none;
  /* iOS Safari */
  -webkit-user-select: none;
  /* Safari */
  -khtml-user-select: none;
  /* Konqueror HTML */
  -moz-user-select: none;
  /* Old versions of Firefox */
  -ms-user-select: none;
  /* Internet Explorer/Edge */
  user-select: none;
  /* Non-prefixed version, currently
                                  supported by Chrome, Edge, Opera and Firefox */
}

.begin-cap {
  background-color: gray;
  color: white;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  padding: 2px;
}
.end-cap {
  background-color: gray;
  color: white;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
  padding: 2px;
}
.begin-cap:hover, .end-cap:hover {
  opacity: 0.8;
}

.driving-line {
  height: 30px;
  border-left: 2px dashed #3e8ed0;
  width: 0px;
  margin-left: auto;
  margin-right: auto;
  opacity: 0.5;
}

.moving-event:hover {
  /* color: #3e8ed0; */
  opacity: 0.75;
}

.stopped-event:hover {
  opacity: 0.9;
}

#filter-count {
  display: none;
}



.field.is-grouped.is-grouped-multiline>.control:last-child,
.field.is-grouped.is-grouped-multiline>.control:not(:last-child) {
  margin-bottom: 3px;
}

.field.is-grouped.is-grouped-multiline>.control:last-child {
  margin-bottom: 3px;
  margin-right: 0;
}

.field.is-grouped>.control:not(:last-child) {
  margin-right: 3px;
}

#filter-list .asset-ico {
  height: 20px;
  width: 20px;
  image-rendering: -webkit-optimize-contrast;
}

abbr[title] {
  text-decoration: unset;
}

.pop-up-line {
  display: flex;
  align-items: flex-start;
  align-content: center;
}

.pop-up-icon {
  width: 1rem !important;
  height: 1rem !important;
  min-width: unset;
  max-width: unset;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-right: 0.25rem;
  margin-left: -0.25rem;
}

.warning-text {
  color: darkorange;
}

.leaflet-control-container {
  width: 100%;
}

.leaflet-geosearch-bar {
  margin-top: -2px;
  margin-right: 48px;
  margin-left: 48px;
  /* width: 100%; */
  /* max-width: 400px; */
}

/* .header-cell {
  font-size: 0.9rem
} */

.is-size-8 {
  font-size: 0.7rem;
}

.detail-header {
  display: flex;
  align-items: center;
  justify-content: center;
}

i.rti-logo {
  height: 16px;
  opacity: 0.75;
  background-image: url("./assets/images/rti_white.png");
  /* flex-grow: 1; */
  background-size: auto 14px;
  background-repeat: no-repeat;
  background-position: center center;
  aspect-ratio: 161 / 58;
  image-rendering: auto;
}

i.rti-logo.small {
  height: 10px;
  background-size: auto 9px;
}

i.tli-logo {
  height: 16px;
  opacity: 0.75;
  background-image: url("./assets/images/tli_white.png");
  /* flex-grow: 1; */
  background-size: auto 14px;
  background-repeat: no-repeat;
  background-position: center center;
  aspect-ratio: 110 / 61;
  image-rendering: auto;
}

i.tli-logo.small {
  height: 10px;
  background-size: auto 9px;
}


.block {
  display: block;
}

.ellipses {
  overflow: hidden !important;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.tabs a {
  padding: 0.5em 0.5em;
}

#tab-toolbox {
  width:auto;
  display: flex;
  justify-content: space-between;
  gap: 0.25rem;
}

/* Tooltip container */
.tooltip {
  position: relative;
  display: inline-block;
  border-bottom: 1px dotted black; /* If you want dots under the hoverable text */
  z-index: 1000;
}

/* Tooltip text */
.tooltip .tooltiptext {
  visibility: hidden;
  width: 120px;
  background-color: black;
  color: #fff;
  text-align: center;
  padding: 5px 0;
  border-radius: 6px;
  
 
  /* Position the tooltip text - see examples below! */
  position: absolute;
  z-index: 1000;
}

.tooltip .tooltiptext.right {
  top: -5px;
  left: 105%;
}

/* Show the tooltip text when you mouse over the tooltip container */
.tooltip:hover .tooltiptext {
  visibility: visible;
}
.tooltip .tooltiptext {
  font-size: 1rem;
  font-weight: normal;
  width: 120px;
  top: 100%;
  left: 50%;
  margin-left: -60px; /* Use half of the width (120/2 = 60), to center the tooltip */
}


/* tooltips */
.tutorial-cover {
  z-index: 10000;
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

.tutorial-text {
  color: white;
  margin-top: 1rem;
  pointer-events: none;
}

.darken {
  /* background-color: rgba(0, 0, 0, 0.4); */
  filter: brightness(0.5);
}

.highlight-red {
  outline: 2px red solid;
  z-index: 499;
  animation: pulse 2s infinite;
}

[data-tutorial-top]::before {
  content: ' ';
  position: absolute;
  top: -1.3rem;
  left: 48%;
  width: 2%;
  height: 3rem;
  border: 1rem solid white;
  border-color: white transparent transparent transparent;
  z-index: 502;

}
[data-tutorial-top]::after {
  display: flex;
  align-items: center;
  justify-content: center;
  content: attr(data-tutorial-top);
  position: absolute;
  top: -4rem;
  left: 5%;
  width: 90%;
  /* height: 3.5rem; */
  background-color: white;
  font-weight: bold;
  filter: drop-shadow(2px 4px 6px black);
  box-shadow: 0 0 0 0 rgb(255, 255, 255);
  animation: pulse 2s infinite;
  padding: 10px;
  text-align: center;
  z-index: 501;
}

[data-tutorial-none]::after {
  display: flex;
  align-items: center;
  justify-content: center;
  content: attr(data-tutorial-none);
  position: absolute;
  top: 3.5rem;
  background-color: white;
  font-weight: bold;
  filter: drop-shadow(2px 4px 6px black);
  box-shadow: 0 0 0 0 rgb(255, 255, 255);
  animation: pulse 2s infinite;
  padding: 10px;
  text-align: center;
  font-size: 1rem;
  pointer-events: none;
  z-index: 501;
  color: rgba(0, 0, 0, 0.7);
}

[data-tutorial-bottom]::before {
  content: ' ';
  position: absolute;
  top: 0.5rem;
  width: 2%;
  height: 3rem;
  border: 1rem solid white;
  border-color: transparent transparent white transparent;
  z-index: 1;
  pointer-events: none;
  z-index: 502;
}
[data-tutorial-bottom]::after {
  display: flex;
  align-items: center;
  justify-content: center;
  content: attr(data-tutorial-bottom);
  position: absolute;
  top: 3.5rem;
  /* left: 15%; */
  width: 90%;
  min-width: 15rem;
  max-width: 20rem;
  white-space: break-spaces;
  /* height: 3.5rem; */
  background-color: white;
  font-weight: bold;
  filter: drop-shadow(2px 4px 6px black);
  box-shadow: 0 0 0 0 rgb(255, 255, 255);
  animation: pulse 2s infinite;
  padding: 10px;
  text-align: center;
  font-size: 1rem;
  pointer-events: none;
  z-index: 501;
  color: rgba(0, 0, 0, 0.7);
}

[data-tutorial-left]::before {
  content: ' ';
  position: absolute;
  top: 0.5rem;
  width: 2%;
  height: 3rem;
  border: 1rem solid white;
  border-color: transparent transparent white transparent;
  z-index: 1;
  pointer-events: none;
  z-index: 502;
}
[data-tutorial-left]::after {
  display: flex;
  align-items: center;
  justify-content: center;
  content: attr(data-tutorial-left);
  position: absolute;
  top: 3.5rem;
  /* left: 15%; */
  /* width: 70%; */
  /* height: 3.5rem; */
  background-color: white;
  font-weight: bold;
  filter: drop-shadow(2px 4px 6px black);
  box-shadow: 0 0 0 0 rgb(255, 255, 255);
  animation: pulse 2s infinite;
  padding: 10px;
  text-align: center;
  font-size: 1rem;
  pointer-events: none;
  z-index: 501;
  color: rgba(0, 0, 0, 0.7);
}

@keyframes pulse {
0% {
  box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.7);
}

70% {
  box-shadow: 0 0 0 10px rgba(255, 255, 255, 0);
}

100% {
  box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
}
}

/* end toolips */








/* desktop only */
@media screen and (min-width: 768px) {

  #filter-field {
    max-width: 200px;
  }

}

/*from tablet down*/
@media screen and (max-width: 768px) {
  #custom-filter {
    flex-direction: column;
    align-items: stretch;
  }

  .touch-fullwidth {
    width: 100%;
    margin-bottom: 0.25rem !important;

  }

  .TitleBar {
    height: auto;
    border-bottom: var(--secondary-bg-color) 1px solid;
  }

.hero-body {
  padding: 1rem 0.5rem;
}

  .search-bar-form {
    flex-direction: column;
  }


  .SideBar {
    height: 25%;
    padding-top: 1px;
    padding-bottom: 0.75rem;
  }

  .SideBar.MenuOpen {
    height: 0%;
  }


  .tab-page {
    padding-bottom: 0.75rem;
    overflow-y: scroll;
  }

  .mapContainer {
    height: 75%;
  }

  .detailsContainer {
    height: 0%;
    border-right-width: 0px;
    border-left-width: 0px;
    border-top: 1px gainsboro solid;
  }

  .detailsContainer.hasDetails {
    height: 25%;
  }

  .mapContainer.hasDetails {
    height: 50%;
  }

  .mapContainer.MenuOpen {
    height: 100%;
  }

  .mapContainer.is-10 {
    border-right-width: 0px;
  }

  #filter-list.field.is-grouped.is-grouped-multiline {
    flex-wrap: nowrap !important;
    overflow-x: scroll;
  }

}


/* font reduction for at or less than 1080p */
@media screen and (max-width: 1921px) {

  #asset-details,
  #filter-section {
    font-size: 0.9rem
  }

  #asset-actions-container .button {
    font-size: 0.9rem
  }

  #expirations-container .message {
    font-size: 0.9rem
  }

}

/* pane size increase for at or less than 1080p desktops */
@media screen and (max-width: 1921px) and (min-width: 769px) {

  .MainContainer .column.is-8 {
    width: 64%;
  }
  .MainContainer .column.is-2 {
    width: 18%;
  }
  .MainContainer .column.is-10 {
    width: 82%;
  }

}
@media screen and (max-width: 1800px){

  .small-screen-hide {
    display:none;
  }
}

.loader {
  border: .25rem solid #e1e0e0; /* Light grey */
  border-top: .25rem solid #3498db; /* Blue */
  border-radius: 50%;
  width: 1.5rem;
  height: 1.5rem;
  animation: spin 2s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}