/* General styling -------- */

:root {
  --font-family:  "proxima-soft","calibri",sans-serif;
  --font-color: #000;
  --colour-ha-green: #6AA442;
  --colour-ha-lightgreen: #B8E798;
  --colour-ha-purple: #7F3D97;
  --colour-ha-pine: #2E4E43;
  --colour-ha-burgundy: #7E1D38;
  --colour-ha-lightburgundy:#AF657A; 
  --colour-ha-ice: #EAF1ED;
  --colour-ha-dark-grey: #444;
}

body {
    margin: 0;
    font-family: var(--font-family);
    font-size: 16px;
    font-weight: 300;
    line-height: 1.5;
    color: var(--font-color);
    text-align: left;
    background-color: #fff
}

.h1,.h2,.h3,.h4,.h5,.h6,
h1,h2,h3,h4,h5,h6 {
    font-family: var(--font-family);
    font-weight: 600;
    line-height: 1.1;
    color: var(--colour-ha-purple)
}

.h1 .small,.h1 small,.h2 .small,.h2 small,.h3 .small,.h3 small,.h4 .small,.h4 small,.h5 .small,.h5 small,.h6 .small,.h6 small,h1 .small,h1 small,h2 .small,h2 small,h3 .small,h3 small,h4 .small,h4 small,h5 .small,h5 small,h6 .small,h6 small {
    font-weight: 600;
    line-height: 1;
    font-size: 65%
}

.h1, h1 {
    font-size: 28px
}

.h2, h2 {
    font-size: 24px
}

.h3, .h4, .h5, .h6, 
h3, h4, h5, h6 {
    font-size: 20px
}

.h4, .h5, .h6, 
h4, h5, h6 {
    font-size: 16px
}

h1.modal-title {
  margin-top: 5px;
}


.wrapper-body {
    min-height: calc(100% - 150px);
}

a {
  font-weight: 500;
  color: var(--colour-ha-green);
  text-decoration: underline;
}

.page-header-content a:not(.btn) {
  color: var(--colour-ha-lightgreen);
}

a:hover,
a:focus,
a:active {
  color: var(--colour-ha-burgundy);
  text-decoration: none;
}

.page-header-content a:hover:not(.btn),
.page-header-content a:focus:not(.btn),
.page-header-content a:active:not(.btn) {
  color: var(--colour-ha-lightburgundy);
}


.custom-sitetitle {
  display: inline;
}

/* ---------------------- */

/* Header and navbar styling -------- */

.navbar .site-logo {
  width: auto; 
  height: 46px; 
  margin: 0 10px;
  transform: translate(0, -5px);
} 

.static-top.navbar .menu-bar > .navbar-nav > li > a {
    font-family: var(--font-family);
    font-weight: 500;
}

.navbar-dark .navbar-nav > li > a:hover {
    color: #fff;
    background-color: var(--colour-ha-green);
}

.navbar-dark .navbar-toggler {
  border: 1px solid var(--colour-ha-pine);
}

.navbar-dark .navbar-toggler:hover {
  background-color: var(--colour-ha-green);
}

.navbar-dark .navbar-toggler:focus {
  background-color: var(--colour-ha-green);
}

.navbar-dark .navbar-nav .show.dropdown-menu {
  background-color: var(--colour-ha-green);
}

.navbar-dark .navbar-nav > li > a:focus {
  background-color: var(--colour-ha-green); 
}

.navbar-dark .navbar-nav > .dropdown > a.show .navbar-dark .navbar-nav > .dropdown > a.show:hover, 
.navbar-dark .navbar-nav > .dropdown > a.show:focus {
    background-color: var(--colour-ha-green); 
}

.navbar-dark .navbar-nav .show.dropdown-menu > li > a:hover,
.navbar-dark
  .navbar-nav
  .show.dropdown-menu
  > li
  > a:focus
  .navbar-dark
  .navbar-nav
  .show.dropdown-menu
  > .active
  > a,
.navbar-dark .navbar-nav .show.dropdown-menu > .active > a:hover,
.navbar-dark .navbar-nav .show.dropdown-menu > .active > a:focus {
  background-color: #ffffff;
  color: black;
}

.navbar-toggler {
  background-color: var(--colour-ha-green);
}

.navbar-toggler:focus {
  background-color: var(--colour-ha-pine);
}
/* ---------------------- */

/* Footer styling -------- */
footer {
  border-top: 2px solid var(--colour-ha-purple)
}

footer .footer-bottom
{
    background-color: unset;
}

footer .footer-bottom p {
    color: var(--font-color);
}

.footer-bottom {
    padding: 20px 0;
}

footer .footer-bottom p {
  font-size: 14px;
}

/* ---------------------- */

/* Page elements styling -------- */

.page-header-background {
  background-color: var(--colour-ha-pine);
}

.page-header-content {
  background-color: none;
  padding: 30px 20px 30px 0px;
  margin-bottom: 35px;
  color: white;
}

.page-header-content h1,
.page-header-content h2,
.page-header-content h3 {
  color: white;
}

.info-notice {
  margin-top: 1rem;
  margin-bottom: 1rem;
  background-color: lightgrey;
  border-left: 4px solid var(--colour-ha-purple);
  padding: 10px;
}
/* ---------------------- */

/* Buttons styling -------- */
.btn {
  padding: 5px 15px;
  border-radius: 0px;
  min-width: 150px;
}

.btn-primary, .btn-info {
  background-color: var(--colour-ha-green);
  border-color: var(--colour-ha-green);
}

.btn-primary:hover, .btn-info {
  background-color: var(--colour-ha-green);
  border-color: var(--colour-ha-green);
}

.btn-primary:active, 
.btn-primary:focus,
.btn-primary:focus-visible {
  background-color: var(--colour-ha-pine);
  border-color: var(--colour-ha-pine);
}

.btn-default, .btn-secondary {
  border: solid 2px var(--colour-ha-purple);
  color: var(--colour-ha-purple);
}

.btn-default, .btn-secondary:hover {
  border-color: var(--colour-ha-purple);
  color: var(--colour-ha-purple);
}

.btn-check:checked+.btn, 
.btn:first-child:active, 
:not(.btn-check)+.btn:active {
  background-color: var(--colour-ha-purple);
  border-color: var(--colour-ha-purple);
}

.btn:focus,.btn:focus-visible {
  outline: 5px auto var(--colour-ha-green);
}

/* ---------------------- */

/* Forms and lists styling -------- */
.crmEntityFormView,
.entitylist {
  border: none;
}

.form-control {
    font-weight: 300; 
}

input, textarea { 
  border-radius: 5px;
	padding: 5px;
}


.view-grid th {
  background-color: var(--colour-ha-ice30);
  padding: 10px 10px;
}

.crmEntityFormView .cell {
  padding: 0 10px 15px;
}

/* ---------------------- */

/* Radio input styling -------- */
/* Hide default radio */
.custom-radio input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

/* Custom radio container */
.custom-radio {
  display: flex;
  align-items: center;
  cursor: pointer;
  position: relative;
  padding-left: 30px;
  margin: 5px 0px;
  font-weight: 300;
}

/* Create the circle */
.radio-mark {
  position: absolute;
  top: 2px;
  left: 0;
  height: 20px;
  width: 20px;
  background-color: none;
  border-radius: 50%;
  border: 2px solid var(--colour-ha-dark-grey);
  transition: all 0.2s ease-in-out;
}

/* Checked state */
.custom-radio input:checked ~ .radio-mark {
  background-color: var(--colour-ha-purple);
  box-shadow: inset 0 0 0 2px white; /* Creates the inner circle */
}

/* Loading spinner -----*/
.spinner {
  border: 4px solid lightgrey;
  border-top: 4px solid var(--colour-ha-purple);
  border-radius: 50%;
  width: 50px;
  height: 50px;
  animation: spin 1s linear infinite;
  position: absolute;
  left: 50%;
  margin-top: -100px;
  margin-left: -25px;
}

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

.spinner-message {
  margin-top: 50px;
  text-align: center;
}

/* -- Alerts and notification --*/


.alert {
  border-radius: 0px;
  padding: 10px 10px 10px 15px;
}

.alert-info {
    --bs-alert-color: black;
    --bs-alert-bg: var(--colour-ha-ice);
    --bs-alert-border-color: none;
    border-left: 8px solid var(--colour-ha-purple);
  
}

/* ---------------------- */

/* Container */

/*
@media (min-width: 992px) {
    .container, .container-lg, .container-md, .container-sm {
        max-width: unset;
    }

  #content-container {
    padding-left: 25px;
    padding-right: 50px;
  }
}

@media (min-width: 768px) {
    .container, .container-md, .container-sm {
        max-width: unset;
    }

  #content-container {
    padding-left: 20px;
    padding-right: 15px;
  }
}

@media (min-width: 576px) {
    .container, .container-sm {
        max-width: unset;
    }
    #content-container {
      padding-left: 15px;
      padding-right: 15px;
    }
}
    */


    .profile-page-heading {
    font-weight: 600;
    font-size: 24px;
    letter-spacing: 0px !important;
    padding-left: 20px;
}

legend{
  border-bottom: 0px;
}

input.form-control, .form-select, .msos-container:not(.msos-disabled) {
    border: 1px solid #242424;
}

.crmEntityFormView .cell .field-label{
  margin-bottom: 8px;
}

.text-primary{
  color: var(--colour-ha-green) !important;
}

.list-group {
    gap: 5px;
}

.card-body img {
    display: none;
}

.userFullName{
  padding-top: 0px;
  display: flex;
  width: 100%;
  gap: 15px;
  align-items: center;
}

.userFullName:before {
    content: "\f2bd";
    display: block;
    font-family: 'FontAwesome';
    font-size: 30PX;
    color: var(--font-color);
}

a.weblink.list-group-item, .list-group-item+.list-group-item {
    border: solid 1px #ccc;
}

.mb-3.profile-info {
    margin-bottom: 5px !important;
}

label {
    font-weight: 500;
}

#ProfileFormView .cell {
    padding: 0 20px 25px;
}

.breadcrumb{
  display: none;
} 

#ProfileFormView .section-title h3 {
    font-size: 24px;
    margin-left: 20px;
    margin-bottom: 20px;
}

td.clearfix.cell:empty {
    display: none;
}

.card-title{
  margin-bottom: 0px;
}

.card-title {
    gap: 10px;
    display: flex;
}

.card.nav-profile {
    border: none;
}

.card-header {
    margin-bottom: 5px;
    background-color: var(--colour-ha-ice);
    color: var(--font-color);
}

.card-body{
  color: var(--font-color);
  BACKGROUND-COLOR: var(--colour-ha-ice);
}

.col-lg-8 .actions {
    margin-left: 20px;
    margin-bottom: 60px;
}

html[dir=ltr] .msos-selected-display-item {
    background-color: var(--colour-ha-ice);
}

.table-striped>tbody>tr:nth-of-type(odd)>*{
  --bs-table-accent-bg: unset;
}

.table>thead {
    vertical-align: bottom;
    background-color: var(--colour-ha-ice);
}

.grid-actions{
  border-bottom: none;
}

thead a:not(.btn) {
    color: var(--font-color);
    text-decoration: none;
    font-weight: 500;
}

/* -- Modal bootstrap --*/

.ui-dialog {
  border-radius: 8px;
  border: none;
  box-shadow:
    0 4px 12px rgba(0, 0, 0, 0.08),
    0 2px 2px rgba(0, 0, 0, 0.04);
}

.ui-dialog-titlebar {
  border-radius: 0;
  border: none;
  border-bottom: 1px solid lightgray;
}

.ui-dialog-buttonset button {
  font-size: 16px;
  font-weight: 300;
}