@charset "UTF-8";
hr {
  color: transparent;
  background-color: #ebebeb;
  height: 2px !important;
  opacity: 1;
}

/* Custom Bootstrap-style classes */
.dropdown-scroll {
  max-height: 75vh;
  overflow-y: auto;
}

.d-contents {
  display: contents;
}

.ws-normal {
  white-space: normal;
}

.ws-pre-wrap {
  white-space: pre-wrap;
}

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

.strike-dash,
.strike-dash:hover {
  text-decoration: line-through dashed;
}

.vective .container {
  max-width: inherit !important;
  padding-left: 0px !important;
  padding-right: 0px !important;
}

.transition-all-point25s {
  transition: all 0.25s;
}

.cursor-default {
  cursor: default !important;
}

.cursor-pointer {
  cursor: pointer !important;
}

.cursor-grab {
  cursor: grab !important;
}

.rounded-0-end {
  border-top-right-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

.rounded-0-top {
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
}

.rounded-0-bottom {
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

.rounded-0-top-start {
  border-top-left-radius: 0 !important;
}

.rounded-0-top-end {
  border-top-right-radius: 0 !important;
}

.rounded-bottom-start {
  border-bottom-left-radius: 0.25em !important;
}

.table-sm-y {
  /* Small table but only in the y direction */
}
.table-sm-y td,
.table-sm-y th {
  padding-top: 0.3rem;
  padding-bottom: 0.3rem;
}

.rows-striped > .row:not(:empty) {
  border-top: 1px solid #c0c0c0;
  padding-top: 10px;
  padding-bottom: 10px;
}
.rows-striped > .row:not(:empty):nth-of-type(even) {
  background-color: rgba(0, 0, 0, 0.05);
}

@media (min-width: 992px) {
  /* Not strictly in line with bootstrap, as rounded-lg denotes the size of rounding as opposed to screensize for some reason */
  .rounded-end-lg {
    border-top-right-radius: 0.25rem !important;
    border-bottom-right-radius: 0.25rem !important;
  }
  .rounded-bottom-start-lg-0 {
    border-bottom-left-radius: 0 !important;
  }
}
.dots-between > *:not(:last-child):after {
  display: inline-block;
  padding-left: 0.5rem;
  padding-right: 0.25rem;
  content: "·";
  color: black;
}

.btn-left-stripe {
  text-align: left !important;
}
.btn-left-stripe:hover {
  background-image: linear-gradient(90deg, var(--tenant-primary-colour) 8px, transparent 8px);
}

.bg-regular {
  background-color: #2d66c2;
  color: #ffffff;
}

.bg-single {
  background-color: #d7e334;
}

/* Font awesome */
.fa-1_5x {
  font-size: 1.5em;
}

.fa-stack.fa-stack-small {
  font-size: 0.5em;
}

.word-break-all {
  word-break: break-all;
}

.outline-0 {
  outline: 0;
}

.light-placeholder::placeholder {
  color: #adb5bd;
  opacity: 1; /* Firefox */
}

.fake-disabled { /* Make fields still look disabled after submitting (they are enabled so that data can be submitted). */
  pointer-events: none;
  background: #e9ecef !important;
}

.bg-site-background {
  background-color: var(--site-background-colour);
}

.bg-site-background-darker {
  background-color: var(--site-background-colour-darker);
}

.sticky-header {
  position: sticky;
  top: 0;
  background: #FFFFFF;
  z-index: 10;
}

.sticky-footer {
  position: sticky;
  bottom: 0;
  background: #FFFFFF;
  z-index: 10;
}

.sticky-start {
  position: sticky;
  left: 0;
  background: #FFFFFF;
  z-index: 10;
}

.w-fit-content {
  width: fit-content;
}

.mw-fit-content {
  min-width: fit-content;
}

.h-fit-content {
  width: fit-content;
}

.mh-fit-content {
  min-height: fit-content;
}

body, .modal-content {
  font-size: 16px;
  background-color: var(--site-background-colour) !important;
}

input[disabled] {
  opacity: 0.5;
}

.modal {
  overflow-y: auto;
}
.modal.show {
  background-color: rgba(0, 0, 0, 0.5);
}
.modal.bootbox {
  display: flex !important;
  align-items: center;
  justify-content: center;
}
.modal.bootbox .modal-header h4 {
  order: 0;
}
.modal.bootbox .modal-header button {
  order: 1;
}

.modal-backdrop {
  visibility: hidden !important;
}
.modal-backdrop.fade.show {
  opacity: 0.5 !important;
}

h1 span {
  transition: 0.15s;
}

@media (min-width: 992px) {
  .body {
    min-height: 500px;
  }
}
.alert ul {
  padding: 0;
  margin: 0;
}

.alert li {
  list-style: none;
}

.select2 {
  width: 100% !important;
}

.select2-container--open,
.mapboxgl-ctrl-geocoder,
.pac-container {
  z-index: 1005 !important;
}

.open-modal-with-form .select2-container--open,
.open-modal-with-form .mapboxgl-ctrl-geocoder,
.open-modal-with-form .pac-container {
  z-index: 1060 !important;
}

legend.form-label {
  font-size: var(--bs-body-font-size) !important;
  float: none !important;
}

/* We need 15 extra pixels on the right-hand side for the scroll bar, otherwise the sidebar gets squashed slightly. */
.tooltip {
  pointer-events: none;
}

.disruption {
  text-align: center;
  border-radius: 0.3rem;
  color: white;
  margin-bottom: 0.25rem;
  padding: 0.5rem;
  display: flex;
  flex-direction: row;
  justify-content: center;
  text-decoration: none !important;
}
.disruption i {
  display: flex;
  align-items: center;
}

.disruption:last-of-type {
  margin-bottom: 1rem;
}

.current-disruption {
  background-color: #CC0102;
}

.current-disruption:hover {
  background-color: #aa0001;
}

.upcoming-disruption {
  background-color: #F3C40B;
}

.upcoming-disruption:hover {
  background-color: #deb20b;
}

.info-disruption {
  background-color: var(--tenant-secondary-colour);
}

.info-disruption:hover {
  background-color: var(--tenant-secondary-colour-darker);
}

#pageHeader {
  top: 0;
  width: calc(100% + 155px);
  z-index: 1020;
  background-color: #fff;
  margin-left: -70px;
  margin-right: -85px;
  padding-left: 70px;
  padding-right: 85px;
}

@media (min-width: 992px) {
  .page-header-text-div {
    max-width: 70%;
  }
}
#mainSection {
  flex-grow: 1;
  padding-left: 70px;
  padding-right: 70px;
  max-width: calc(100% - 290px - 15px);
}

#mainSection.sidebar-minimised {
  max-width: calc(100% - 80px - 15px);
}

@media (max-width: 991px) {
  #mainSection {
    min-width: 100%;
    padding-left: 15px;
    padding-right: 15px;
  }
  #pageHeader {
    margin-left: -15px;
    padding-left: 15px;
    padding-right: 15px;
    width: calc(100% + 30px);
  }
}
#bottomHalfSidebarDesktop.maximised i.sidebar-btn-icon,
#mobileSidebar i.sidebar-btn-icon {
  position: absolute;
  left: 12px;
  top: 10.5px;
}

#bottomHalfSidebarDesktop.maximised .sidebar-btn,
#mobileSidebar .sidebar-btn {
  padding-left: 28.875px;
}

#bottomHalfSidebarDesktop,
#mobileSidebar {
  margin-right: 0 !important;
  padding-right: 0 !important;
}
#bottomHalfSidebarDesktop .sidebar-btn:hover, #bottomHalfSidebarDesktop .powered-by-vectare-btn:hover,
#mobileSidebar .sidebar-btn:hover,
#mobileSidebar .powered-by-vectare-btn:hover {
  background-color: rgba(255, 255, 255, 0.0823529412);
}
#bottomHalfSidebarDesktop .sidebar-btn:active, #bottomHalfSidebarDesktop .powered-by-vectare-btn:active,
#mobileSidebar .sidebar-btn:active,
#mobileSidebar .powered-by-vectare-btn:active {
  background-color: rgba(255, 255, 255, 0.1882352941);
}
#bottomHalfSidebarDesktop .sidebar-btn,
#mobileSidebar .sidebar-btn {
  transition-duration: 0.15s;
  transition-property: transform;
  position: relative;
}
#bottomHalfSidebarDesktop .sidebar-btn:hover,
#mobileSidebar .sidebar-btn:hover {
  transform: scale(1.05);
}
#bottomHalfSidebarDesktop .sidebar-btn:active,
#mobileSidebar .sidebar-btn:active {
  color: #fff;
  transform: scale(1.05);
}
#bottomHalfSidebarDesktop .sidebar-btn:hover:before,
#mobileSidebar .sidebar-btn:hover:before {
  right: 0;
}
#bottomHalfSidebarDesktop .sidebar-btn.highlighted,
#mobileSidebar .sidebar-btn.highlighted {
  background-color: rgba(255, 255, 255, 0.1882352941);
}

#bottomHalfSidebarDesktop:not(.maximised) span.sidebar-btn-text,
#bottomHalfSidebarDesktop:not(.maximised) .minimised-sidebar-hide {
  display: none !important;
}

#bottomHalfSidebarDesktop.maximised .minimised-sidebar-show {
  display: none !important;
}

#bottomHalfSidebarDesktop.maximised .maximised-sidebar-hide,
#mobileSidebar .maximised-sidebar-hide {
  display: none !important;
}

/* Animation for minimising/maximising the sidebar. */
#mainSection,
#bottomHalfSidebarDesktop {
  transition: 0.2s ease;
}

#bottomHalfSidebarDesktop {
  height: 100vh !important;
  overflow: hidden;
}

#bottomHalfSidebarDesktop {
  width: 290px !important;
}

#bottomHalfSidebarDesktop.minimised {
  width: 80px !important;
}

#bottomHalfSidebarDesktop .sidebar-scrollable-section {
  overflow-x: hidden;
  overflow-y: hidden;
}

#bottomHalfSidebarDesktop .sidebar-scrollable-section:hover {
  overflow-y: auto;
}

#mobileSidebar .sidebar-scrollable-section {
  overflow-x: hidden;
  overflow-y: auto;
}

#bottomHalfSidebarDesktop.maximised .sidebar-scrollable-subsection,
#mobileSidebar .sidebar-scrollable-subsection {
  width: calc(100% - 4px);
  margin-right: 4px;
}

#bottomHalfSidebarDesktop:not(.maximised) ::-webkit-scrollbar {
  display: none;
}

#bottomHalfSidebarDesktop ::-webkit-scrollbar,
#mobileSidebarContainer ::-webkit-scrollbar {
  background-color: rgba(255, 255, 255, 0.4392156863);
  width: 5px;
  background-color: transparent;
}
#bottomHalfSidebarDesktop ::-webkit-scrollbar-thumb,
#mobileSidebarContainer ::-webkit-scrollbar-thumb {
  background-color: rgba(255, 255, 255, 0.4392156863);
  border-radius: 5px;
}

#bottomHalfSidebarDesktop.maximised .sidebar-scrollable-subsection {
  padding-left: 35px;
  padding-right: 35px;
}

#mobileSidebarContainer .sidebar-scrollable-subsection {
  padding-left: 20px;
  padding-right: 20px;
}

.logo-image {
  width: 55%;
  aspect-ratio: 1/1;
}

#bottomHalfSidebarDesktop,
#mobileSidebar {
  font-size: 13px;
}
#bottomHalfSidebarDesktop .btn,
#mobileSidebar .btn {
  font-size: 13px;
}
#bottomHalfSidebarDesktop input,
#mobileSidebar input {
  font-size: 13px;
}

.sidebar-btn-div {
  margin: 2.5px auto;
  position: relative;
}
.sidebar-btn-div .btn {
  border: 1px solid black;
  width: 100%;
  border-radius: 4px;
  color: var(--tenant-tertiary-colour);
}

.sidebar-btn-text,
.sidebar-btn-icon {
  color: var(--tenant-tertiary-colour) !important;
}

#bottomHalfSidebarDesktop.maximised #collapseSidebarButtonDiv {
  margin-left: 35px;
  margin-right: 35px;
  width: calc(100% - 70px);
}

.slightly-transparent-bg {
  background-color: rgba(255, 255, 255, 0.0823529412);
}

.fairly-transparent-bg {
  background-color: rgba(255, 255, 255, 0.1882352941);
}

#mobileSidebarContainer {
  width: 300px;
  z-index: 2000;
}

#mobileSidebar,
#btnMobileSidebarHide {
  pointer-events: auto;
}

.two-line-overflow {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.custom-parsley-error ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
}
.custom-parsley-error ul li {
  position: relative;
  padding: 0.75rem 1.25rem;
  margin-bottom: 0;
  margin-top: 0.25rem !important;
  border-radius: 0.25rem;
  color: #721c24;
  background-color: #f8d7da;
  border: 1px solid #f5c6cb;
}

.flatpickr-input {
  background-color: white !important;
}

#document360-widget-iframe {
  right: 2px !important;
  bottom: 5px !important;
}

.page-title {
  color: var(--tenant-primary-colour);
}

.page-subtitle {
  font-size: 0.85rem;
}

.page-title-div {
  display: flex;
  align-items: center;
}
.page-title-div .page-title {
  margin-bottom: 0;
}
.page-title-div .page-subtitle {
  float: right;
  margin-bottom: 0;
  min-width: 100px;
  text-align: right;
}
.page-title-div + hr {
  margin-top: 0.5rem;
}

.page-filters-links-div {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 1rem;
  width: 100%;
  gap: 10px;
}
.page-filters-links-div .page-filters-links-start-div {
  flex-basis: 0;
  flex-grow: 1;
  max-width: 100%;
  align-self: start;
  margin-right: auto;
}
.page-filters-links-div .page-filters-links-start-div.page-filters-links-start-div-btns {
  /* When page-filters-links-start-div contains buttons, this class prevents the buttons breaking onto multiple lines */
  display: inline-flex;
  gap: 0.375rem;
}
.page-filters-links-div .page-filters-links-end-div {
  flex: 0 0 auto;
  align-self: start;
  margin-left: auto;
}

.badge-corner {
  position: absolute;
  right: 0;
  top: 0;
  padding: 0.1rem 0.5rem;
  border-top-right-radius: 0.25rem;
  border-bottom-left-radius: 0.25rem;
  z-index: 1;
  font-size: 0.75em;
}

/*# sourceMappingURL=main.css.map */
