:root {
  --color-primary: #007F6C;
  --color-secondary: #8AD7B3;
  --color-success: #A8E6A3;
  --color-danger: #F28B82;
  --color-warning: #FFD97D;
  --color-info: #81D4FA;

  --color-background: #F9FCFA;
  --color-sidemenu-bg: #00564D;
  --color-sidemenu-text: #FFFFFF;
  --color-navbar-top-bg: #8AD7B3;
  --color-navbar-top-text: #00473F;
  --color-navbar-bottom-bg: #007F6C;
  --color-navbar-bottom-text: #FFFFFF;
}

.bg-primary {
  background-color: var(--color-primary) !important;
}

.bg-secondary {
  background-color: var(--color-secondary) !important;
  color: #00473F;
  font-weight: normal;
}

body {
  background-color: var(--color-background);
  color: #333;
  padding-top: 56px; /* espace pour ne pas masquer le contenu */
}

.navbar-top {
  background-color: var(--color-navbar-top-bg);
  color: var(--color-navbar-top-text);
}

.navbar-bottom {
  background-color: var(--color-navbar-bottom-bg);
  color: var(--color-navbar-bottom-text);
}

.sidebar {
  background-color: var(--color-sidemenu-bg);
  color: var(--color-sidemenu-text);
}

/* Boutons personnalisés */
.btn-primary {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

.btn-secondary {
  background-color: var(--color-secondary);
  border-color: var(--color-secondary);
  color: #00473F;
}

.btn-success {
  background-color: var(--color-success);
  border-color: var(--color-success);
  color: #004D00;
}

.btn-danger {
  background-color: var(--color-danger);
  border-color: var(--color-danger);
  color: #600000;
}

.btn-warning {
  background-color: var(--color-warning);
  border-color: var(--color-warning);
  color: #664400;
}

.btn-info {
  background-color: var(--color-info);
  border-color: var(--color-info);
  color: #003344;
}

/* Alertes */
.alert-primary {
  background-color: #D8F5E4;
  border-color: var(--color-secondary);
  color: #00473F;
}

.alert-success {
  background-color: #EAF7EA;
  border-color: var(--color-success);
  color: #004D00;
}

.alert-danger {
  background-color: #FDECEA;
  border-color: var(--color-danger);
  color: #600000;
}

.alert-warning {
  background-color: #FFF8E1;
  border-color: var(--color-warning);
  color: #664400;
}

.alert-info {
  background-color: #E0F7FF;
  border-color: var(--color-info);
  color: #003344;
}


.container {
    background-color: var(--color-background);
  color: #333;
}
.navbar-custom {
    height: 56px;
    background-color: #FFF3E0;
    color: var(--color-navbar-top-text);
}
.navbar-custom .navbar-brand {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}
.bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    border-top: 1px solid #ddd;
    z-index: 1030;
    background-color: var(--color-navbar-bottom-bg);
}
.bottom-nav .nav-link {
    color: var(--color-navbar-bottom-text);
    font-size: 15px;
}
.bottom-nav .nav-link.active {
    color: #0d6efd;
}
.navbar-custom {
  background-color: var(--color-navbar-top-bg);  /* #e9a223; : orange personnalisé */
  color: white;
}
.navbar-custom .navbar-brand,
.navbar-custom .btn,
.navbar-custom .navbar-toggler-icon {
  color: white;
  filter: brightness(100);
}
.text-icon {
    font-size: 15px;
}
  .event-card {
    margin-bottom: 10px;
  }

  .event-date {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: #007bff;
    color: white;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    font-weight: bold;
    font-size: 0.8rem;
    margin-top: 5px;
  }

  .event-date .day {
    font-size: 1.2rem;
    line-height: 1;
  }

  .event-date .month {
    text-transform: uppercase;
    font-size: 0.8rem;
    line-height: 1;
  }

  .event-image {
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 0.375rem;
    display: block;
  }
.fixed-bottom {
  padding-bottom: calc(env(safe-area-inset-bottom) + 10px);
}

#menuOffcanvas,
#menuOffcanvas .offcanvas-body,
#menuOffcanvas .offcanvas-header,
#menuOffcanvas .list-group,
#menuOffcanvas .list-group-item {
    background-color: var(--color-sidemenu-bg) !important;
    color: var(--color-sidemenu-text) !important;
  }