body {
    background-color: var(--hp-color-white);
    color: var(--hp-color-text-default);
    font-family: var(--bs-body-font-family);
}

/* Lot 10: legacy utility bridge to reduce style.css coupling. */
.gray-bg,
.bg-muted {
    background-color: var(--hp-color-surface-200) !important;
}

/* Keep the application canvas flat/white even with legacy gray-bg class. */
#page-wrapper.gray-bg {
    background-color: var(--hp-color-white) !important;
}

.white-bg {
    background-color: var(--hp-color-white) !important;
}

.bg-primary,
.navy-bg {
    background-color: var(--hp-color-green) !important;
    color: var(--hp-color-white) !important;
}

.bg-success,
.blue-bg {
    background-color: var(--hp-color-blue) !important;
    color: var(--hp-color-white) !important;
}

.bg-info,
.lazur-bg {
    background-color: var(--hp-color-info-strong) !important;
    color: var(--hp-color-white) !important;
}

.bg-warning,
.yellow-bg {
    background-color: var(--hp-color-brand-orange) !important;
    color: var(--hp-color-white) !important;
}

.bg-danger,
.red-bg {
    background-color: var(--hp-color-red) !important;
    color: var(--hp-color-white) !important;
}

/* Global heading scale to keep typography consistent across themes. */
body h1, body .h1 {
    font-size: 2rem;
    font-family: var(--hp-font-strong);
}

body h2, body .h2 {
    font-size: 1.65rem;
    font-family: var(--hp-font-strong);
}

body h3, body .h3 {
    font-size: 1.35rem;
    font-family: var(--hp-font-strong);
}

body h4, body .h4 {
    font-size: 1.1rem;
    font-family: var(--hp-font-strong);
}

body h5, body .h5 {
    font-size: 0.85rem;
    font-family: var(--hp-font-strong);
}

body h6, body .h6 {
    font-size: 0.8rem;
    font-family: var(--hp-font-strong);
}

body b,
body strong,
body th,
body .fw-semibold,
body .fw-bold {
    font-family: var(--hp-font-strong);
}

/* Ensure Bootstrap breadcrumb variable is always resolved. */
body .breadcrumb {
    --bs-breadcrumb-font-size: 13px;
}

body .breadcrumb-item > a,
body .breadcrumb-item > a:hover,
body .breadcrumb-item > a:focus,
body .breadcrumb-item > a:active {
    color: var(--hp-color-white);
    text-decoration: none;
}

/* Component baseline (Lot 2): unified links/buttons/forms/alerts/tables. */
#page-wrapper a {
    color: var(--bs-link-color);
}

#page-wrapper a:hover,
#page-wrapper a:focus {
    color: var(--bs-link-hover-color);
}

/* Carded table sections (shared across pages like Expenses/Contracts). */
#page-wrapper .expenses-table-wrapper {
    padding: 10px;
}

#page-wrapper .expenses-index-section {
    border: 1px solid var(--hp-color-border-default);
    border-radius: 6px;
    overflow: hidden;
    background-color: var(--hp-color-white);
    margin-bottom: 0.65rem;
}

#page-wrapper .expenses-index-section-header {
    background-color: var(--hp-color-surface-100);
    border-bottom: 1px solid var(--hp-color-border-default);
    padding: 0.55rem 0.9rem;
}

#page-wrapper .expenses-index-section-header h3 {
    margin: 0;
    font-size: 0.95rem;
}

#page-wrapper .expenses-index-section-toggle {
    color: var(--hp-color-text-subtle);
    text-decoration: none;
    font-weight: 600;
}

#page-wrapper .expenses-index-section-toggle:hover,
#page-wrapper .expenses-index-section-toggle:focus {
    color: var(--hp-color-dark-blue);
    text-decoration: none;
}

#page-wrapper .expenses-index-section .table {
    margin-bottom: 0;
}

#page-wrapper .expenses-index-section .card-body {
    padding: 0.6rem 0.8rem 0.75rem !important;
}

#page-wrapper .expenses-index-section .dataTables_wrapper .dt-toolbar,
#page-wrapper .expenses-index-section .dataTables_wrapper .dt-footer {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
}

#page-wrapper .btn {
    border-radius: var(--hp-radius-sm);
    font-size: 0.85rem;
    font-weight: 600;
    transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

#page-wrapper .btn:focus,
#page-wrapper .btn:focus-visible {
    box-shadow: var(--hp-shadow-focus);
}

#page-wrapper .btn-primary {
    background-color: var(--hp-color-blue);
    border-color: var(--hp-color-blue);
    color: var(--hp-color-white);
}

#page-wrapper .btn-primary:hover,
#page-wrapper .btn-primary:focus {
    background-color: #1A55E6; /* lighter than --hp-color-blue for better legibility */
    border-color: #1A55E6;
}

/* Anchor buttons: prevent link hover color overriding btn styles. */
#page-wrapper a.btn.btn-primary:hover,
#page-wrapper a.btn.btn-primary:focus {
    color: var(--hp-color-white);
    text-decoration: none;
}

/* Global fallback for pages rendering buttons outside #page-wrapper. */
.btn-primary:hover,
.btn-primary:focus {
    background-color: #1A55E6;
    border-color: #1A55E6;
    color: var(--hp-color-white);
}

/* Warning buttons: make hover visibly darker while keeping contrast. */
#page-wrapper .btn-warning {
    background-color: var(--hp-color-yellow);
    border-color: var(--hp-color-yellow);
    color: var(--hp-color-dark-blue);
}

#page-wrapper .btn-warning:hover,
#page-wrapper .btn-warning:focus {
    background-color: #D9BD00; /* slightly darker yellow */
    border-color: #D9BD00;
    color: var(--hp-color-dark-blue);
}

.btn-warning {
    background-color: var(--hp-color-yellow);
    border-color: var(--hp-color-yellow);
    color: var(--hp-color-dark-blue);
}

.btn-warning:hover,
.btn-warning:focus {
    background-color: #D9BD00;
    border-color: #D9BD00;
    color: var(--hp-color-dark-blue);
}

#page-wrapper .btn-outline-primary {
    color: var(--hp-color-blue);
    border-color: var(--hp-color-blue);
}

#page-wrapper .btn-outline-primary:hover,
#page-wrapper .btn-outline-primary:focus {
    color: var(--hp-color-white);
    background-color: var(--hp-color-blue);
    border-color: var(--hp-color-blue);
}

#page-wrapper .btn-outline-info {
    color: var(--hp-color-blue);
    border-color: var(--hp-color-blue);
}

/* Softer hover on white backgrounds (keeps "outline" intent). */
#page-wrapper .btn-outline-info:hover,
#page-wrapper .btn-outline-info:focus {
    color: var(--hp-color-blue);
    background-color: rgba(0, 61, 194, 0.12); /* --hp-color-blue with gentle alpha */
    border-color: var(--hp-color-blue);
    text-decoration: none;
}

#page-wrapper .form-control,
#page-wrapper .form-select,
#page-wrapper .input-group-text {
    border-color: var(--hp-color-border-default);
    border-radius: var(--hp-radius-sm);
}

#page-wrapper .form-control:focus,
#page-wrapper .form-select:focus {
    border-color: var(--hp-color-focus-border);
    box-shadow: var(--hp-shadow-focus);
}

#page-wrapper .alert {
    border-radius: var(--hp-radius-md);
    border: 1px solid var(--hp-color-border-default);
    font-size: 0.85rem;
}

#page-wrapper .alert-info {
    color: var(--hp-color-text-subtle);
    background-color: var(--hp-color-light-blue);
    border-color: var(--hp-color-border-default);
}

#page-wrapper .alert-success {
    color: var(--hp-color-text-subtle);
    background-color: var(--hp-color-success-soft);
    border-color: var(--hp-color-border-default);
}

#page-wrapper .alert-warning {
    color: var(--hp-color-text-subtle);
    background-color: var(--hp-color-warning-soft);
    border-color: var(--hp-color-border-default);
}

#page-wrapper .alert-danger {
    color: var(--hp-color-text-subtle);
    background-color: var(--hp-color-danger-soft);
    border-color: var(--hp-color-border-default);
}

/* Global form typography normalization after Bootstrap migration. */
#page-wrapper form .control-label,
#page-wrapper form .form-label,
#page-wrapper form .form-control,
#page-wrapper form .form-select {
    font-size: 0.85rem;
}

/* Keep legacy btn-info palette used across pages. */
#page-wrapper .btn-info {
    color: var(--hp-color-white);
    background-color: var(--hp-color-info-strong);
    border-color: var(--hp-color-info-strong);
}

/* Select2 global skin aligned with Bootstrap 5 form-select. */
#page-wrapper .select2-container {
    width: 100% !important;
    font-size: 0.85rem;
}

#page-wrapper .select2-container--default .select2-selection--single {
    height: calc(1.5em + 0.75rem + 2px);
    min-height: calc(1.5em + 0.75rem + 2px);
    border: 1px solid var(--hp-color-border-default);
    border-radius: 0.375rem;
    background-color: var(--hp-color-white);
    box-sizing: border-box;
}

#page-wrapper .select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--hp-color-text-body);
    line-height: 1.5;
    padding-left: 0.75rem;
    padding-right: 2rem;
    padding-top: 0.375rem;
    padding-bottom: 0.375rem;
}

#page-wrapper .select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: var(--hp-color-text-muted);
}

#page-wrapper .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: calc(1.5em + 0.75rem + 2px);
    width: 2rem;
    right: 0;
}

#page-wrapper .select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: var(--hp-color-text-muted) transparent transparent transparent;
    border-width: 5px 4px 0 4px;
}

#page-wrapper .select2-container--default.select2-container--open .select2-selection--single {
    border-color: var(--hp-color-focus-border);
    box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25);
    outline: 0;
}

#page-wrapper .select2-container--default.select2-container--disabled .select2-selection--single {
    background-color: var(--hp-color-surface-300);
    border-color: var(--hp-color-border-default);
    opacity: 1;
}

#page-wrapper .select2-container--default.select2-container--disabled .select2-selection__rendered {
    color: var(--hp-color-text-muted);
}

#page-wrapper .select2-dropdown {
    border: 1px solid var(--hp-color-border-default);
    border-radius: 0.375rem;
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.12);
    font-size: 0.85rem;
}

#page-wrapper .select2-results__option {
    padding: 0.375rem 0.75rem;
}

#page-wrapper .select2-container--default .select2-results__option--highlighted[aria-selected] {
    background-color: var(--hp-color-blue);
    color: var(--hp-color-white);
}

#page-wrapper .select2-container--default .select2-selection--multiple {
    min-height: calc(1.5em + 0.75rem + 2px);
    border: 1px solid var(--hp-color-border-default);
    border-radius: 0.375rem;
    padding: 0.15rem 0.25rem;
}

/* Global form spacing for BS5 layouts. */
#page-wrapper form .row {
    --bs-gutter-y: 0.75rem;
}

#page-wrapper form .d-flex.flex-wrap {
    gap: 0.75rem;
}

/* Flatpickr global styling (icon + highlighted weekdays compatibility). */
#page-wrapper input.app-date-input {
    padding-right: 2rem;
    background-image: url("/icons/calendar.svg");
    background-repeat: no-repeat;
    background-position: right 0.55rem center;
    background-size: 0.95rem 0.95rem;
}

.flatpickr-day.app-fp-highlight-day {
    background-color: var(--hp-color-surface-highlight);
    border-color: var(--hp-color-surface-highlight);
}

#wrapper {
    width: 100%;
    overflow-x: hidden;
}

.gray-bg {
    background-color: var(--hp-color-white);
}

.fixed-sidebar .navbar-static-side {
    position: fixed;
    width: 220px;
    height: 100%;
    z-index: 2001;
}

#page-wrapper {
    margin: 0 0 0 220px;
    min-height: 100vh;
    padding: 0 15px;
    background-color: var(--hp-color-white);
}

.wrapper {
    padding: 0 10px;
}

.wrapper-content {
    padding: 20px 10px 40px;
}

.page-heading {
    border-top: 0;
    padding: 0 10px 20px;
}

.border-bottom {
    border-bottom: 1px solid var(--hp-color-border-soft);
}

/* User-selected heading theme colors previously provided by style.css. */
.bg-red {
    background-color: var(--hp-color-brand-maroon) !important;
    color: var(--hp-color-white);
}

.bg-orange {
    background-color: var(--hp-color-brand-orange) !important;
    color: var(--hp-color-white);
}

.bg-yellow {
    background-color: var(--hp-color-yellow) !important;
    color: var(--hp-color-black);
}

.bg-white {
    background-color: var(--hp-color-surface-200) !important;
    color: var(--hp-color-black);
}

.bg-green {
    background-color: var(--hp-color-brand-green-dark) !important;
    color: var(--hp-color-white);
}

.bg-blue {
    background-color: var(--hp-color-brand-blue-mid) !important;
    color: var(--hp-color-white);
}

.bg-black {
    background-color: var(--hp-color-black) !important;
    color: var(--hp-color-white);
}

.bg-default {
    background-color: var(--hp-color-brand-teal-dark) !important;
    color: var(--hp-color-white);
}

.navbar-static-side,
.navbar-default {
    background-color: var(--hp-color-dark-blue);
    border-color: var(--hp-color-dark-blue);
}

.navbar-static-side .nav > li > a,
.navbar-default .nav > li > a {
    color: var(--hp-color-white);
    padding: 8px 16px 8px 20px;
    font-weight: 600;
    font-size: 0.95rem;
    display: block;
    width: 100%;
    text-decoration: none;
    white-space: nowrap;
}

.navbar-static-side .nav > li > a:hover,
.navbar-static-side .nav > li > a:focus,
.navbar-static-side .nav > li.active > a,
.navbar-default .nav > li > a:hover,
.navbar-default .nav > li > a:focus,
.navbar-default .nav > li.active > a {
    color: var(--hp-color-white);
    background-color: rgba(255, 255, 255, 0.08);
    text-decoration: none;
}

.navbar-static-side .nav > li,
.navbar-default .nav > li {
    display: block;
    width: 100%;
    margin: 0;
}

.nav-header-admin {
    padding-top: 25px;
    background: var(--hp-color-dark-blue);
}

.nav-header {
    padding: 30px 20px 16px;
    background: var(--hp-color-dark-blue);
}

.nav-header a {
    color: var(--hp-color-white);
    font-weight: 500;
    font-size: 0.85rem;
}

.nav-label {
    margin-left: 0;
}

.profile-element {
    color: var(--hp-color-white);
}

.sidebar-collapse .nav {
    padding-left: 0;
    list-style: none;
}

.sidebar-collapse #side-menu {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    margin: 0;
    padding: 0;
}

.sidebar-collapse #side-menu > li:not(.nav-header):not(.nav-sidebar-spacer):not(.nav-footer-user-container) > a > i.fa {
    display: none;
}

.sidebar-collapse #side-menu > li.nav-sidebar-spacer {
    flex: 1 1 auto;
    min-height: 0;
    margin: 0;
    padding: 0;
    list-style: none;
}

.sidebar-collapse #side-menu > li.nav-header + li:not(.nav-sidebar-spacer):not(.nav-footer-user-container) {
    margin-top: 36px;
}

.logo-element {
    display: none;
    padding: 18px 0;
    text-align: center;
    font-size: 18px;
    font-weight: 600;
    color: var(--hp-color-white);
}

.nav-logo {
    width: 132px;
    max-width: 100%;
    display: block;
    margin: 0 auto;
}

.nav-user-block {
    text-align: center;
}

/* Desktop: anchor user block at the bottom of sidebar. */
@media (min-width: 768px) {
    .nav-footer-user-container {
        margin-top: auto;
        padding: 0 20px 16px;
        list-style: none;
    }

    .nav-footer-user-container .nav-user-block {
        margin: 0;
    }
}

.nav-user-block .nav-user-name {
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.2;
    color: var(--hp-color-white);
    margin-bottom: 2px;
}

.nav-user-block .nav-user-number {
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1.2;
    color: rgba(255, 255, 255, 0.88);
    margin-bottom: 6px;
}

.nav-user-block .block,
.nav-user-block .nav-user-name,
.nav-user-block .nav-user-number {
    display: block;
    width: 100%;
    text-align: center;
}

.nav-user-block a {
    display: block;
    width: 100%;
    text-align: center;
    font-size: 0.9rem;
    line-height: 1.2;
}

.nav-user-block a.nav-logout-link,
.nav-user-block a.nav-logout-link:link,
.nav-user-block a.nav-logout-link:visited,
.nav-user-block a.nav-logout-link:hover,
.nav-user-block a.nav-logout-link:focus,
.nav-user-block a.nav-logout-link:active {
    color: rgba(255, 255, 255, 0.92);
    font-size: 0.85rem;
    font-weight: 400;
    text-decoration: none;
}

.ibox {
    clear: both;
    margin-bottom: 25px;
    margin-top: 0;
    padding: 0;
    background: transparent;
}

.ibox-title {
    background-color: transparent;
    border: 0;
    padding: 14px 15px 7px;
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.ibox-title h5 {
    margin: 0;
}

.ibox-tools {
    float: none;
    display: flex;
    align-items: center;
}

.ibox-tools a {
    display: inline-flex;
    align-items: center;
}

.ibox-content {
    background-color: var(--hp-color-light-blue);
    border-radius: var(--hp-radius-md);
    color: inherit;
    padding: 15px 20px 20px;
    border: 0;
}

/* Reusable ibox visual variants (apply on .ibox so title is included). */
.ibox.transparent-style .ibox-title,
.ibox.transparent-style .ibox-content {
    background-color: transparent;
}

.ibox.yellow-style .ibox-title,
.ibox.yellow-style .ibox-content {
    background-color: var(--hp-home-feature-bg, #FFF6CF);
}

.ibox.blue-style .ibox-title,
.ibox.blue-style .ibox-content {
    background-color: var(--hp-color-light-blue);
}

.ibox.red-style .ibox-title,
.ibox.red-style .ibox-content {
    background-color: var(--hp-color-danger-soft, #F8D7DA);
}

.ibox.transparent-border-style {
    border: 1px solid var(--hp-color-border-soft);
    border-radius: var(--hp-radius-md);
    overflow: hidden; /* ensures title/content follow the rounded border */
}

.ibox.transparent-border-style .ibox-title,
.ibox.transparent-border-style .ibox-content {
    background-color: transparent;
}

/* Compact typography inside ibox panels. */
.ibox,
.ibox-title h5,
.ibox-content {
    font-size: 0.85rem;
}

/* Shared "activity list" styling. */
#page-wrapper .app-activity-list {
    max-width: 600px;
    float: none;
    margin: 0 auto;
}

#page-wrapper .app-activity-item {
    color: var(--hp-color-dark-blue);
    margin: 0;
    padding: 0.7rem 0.95rem;
    line-height: 1.35;
    font-size: 0.82rem;
    display: flex;
    align-items: center; /* vertical centering */
    gap: 0.5rem;
}

#page-wrapper .app-activity-item__text {
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#page-wrapper .app-activity-item__actions {
    flex: 0 0 auto;
    width: 180px;
    display: flex;
    justify-content: flex-end;
    gap: 0.4rem;
    white-space: nowrap;
}

/* Badges are action buttons. */
#page-wrapper .app-activity-item__actions > .badge {
    line-height: 1.2;
    padding: 0.38rem 0.62rem;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 600;
    text-decoration: none;
    transition: transform 0.15s ease, filter 0.15s ease, box-shadow 0.15s ease;
}

#page-wrapper .app-activity-item__actions > .badge.bg-info {
    background-color: var(--hp-color-blue) !important;
    color: var(--hp-color-white) !important;
}

#page-wrapper .app-activity-item__actions > .badge.bg-danger {
    background-color: var(--hp-color-red) !important;
    color: var(--hp-color-white) !important;
}

#page-wrapper .app-activity-item__actions > .badge:hover,
#page-wrapper .app-activity-item__actions > .badge:focus {
    filter: brightness(0.95);
    transform: translateY(-1px);
    box-shadow: var(--hp-shadow-sm);
    text-decoration: none;
}

#page-wrapper .app-activity-badge-gap {
    margin-left: 5px;
}

/* Global table density normalization after Bootstrap migration. */
#page-wrapper .table,
#page-wrapper table.dataTable {
    font-size: 0.82rem;
    line-height: 1.3;
    color: var(--hp-color-dark-blue);
    border: 1px solid var(--hp-color-border-soft);
    border-radius: var(--hp-radius-sm);
}

#page-wrapper .table > :not(caption) > * > *,
#page-wrapper table.dataTable > :not(caption) > * > * {
    padding: 0.55rem 0.75rem;
    vertical-align: middle;
}

/* Some legacy views render tables outside #page-wrapper (e.g. modals/partials). */
.table > :not(caption) > * > *,
table.dataTable > :not(caption) > * > * {
    vertical-align: middle;
}

#page-wrapper table.dataTable thead th {
    font-weight: 600;
    white-space: nowrap;
    color: var(--hp-color-dark-blue);
    background-color: var(--hp-color-surface-100);
    border: 0;
}

#page-wrapper table.dataTable tbody td,
#page-wrapper table.dataTable tbody td span {
    color: var(--hp-color-dark-blue);
    border: 0;
}

/* No internal separators (keep only outer table border). */
#page-wrapper table.dataTable thead th:last-child,
#page-wrapper table.dataTable tbody td:last-child {
    border-right: 0;
}

/* Non-DataTables tables: keep a single horizontal separator between rows. */
#page-wrapper .table thead th {
    font-weight: 600;
    color: var(--hp-color-dark-blue);
    background-color: var(--hp-color-surface-100);
    border-bottom: 1px solid var(--hp-color-border-soft);
}

#page-wrapper .table tbody td {
    color: var(--hp-color-dark-blue);
    border-top: 0;
    border-bottom: 1px solid var(--hp-color-border-soft);
}

#page-wrapper .table tbody tr:last-child > td {
    border-bottom: 0;
}

/* DataTables zebra-striping: white / light-blue. */
#page-wrapper table.dataTable tbody tr.even > * {
    background-color: var(--hp-color-white);
}

#page-wrapper table.dataTable tbody tr.odd > * {
    background-color: var(--hp-color-light-blue);
}

#page-wrapper table.dataTable tbody tr:hover > * {
    /* Option A: subtle overlay, keeps zebra background intact. */
    box-shadow: inset 0 0 0 9999px rgba(26, 44, 78, 0.06);
}

#page-wrapper .dataTables_wrapper .dataTables_length label,
#page-wrapper .dataTables_wrapper .dataTables_filter label,
#page-wrapper .dataTables_wrapper .dataTables_info,
#page-wrapper .dataTables_wrapper .dataTables_paginate {
    font-size: 0.85rem;
    color: var(--hp-color-text-default);
}

#page-wrapper .dataTables_wrapper .dataTables_length select,
#page-wrapper .dataTables_wrapper .dataTables_filter input {
    font-size: 0.85rem;
    line-height: 1.2;
    height: calc(1.5em + 0.4rem + 2px);
}

#page-wrapper .dataTables_wrapper .dataTables_length select.form-select {
    width: auto;
    display: inline-block;
}

#page-wrapper .dataTables_wrapper .dataTables_paginate .pagination {
    margin: 0;
}

/* Pagination (Bootstrap / DataTables) */
#page-wrapper .pagination {
    --bs-pagination-color: var(--hp-color-blue);
    --bs-pagination-bg: var(--hp-color-white);
    --bs-pagination-border-color: var(--hp-color-border-default);
    --bs-pagination-hover-color: var(--hp-color-blue);
    --bs-pagination-hover-bg: rgba(0, 61, 194, 0.08); /* subtle blue tint */
    --bs-pagination-hover-border-color: var(--hp-color-blue);
    --bs-pagination-focus-color: var(--hp-color-blue);
    --bs-pagination-focus-bg: rgba(0, 61, 194, 0.12);
    --bs-pagination-focus-box-shadow: var(--hp-shadow-focus);
    --bs-pagination-active-color: var(--hp-color-white);
    --bs-pagination-active-bg: var(--hp-color-blue);
    --bs-pagination-active-border-color: var(--hp-color-blue);
    --bs-pagination-disabled-color: var(--hp-color-text-muted);
    --bs-pagination-disabled-bg: var(--hp-color-white);
    --bs-pagination-disabled-border-color: var(--hp-color-border-default);
}

/* Force readable active page number (some DataTables/Bootstrap combos override vars) */
#page-wrapper .page-item.active .page-link,
#page-wrapper .pagination .active > .page-link,
#page-wrapper .pagination .page-link.active {
    color: var(--hp-color-white) !important;
    background-color: var(--hp-color-blue) !important;
    border-color: var(--hp-color-blue) !important;
}

#page-wrapper .dataTables_wrapper .dataTables_paginate .paginate_button,
#page-wrapper .dataTables_wrapper .dataTables_paginate .page-link {
    font-size: 0.8rem;
    line-height: 1.2;
}

#page-wrapper .dataTables_wrapper .dt-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 1rem;
    padding-top: 2px;
}

#page-wrapper .dataTables_wrapper table.dataTable {
    margin-top: 0 !important;
    margin-bottom: 0.5rem !important;
}

#page-wrapper .dataTables_wrapper .dt-toolbar-left,
#page-wrapper .dataTables_wrapper .dt-toolbar-right {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

#page-wrapper .dataTables_wrapper .dt-toolbar .dataTables_filter,
#page-wrapper .dataTables_wrapper .dt-toolbar .dt-buttons,
#page-wrapper .dataTables_wrapper .dt-toolbar .dataTables_length,
#page-wrapper .dataTables_wrapper .dt-toolbar .dataTables_info {
    float: none;
    margin: 0;
}

#page-wrapper .dataTables_wrapper .dt-toolbar .dataTables_filter label {
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

#page-wrapper .dataTables_wrapper .dt-toolbar .dt-buttons {
    display: inline-flex;
    align-items: center;
}

#page-wrapper .dataTables_wrapper .dt-toolbar .dt-buttons .btn,
#page-wrapper .dataTables_wrapper .dt-toolbar .dt-buttons .dt-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: calc(1.5em + 0.4rem + 2px);
    padding: 0.2rem 0.45rem;
    font-size: 0.8rem;
    line-height: 1.2;
    border: 1px solid var(--hp-color-border-default);
    background-color: var(--hp-color-surface-200);
    color: var(--hp-color-text-default);
    box-shadow: none;
}

#page-wrapper .dataTables_wrapper .dt-toolbar .dt-buttons .btn:hover,
#page-wrapper .dataTables_wrapper .dt-toolbar .dt-buttons .dt-button:hover,
#page-wrapper .dataTables_wrapper .dt-toolbar .dt-buttons .btn:focus,
#page-wrapper .dataTables_wrapper .dt-toolbar .dt-buttons .dt-button:focus {
    background-color: var(--hp-color-surface-300);
    border-color: var(--hp-color-border-default);
    color: var(--hp-color-text-subtle);
}

#page-wrapper .dataTables_wrapper .dt-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-top: 0.6rem;
}

#page-wrapper .dataTables_wrapper .dt-footer .dataTables_info,
#page-wrapper .dataTables_wrapper .dt-footer .dataTables_paginate {
    float: none;
    margin: 0;
}

@media (max-width: 991.98px) {
    #page-wrapper .dataTables_wrapper .dt-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    #page-wrapper .dataTables_wrapper .dt-toolbar-right {
        justify-content: space-between;
        flex-wrap: wrap;
    }

    #page-wrapper .dataTables_wrapper .dt-footer {
        flex-direction: column;
        align-items: flex-start;
    }
}

.footer.fixed {
    position: fixed;
    bottom: 0;
    left: 220px;
    right: 0;
    background: var(--hp-color-white);
    border-top: 1px solid var(--hp-color-border-soft);
    padding: 10px 20px;
    z-index: 1000;
}

/* Avoid desktop blank scroll area with fixed footer. */
@media (min-width: 768px) {
    #page-wrapper {
        min-height: calc(100vh - 44px);
    }
}

.minimalize-styl-2 {
    margin: 14px 5px 5px 20px;
}

.text-title {
    font-size: 28px;
    font-weight: 600;
    color: var(--hp-color-blue);
}

h2.text-title {
    color: var(--hp-color-white);
    font-size: 24px;
    margin-top: 20px;
    margin-bottom: 10px;
}

.btn-google {
    border: 1px solid var(--hp-color-border-default);
    background-color: var(--hp-color-white);
    color: var(--hp-color-text-strong);
    font-weight: 500;
    min-width: 150px;
    box-shadow: 0 1px 2px 1px rgba(0, 0, 0, 0.08);
}

/* Legacy "OR" separator used on login flows (migrated from style.css). */
.or-container {
    display: flex;
    align-items: center;
    margin: 15px 0;
    color: var(--hp-color-border-default);
}

.line-separator {
    flex-grow: 5;
    height: 1px;
    background-color: var(--hp-color-border-default);
}

.or-label {
    flex-grow: 1;
    margin: 0 10px;
    text-align: center;
}

/* Shared large button sizing for consistent UI across pages. */
.btn.btn-lg,
.btn-group-lg > .btn {
    padding: 0.35rem 0.75rem;
    font-size: 0.95rem;
    line-height: 1.2;
}

.nav-center {
    text-align: center;
}

.nav-logo {
    width: 132px;
    max-width: 100%;
}

.nav-welcome {
    color: var(--hp-color-white);
}

.nav-admin-label {
    margin-left: 20px;
    color: var(--hp-color-light-gray);
}

.footer-inline {
    margin: 0 !important;
    color: var(--hp-color-text-muted);
    font-size: 0.85rem;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: nowrap;
    white-space: nowrap;
}

.footer-inline a {
    text-decoration: none;
}

.footer-inline a:hover,
.footer-inline a:focus {
    color: var(--hp-color-text-subtle);
}

.footer-language,
.footer-language-form {
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    color: var(--hp-color-text-muted);
    font-size: 0.85rem;
}

.footer-language-form {
    margin: 0 !important;
    gap: 0.35rem;
}

.footer-language-select {
    max-width: 120px;
    height: 28px;
    padding: 2px 6px;
    font-size: 0.85rem;
    line-height: 1.2;
    color: var(--hp-color-text-muted);
}

.footer-language-select {
    max-width: 120px;
    height: 28px;
    padding: 2px 6px;
    font-size: 0.85rem;
    line-height: 1.2;
    color: var(--hp-color-text-muted);
}

.app-panel-lg {
    padding: 24px;
    border-radius: 0;
    background-color: transparent;
    border: 0;
}

.app-panel {
    min-height: 20px;
    padding: 19px;
    margin-bottom: 20px;
    background-color: transparent;
    border: 0;
    border-radius: 0;
}

/* Legacy layout helpers kept during BS5 transition. */
.middle-box {
    max-width: 400px;
    z-index: 100;
    margin: 0 auto;
    padding-top: 40px;
}

.loginscreen.middle-box {
    width: 300px;
}

.wrapper .middle-box {
    margin-top: 140px;
}

.ibox-tools {
    display: block;
    float: none;
    margin-top: 0;
    position: absolute;
    top: 15px;
    right: 15px;
    padding: 0;
    text-align: right;
}

.ibox-tools a {
    cursor: pointer;
    margin-left: 5px;
    color: var(--hp-color-icon-muted) !important;
}

.ibox-tools a.btn-primary {
    color: var(--hp-color-white) !important;
}

.ibox.fullscreen .collapse-link {
    display: none;
}

.form-control[readonly] {
    background-color: var(--hp-color-white);
    border-color: var(--hp-color-border-muted);
    color: var(--hp-color-text-muted);
    cursor: default;
    box-shadow: none;
    opacity: 1;
}

.form-control[readonly]:focus {
    border-color: var(--hp-color-border-muted);
    box-shadow: none;
}

.hidden {
    display: none !important;
}

.col-md-offset-2 {
    margin-left: 16.666667%;
}

.badge.alert-danger,
.badge.alert-warning,
.badge.alert-success,
.badge.alert-info {
    display: inline-block;
    padding: 0.25em 0.5em;
    border-radius: 0.375rem;
    text-decoration: none;
}

.badge.alert-danger {
    color: var(--hp-color-white);
    background-color: var(--hp-color-red);
}

.badge.alert-warning {
    color: var(--hp-color-text-body);
    background-color: var(--hp-color-yellow);
}

.badge.alert-success {
    color: var(--hp-color-white);
    background-color: var(--hp-color-green);
}

.badge.alert-info {
    color: var(--hp-color-white);
    background-color: var(--hp-color-blue);
}

.badge.alert-default {
    color: var(--hp-color-text-body);
    background-color: var(--hp-color-surface-100);
    border: 1px solid var(--hp-color-border-default);
}

.badge.table-status-badge {
    font-size: 12px;
    padding: 5px 12px;
    border: 1px solid transparent;
    font-weight: 600;
}

.badge.table-status-badge-lg {
    font-size: 14px;
    padding: 8px 20px;
}

.badge.table-status-badge.alert-info {
    color: var(--hp-color-white) !important;
    background-color: var(--hp-color-blue) !important;
    border-color: transparent;
}

.badge.table-status-badge.alert-success {
    color: var(--hp-color-white) !important;
    background-color: var(--hp-color-green) !important;
    border-color: transparent;
}

.badge.table-status-badge.alert-danger {
    color: var(--hp-color-white) !important;
    background-color: var(--hp-color-red) !important;
    border-color: transparent;
}

.badge.table-status-badge.alert-warning {
    color: var(--hp-color-dark-blue) !important;
    background-color: var(--hp-color-yellow) !important;
    border-color: transparent;
}

.app-mobile-menu-toggle {
    margin: 19px 10px 0 0;
}

.app-form-padding-bottom {
    padding-bottom: 15px;
}

.app-dropzone-dashed {
    background: none !important;
    border: 2px dashed var(--hp-color-light-gray) !important;
}

.app-no-bg-border {
    background: none !important;
    border: none !important;
}

.app-cell-actions {
    text-align: right;
    padding-right: 5%;
    vertical-align: middle;
}

.app-cell-actions-lg {
    text-align: right;
    padding-right: 20px;
    vertical-align: middle;
}

.app-empty-state-alert {
    font-size: large;
    font-weight: bold;
    text-align: center;
    padding: 25px;
    margin: 25px;
}

.app-btn-compact {
    padding: 8px 30px;
    margin: 10px;
}

.app-modal-dialog-wide {
    min-width: 800px;
}

.app-alert-icon-lg {
    font-size: 35px;
    float: left;
    margin-right: 15px;
}

.app-chart-panel {
    height: 290px;
    padding: 2% 4% 2% 2%;
    background-color: rgba(192, 192, 192, 0.1);
}

.app-wrapper-bottom-xl {
    margin-bottom: 100px;
}

.app-ibox-gap {
    margin-bottom: 30px;
}

.app-section-spaced {
    margin-top: 45px;
    margin-bottom: 25px;
}

.app-filter-field-compact {
    width: 150px;
    padding-right: 12px;
    margin-right: 20px;
}

.app-status-badge {
    font-size: 14px;
    padding: 5px 15px;
}

.app-select-period {
    height: 40px;
    width: 200px;
    text-align: center;
}

.app-heading-compact {
    margin: 10px 0 3px;
}

.app-row-margin-10-20-0 {
    margin: 10px 20px 0;
}

.app-ml-17p {
    margin-left: 17%;
}

.app-max-h-100 {
    max-height: 100px;
}

.app-modal-content-w-400 {
    width: 400px;
}

.app-iradio-relative {
    position: relative;
}

.app-iradio-input-hidden {
    position: absolute;
    opacity: 0;
}

.app-iradio-helper {
    position: absolute;
    top: 0%;
    left: 0%;
    display: block;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    background: var(--hp-color-white);
    border: 0;
    opacity: 0;
}

.app-radio-inline {
    display: inline-flex;
    align-items: center;
    margin-right: 0.75rem;
    font-weight: 400;
}

.app-input-group-addon {
    display: flex;
    align-items: center;
    padding: 0.375rem 0.75rem;
    margin-bottom: 0;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--hp-color-text-subtle);
    text-align: center;
    white-space: nowrap;
    background-color: var(--hp-color-surface-300);
    border: 1px solid var(--hp-color-border-default);
}

/* Global Dropzone refresh for a cleaner upload area. */
#page-wrapper .dropzone {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    min-height: 170px;
    padding: 1rem;
    border: 2px dashed var(--hp-color-border-dashed);
    border-radius: 10px;
    background-color: var(--hp-color-surface-400);
    transition: border-color 0.2s ease, background-color 0.2s ease;
}

#page-wrapper .dropzone:hover {
    border-color: var(--hp-color-border-hover);
    background-color: var(--hp-color-surface-500);
}

#page-wrapper .dropzone.dz-drag-hover {
    border-color: var(--hp-color-info-accent);
    background-color: var(--hp-color-surface-600);
}

#page-wrapper .dropzone .dz-message {
    margin: 0;
    color: var(--hp-color-text-faded);
    font-size: 0.9rem;
    font-weight: 500;
    text-align: center;
}

#page-wrapper .dropzone .dz-preview {
    margin: 0.55rem;
}

#page-wrapper .dropzone .dz-preview .dz-image {
    border-radius: 8px;
}

#page-wrapper .dropzone .dz-preview .dz-details {
    font-size: 0.8rem;
}

#page-wrapper .dropzone .dz-preview .dz-remove {
    color: var(--hp-color-link);
    text-decoration: none;
    font-size: 0.8rem;
}

@media (max-width: 768px) {
    #appMobileSidebar {
        width: 280px;
        max-width: 82vw;
        z-index: 1045;
        --bs-offcanvas-bg: var(--hp-color-dark-blue);
        --bs-offcanvas-color: var(--hp-color-light-gray);
        background-color: var(--hp-color-dark-blue) !important;
    }

    #appMobileSidebar .offcanvas-body {
        padding: 0;
        background-color: var(--hp-color-dark-blue) !important;
        display: flex;
        flex-direction: column;
        min-height: 0;
    }

    #appMobileSidebar .nav {
        background-color: var(--hp-color-dark-blue) !important;
        display: flex;
        flex-direction: column;
        flex-wrap: nowrap;
        flex: 1 1 auto;
        min-height: 100%;
        margin: 0;
        overflow-y: auto;
    }

    /* Le spacer sert au desktop ; dans l’offcanvas il créait trop de vide et poussait le bloc user hors zone utile. */
    #appMobileSidebar .nav > li.nav-sidebar-spacer {
        display: none !important;
    }

    #appMobileSidebar .nav > li.nav-footer-user-container {
        flex-shrink: 0;
        margin-top: 0.75rem;
        padding: 0.75rem 16px 12px;
        border-top: 1px solid rgba(255, 255, 255, 0.12);
        list-style: none;
    }

    #appMobileSidebar .nav > li.nav-footer-user-container .nav-user-block {
        margin: 0;
    }

    #appMobileSidebar .nav > li.nav-footer-user-container .nav-user-name,
    #appMobileSidebar .nav > li.nav-footer-user-container .nav-user-number {
        color: var(--hp-color-white) !important;
    }

    #appMobileSidebar .nav > li.nav-footer-user-container .nav-welcome {
        display: block;
        width: 100%;
        text-align: center;
        color: var(--hp-color-white) !important;
    }

    #appMobileSidebar .nav > li.nav-footer-user-container .nav-logout-link {
        color: rgba(255, 255, 255, 0.92) !important;
        margin-top: 0.35rem;
        padding-top: 0.35rem !important;
    }

    #appMobileSidebar .nav > li.nav-footer-user-container .nav-logout-link:hover,
    #appMobileSidebar .nav > li.nav-footer-user-container .nav-logout-link:focus {
        background-color: rgba(255, 255, 255, 0.08);
        border-radius: var(--hp-radius-sm, 0.25rem);
    }

    #appMobileSidebar .offcanvas-header {
        background-color: var(--hp-color-dark-blue);
        color: var(--hp-color-white);
        border-bottom: 1px solid var(--hp-color-magenta);
    }

    /* Liens du menu : uniquement les <li> qui ont un <a> direct (évite nav-header avec lien dans un div). */
    #appMobileSidebar .nav > li:not(.nav-sidebar-spacer):not(.nav-footer-user-container) > a {
        color: var(--hp-color-light-gray) !important;
        padding: 12px 16px 12px 20px;
        font-weight: 600;
        font-size: 0.85rem;
        display: block;
        width: 100%;
        text-decoration: none;
        white-space: nowrap;
    }

    #appMobileSidebar .nav > li:not(.nav-sidebar-spacer):not(.nav-footer-user-container) > a i,
    #appMobileSidebar .nav > li:not(.nav-sidebar-spacer):not(.nav-footer-user-container) > a .nav-label {
        color: inherit !important;
    }

    #appMobileSidebar .nav > li:not(.nav-sidebar-spacer):not(.nav-footer-user-container) > a:hover,
    #appMobileSidebar .nav > li:not(.nav-sidebar-spacer):not(.nav-footer-user-container) > a:focus,
    #appMobileSidebar .nav > li:not(.nav-sidebar-spacer):not(.nav-footer-user-container).active > a {
        color: var(--hp-color-white) !important;
        background-color: var(--hp-color-magenta);
        text-decoration: none;
    }

    #appMobileSidebar .nav > li:not(.nav-sidebar-spacer) {
        display: block;
        width: 100%;
        margin: 0;
    }

    #appMobileSidebar .nav > li.nav-header + li:not(.nav-sidebar-spacer):not(.nav-footer-user-container) {
        margin-top: 0.75rem;
    }

    #appMobileSidebar .nav > li.nav-header-admin {
        background-color: var(--hp-color-dark-blue);
    }

    .fixed-sidebar .navbar-static-side {
        position: relative;
        width: 100%;
        height: auto;
    }

    #page-wrapper {
        margin-left: 0;
    }

    .footer.fixed {
        left: 0;
        position: static;
        width: 100%;
        margin-top: 1rem;
    }

    #page-wrapper {
        padding-bottom: calc(0.75rem + env(safe-area-inset-bottom));
    }

    .footer.fixed .footer-inline {
        display: flex;
        flex-wrap: wrap;
        white-space: normal;
        row-gap: 0.35rem;
        column-gap: 0.35rem;
        overflow-wrap: anywhere;
    }

    .footer.fixed .footer-language,
    .footer.fixed .footer-language-form {
        white-space: normal;
        flex-wrap: wrap;
    }

    .footer.fixed .footer-language-select {
        max-width: 100%;
    }
}
