:root {
	--ny-blue: #002973;
	--ny-blue-rgb: 0,41,115;
	--ny-blue-light: #0050AA;
	--ny-blue-dark: #001862;
	--ny-yellow: #F2AB00;
	--ny-yellow-light: #F3BC00;
	--ny-yellow-dark: #E17A00;
	--ny-red: #c41330;
	--ny-red-light: #d52441;
	--ny-red-dark: #b30220;
	--orange: #FD7E14;
	--purple: #6F42C1;
	--purple-light: #7F53D2;
	--wnysls-gray: #ddd;
	--wnysls-gray-alt: #999;
	--wnysls-dark-alt: #2C3034;
}

@media print {

  /* Hide everything except the schedule */
  body * {
    visibility: hidden;
  }

  #scheduleCard, #scheduleCard * {
    visibility: visible;
  }

  #scheduleCard {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
  }

  /* 🔥 Force desktop layout (fix Bootstrap collapsing) */
  #scheduleCard .row {
    display: flex !important;
    flex-wrap: nowrap !important;
  }

  #scheduleCard [class*="col-"] {
    flex: 0 0 auto !important;
    display: block !important;
  }

  /* Rebuild your exact column layout */
  #scheduleCard .col-md-1 { width: 8.333333% !important; }
  #scheduleCard .col-md-2 { width: 16.666667% !important; }
  #scheduleCard .col-md-3 { width: 25% !important; }
  #scheduleCard .col-md-6 { width: 50% !important; }

  /* Fix nested tee row (allow wrapping there only) */
  #scheduleCard .row .row {
    flex-wrap: wrap !important;
  }

  #scheduleCard .row .row .col-md-3 {
    width: 25% !important;
  }

  /* Remove nowrap (it WILL break printing) */
  #scheduleCard .text-nowrap {
    white-space: normal !important;
  }

  /* Hide buttons / interactive UI */
  #scheduleCard .btn,
  #scheduleCard [id^="buttonGroup"],
  .offcanvas {
    display: none !important;
  }

  /* Clean spacing for print */
  #scheduleCard .card {
    box-shadow: none !important;
    border: 1px solid #ccc !important;
  }

  #scheduleCard .card-body {
    padding: 10px !important;
  }
}

/* Custom Scroller */
.custom-scroller::-webkit-scrollbar {
	width: 7px;
}

.custom-scroller::-webkit-scrollbar-track {
	background: transparent;
}

::-webkit-scrollbar-thumb {
	background-color: #969696;
	border: 6px solid transparent;
}

::-webkit-scrollbar-thumb:hover {
	background-color: #a8bbbf;
}

/* -----Negative margins----- */
.mt-n1 {
	margin-top: -0.25rem !important;
}

.mt-n2 {
	margin-top: -0.5rem !important;
}

.mt-n3 {
	margin-top: -1rem !important;
}

.mt-n4 {
	margin-top: -1.5rem !important;
}

.mt-n5 {
	margin-top: -3rem !important;
}

.mt-n6 {
	margin-top: -6rem !important;
}

.mt-n7 {
	margin-top: -7rem !important;
}

.mt-n8 {
	margin-top: -8rem !important;
}

.mt-n9 {
	margin-top: -9rem !important;
}

.mt-n10 {
	margin-top: -10rem !important;
}


/* -----Larger margins----- */
.mt-6 {
	margin-top: 6rem !important;
}

.mt-7 {
	margin-top: 7rem !important;
}

.mt-8 {
	margin-top: 8rem !important;
}

.mt-9 {
	margin-top: 9rem !important;
}

.mt-10 {
	margin-top: 10rem !important;
}

/* Backgrounds */
.bg-purple {
	background-color: var(--purple) !important;
}

.bg-orange {
	background-color: var(--orange) !important;
}

.bg-ny-blue {
	background-color: var(--ny-blue) !important;
}

.bg-ny-red {
	background-color: var(--ny-red) !important;
}

.bg-ny-yellow {
	background-color: var(--ny-yellow) !important;
}

.bg-wnysls-gray {
	background-color: var(--wnysls-gray) !important;
}

.bg-wnysls-gray-alt {
	background-color: var(--wnysls-gray) !important;
}

.bg-dark-alt {
	background-color: var(--wnysls-dark-alt) !important;
}

.bg-transparent {
	background-color: rgba(0, 0, 0, 0.05) !important;
}


/* Borders */
.border-ny-blue {
	border-color: var(--ny-blue) !important;
}

.border-ny-red {
	border-color: var(--ny-red) !important;
}

.border-ny-yellow {
	border-color: var(--ny-yellow) !important;
}

.border-orange {
	border-color: var(--orange) !important;
}


/* Link colors */
.link-ny-blue {
	color: var(--ny-blue-light);
}
.link-ny-blue:hover, .link-ny-blue:focus {
	color: var(--ny-blue);
}

.link-purple {
	color: var(--purple);
}
.link-purple:hover, .link-purple:focus {
	color: var(--purple-light);
}

.link-purple-light {
	color: var(--purple-light);
}
.link-purple-light:hover, .link-purple-light:focus {
	color: var(--purple-light-light);
}

.link-wnysls-gray {
	color: var(--wnysls-gray-alt);
}
.link-wnysls-gray:hover, .link-wnysls-gray:focus {
	color: var(--wnysls-gray);
}

.link-ny-yellow {
	color: var(--ny-yellow);
}
.link-ny-yellow:hover, .link-ny-yellow:focus {
	color: var(--ny-yellow-dark);
}

.link-ny-red {
	color: var(--ny-red);
}
.link-ny-red:hover, .link-ny-red:focus {
	color: var(--ny-red-light);
}


/* Text colors */
.text-purple {
	color: var(--purple) !important;
}

.text-orange {
	color: var(--orange) !important;
}

.text-ny-blue {
	color: var(--ny-blue) !important;
}

.text-ny-red {
	color: var(--ny-red) !important;
}

.text-ny-yellow {
	color: var(--ny-yellow) !important;
}

.text-wnysls-gray {
	color: var(--wnysls-gray) !important;
}

.text-wnysls-dark-alt {
	color: var(--wnysls-dark-alt) !important;
}

.text-wnysls-gray-alt {
	color: var(--wnysls-gray-alt) !important;
}

.text-transparent {
	color: rgba(0, 0, 0, 0.2) !important;
}


/* Button colors */
.btn-purple {
  color: #fff;
  background-color: var(--purple);
  border-color: var(--purple);
}

.btn-purple:hover {
  color: #fff;
  background-color: #5f32b1;
  border-color: #5f32b1;
}

.btn-purple:focus, .btn-purple.focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5);
}

.btn-purple.disabled, .btn-purple:disabled {
  color: #fff;
  background-color: var(--purple);
  border-color: var(--purple);
}

.btn-purple:not(:disabled):not(.disabled):active, .btn-purple:not(:disabled):not(.disabled).active,
.show > .btn-purple.dropdown-toggle {
  color: #fff;
  background-color: #5f32b1;
  border-color: #5e31b0;
}

.btn-purple:not(:disabled):not(.disabled):active:focus, .btn-purple:not(:disabled):not(.disabled).active:focus,
.show > .btn-purple.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5);
}

.btn-outline-purple {
  color: var(--purple);
  background-color: transparent;
  background-image: none;
  border-color: var(--purple);
}

.btn-outline-purple:hover {
  color: #fff;
  background-color: var(--purple);
  border-color: var(--purple);
}

.btn-outline-purple:focus, .btn-outline-purple.focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5);
}

.btn-outline-purple.disabled, .btn-outline-purple:disabled {
  color: var(--purple);
  background-color: transparent;
}

.btn-outline-purple:not(:disabled):not(.disabled):active, .btn-outline-purple:not(:disabled):not(.disabled).active,
.show > .btn-outline-purple.dropdown-toggle {
  color: #fff;
  background-color: var(--purple);
  border-color: var(--purple);
}

.btn-outline-purple:not(:disabled):not(.disabled):active:focus, .btn-outline-purple:not(:disabled):not(.disabled).active:focus,
.show > .btn-outline-purple.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.5);
}

.btn-ny-blue {
  color: #fff;
  background-color: var(--ny-blue);
  border-color: var(--ny-blue);
}

.btn-ny-blue:hover {
  color: #fff;
  background-color: var(--ny-blue-light);
  border-color: var(--ny-blue-light);
}

.btn-ny-blue:focus, .btn-ny-blue.focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 0, 255, 0.5);
}

.btn-ny-blue.disabled, .btn-ny-blue:disabled {
  color: #fff;
  background-color: var(--wnysls-dark-alt);
  border-color: var(--wnysls-dark-alt);
}

.btn-ny-blue:not(:disabled):not(.disabled):active, .btn-ny-blue:not(:disabled):not(.disabled).active,
.show > .btn-ny-blue.dropdown-toggle {
  color: #fff;
  background-color: var(--ny-blue);
  border-color: var(--ny-blue);
}

.btn-ny-blue:not(:disabled):not(.disabled):active:focus, .btn-ny-blue:not(:disabled):not(.disabled).active:focus,
.show > .btn-ny-blue.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 0, 255, 0.5);
}

.btn-outline-ny-blue {
  color: var(--ny-blue);
  border-color: var(--ny-blue);
}

.btn-outline-ny-blue:hover {
  color: #fff;
  background-color: var(--ny-blue);
  border-color: var(--ny-blue);
}

.btn-check:focus + .btn-outline-ny-blue, .btn-outline-ny-blue:focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 0, 255, 0.5);
}

.btn-outline-ny-blue.disabled, .btn-outline-ny-blue:disabled {
  color: var(--ny-blue);
  background-color: transparent;
}

.btn-check:checked + .btn-outline-ny-blue, .btn-check:active + .btn-outline-ny-blue, .btn-outline-ny-blue:active, .btn-outline-ny-blue.active, .btn-outline-ny-blue.dropdown-toggle.show {
  color: #fff;
  background-color: var(--ny-blue);
  border-color: var(--ny-blue);
}
.btn-check:checked + .btn-outline-ny-blue:focus, .btn-check:active + .btn-outline-ny-blue:focus, .btn-outline-ny-blue:active:focus, .btn-outline-ny-blue.active:focus, .btn-outline-ny-blue.dropdown-toggle.show:focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 0, 255, 0.5);
}


.btn-ny-red {
  color: #fff;
  background-color: var(--ny-red);
  border-color: var(--ny-red);
}

.btn-ny-red:hover {
  color: #fff;
  background-color: var(--ny-red-light);
  border-color: var(--ny-red-light);
}

.btn-ny-red:focus, .btn-ny-red.focus {
  box-shadow: 0 0 0 0.2rem rgba(255, 0, 0, 0.5);
}

.btn-ny-red.disabled, .btn-ny-red:disabled {
  color: #fff;
  background-color: var(--wnysls-dark-alt);
  border-color: var(--wnysls-dark-alt);
}

.btn-ny-red:not(:disabled):not(.disabled):active, .btn-ny-red:not(:disabled):not(.disabled).active,
.show > .btn-ny-red.dropdown-toggle {
  color: #fff;
  background-color: var(--ny-red);
  border-color: var(--ny-red);
}

.btn-ny-red:not(:disabled):not(.disabled):active:focus, .btn-ny-red:not(:disabled):not(.disabled).active:focus,
.show > .btn-ny-red.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(255, 0, 0, 0.5);
}

.btn-outline-ny-red {
  color: var(--ny-red);
  background-color: transparent;
  background-image: none;
  border-color: var(--ny-red);
}

.btn-outline-ny-red:hover {
  color: #fff;
  background-color: var(--ny-red);
  border-color: var(--ny-red);
}

.btn-outline-ny-red:focus, .btn-outline-ny-red.focus {
  box-shadow: 0 0 0 0.2rem rgba(255, 0, 0, 0.5);
}

.btn-outline-ny-red.disabled, .btn-outline-ny-red:disabled {
  color: var(--ny-red);
  background-color: transparent;
}

.btn-outline-ny-red:not(:disabled):not(.disabled):active, .btn-outline-ny-red:not(:disabled):not(.disabled).active,
.show > .btn-outline-ny-red.dropdown-toggle {
  color: #fff;
  background-color: var(--ny-red);
  border-color: var(--ny-red);
}

.btn-outline-ny-red:not(:disabled):not(.disabled):active:focus, .btn-outline-ny-red:not(:disabled):not(.disabled).active:focus,
.show > .btn-outline-ny-red.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(255, 0, 0, 0.5);
}

.btn-ny-yellow {
  color: #000;
  background-color: var(--ny-yellow);
  border-color: var(--ny-yellow);
}

.btn-ny-yellow:hover {
  color: #000;
  background-color: var(--ny-yellow-dark);
  border-color: var(--ny-yellow-dark);
}

.btn-ny-yellow:focus, .btn-ny-yellow.focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 0, 0, 0.5);
}

.btn-ny-yellow.disabled, .btn-ny-yellow:disabled {
  color: #000;
  background-color: var(--wnysls-dark-alt);
  border-color: var(--wnysls-dark-alt);
}

.btn-ny-yellow:not(:disabled):not(.disabled):active, .btn-ny-yellow:not(:disabled):not(.disabled).active,
.show > .btn-ny-yellow.dropdown-toggle {
  color: #000;
  background-color: var(--ny-yellow);
  border-color: var(--ny-yellow);
}

.btn-ny-yellow:not(:disabled):not(.disabled):active:focus, .btn-ny-yellow:not(:disabled):not(.disabled).active:focus,
.show > .btn-ny-yellow.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 0, 0, 0.5);
}

.btn-outline-ny-yellow {
  color: var(--ny-yellow);
  background-color: transparent;
  background-image: none;
  border-color: var(--ny-yellow);
}

.btn-outline-ny-yellow:hover {
  color: #000;
  background-color: var(--ny-yellow);
  border-color: var(--ny-yellow);
}

.btn-outline-ny-yellow:focus, .btn-outline-ny-yellow.focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 0, 0, 0.5);
}

.btn-outline-ny-yellow.disabled, .btn-outline-ny-yellow:disabled {
  color: var(--ny-yellow);
  background-color: transparent;
}

.btn-outline-ny-yellow:not(:disabled):not(.disabled):active, .btn-outline-ny-yellow:not(:disabled):not(.disabled).active,
.show > .btn-outline-ny-yellow.dropdown-toggle {
  color: #000;
  background-color: var(--ny-yellow);
  border-color: var(--ny-yellow);
}

.btn-outline-ny-yellow:not(:disabled):not(.disabled):active:focus, .btn-outline-ny-yellow:not(:disabled):not(.disabled).active:focus,
.show > .btn-outline-ny-yellow.dropdown-toggle:focus {
  box-shadow: 0 0 0 0.2rem rgba(0, 0, 0, 0.5);
}

.pagination > li > a
{
    background-color: white;
    color: var(--ny-blue);
}

.pagination > li > a:focus,
.pagination > li > a:hover,
.pagination > li > span:focus,
.pagination > li > span:hover
{
    color: #5a5a5a;
    background-color: #eee;
    border-color: #ddd;
}

.pagination > .active > a
{
    color: white;
    background-color: var(--ny-blue) !important;
    border: solid 1px var(--ny-blue) !important;
}

.pagination > .active > a:hover
{
    background-color: var(--ny-blue) !important;
    border: solid 1px var(--ny-blue);
}

/* Mobile + global responsive improvements (migrated from schedule view) */

/* Allow course names, notes and tee info to wrap on smaller screens */
@media (max-width: 991.98px) {
  .text-nowrap {
    white-space: normal !important;
  }
}

/* Make offcanvas full width on small screens */
@media (max-width: 767.98px) {
  .offcanvas.w-50 {
    width: 100% !important;
  }
}

/* Button group layout: default row on desktop, stacked full-width on mobile */
[id^="buttonGroup"] {
  display: flex;
  gap: .5rem;
  flex-direction: row;
  align-items: center;
}
@media (max-width: 767.98px) {
  [id^="buttonGroup"] {
    flex-direction: column;
    align-items: stretch;
  }
  [id^="buttonGroup"] .btn {
    width: 100% !important;
  }
}

/* Course tee items - align icon and name, reduce spacing on mobile */
.col-6.col-md-3.mb-1 {
  display: flex;
  align-items: center;
  gap: .4rem;
  white-space: normal;
}
@media (max-width: 767.98px) {
  .col-6.col-md-3.mb-1 {
    padding-left: 0;
    padding-right: 0;
  }
}

/* Improve readability and touch targets on very small screens */
@media (max-width: 575.98px) {
  .card-body {
    padding: 1rem !important;
  }
  h1 { font-size: 1.45rem; }
  h2 { font-size: 1.25rem; }
  h3 { font-size: 1.1rem; }
  .btn {
    font-size: 1rem;
    padding: .5rem .75rem;
    min-height: 44px;
  }
}

/* Global mobile/tablet quality pass for spacing and crowded controls */
@media (max-width: 991.98px) {
  .content > .px-4 {
    padding-left: .9rem !important;
    padding-right: .9rem !important;
  }

  .row {
    --bs-gutter-x: 1rem;
    --bs-gutter-y: .75rem;
  }

  .form-control,
  .form-select,
  .input-group-text,
  .btn {
    min-height: 42px;
  }

  .table {
    font-size: .95rem;
  }

  .table th,
  .table td {
    white-space: normal;
    word-break: break-word;
    padding: .5rem .45rem;
    vertical-align: middle;
  }

  .table td .btn {
    margin-top: .2rem;
    margin-bottom: .2rem;
  }

  .table td .btn + .btn {
    margin-left: .25rem;
  }

  .d-grid .btn,
  .d-flex .btn {
    min-height: 42px;
  }

  .schedule-meta-btn.btn-sm {
    min-height: auto;
    padding: .3rem .55rem;
    font-size: .88rem;
  }
}

@media (max-width: 767.98px) {
  .card-body {
    padding: 1rem !important;
  }

  .btn,
  .btn-sm,
  .btn-lg {
    min-height: 44px;
    line-height: 1.25;
  }

  .btn-sm {
    padding: .45rem .65rem;
    font-size: .95rem;
  }

  .schedule-meta-btn.btn-sm {
    min-height: auto;
    padding: .25rem .5rem;
    font-size: .85rem;
  }

  .card .card-body[class*="mx-"] {
    margin-left: .5rem !important;
    margin-right: .5rem !important;
  }

  .card .table {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .card .table th,
  .card .table td {
    min-width: 120px;
  }

  .card .table td form,
  .card .table td form.d-inline {
    display: block !important;
    width: 100%;
  }

  .card .table td form + form {
    margin-top: .35rem;
  }

  .card .table td .btn {
    width: 100%;
  }

  #scheduleCard .schedule-metrics-row {
    --bs-gutter-x: 0;
  }

  #scheduleCard .schedule-metrics,
  #scheduleCard .schedule-metrics-row > [class*='col-'] {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .btn-group,
  .btn-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
  }

  .btn-group > .btn,
  .btn-group-vertical > .btn {
    border-radius: .375rem !important;
  }
}

/* Print table readability (moved from schedule view) */
.print-table { width: 100%; border-collapse: collapse; }
.print-table td, .print-table th { padding: .35rem .5rem; text-align: left; vertical-align: top; }

/* Sidebar & header mobile fixes */
@media (max-width: 991.98px) {
  /* Hide desktop sidebar on mobile/tablet and keep offcanvas as primary nav */
  #sidebar, .sidebar {
    display: none !important;
    position: static !important;
    width: auto !important;
    height: auto !important;
    overflow: visible !important;
  }

  .content {
    margin-left: 0 !important;
    margin-top: 0 !important;
    padding-left: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    flex: 1 1 auto !important;
  }

  /* Keep header in normal flow on mobile/tablet to avoid artificial top offsets */
  header, .navbar, .topbar {
    position: static !important;
    top: auto;
    left: auto;
    right: auto;
  }

  body {
    padding-top: 0 !important;
  }

}

@media (max-width: 767.98px) {
  /* Keep existing legacy rules for very small phones */
  .sidebar {
    position: static !important;
    width: 100% !important;
    height: auto !important;
    overflow: visible !important;
  }

  .sidebar .nav-link {
    height: auto;
    padding: .5rem 1rem;
    border-left: none;
  }

  /* Ensure main content doesn't get pushed under a fixed sidebar */
  .content {
    margin-left: 0 !important;
    margin-top: 0 !important;
    padding-top: 0 !important;
    min-height: auto !important;
    overflow-x: visible !important;
  }

  body > .content {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  /* Ensure offcanvas menu never reserves vertical space when closed */
  #sidebarOffcanvas {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
    display: none;
  }

  #sidebarOffcanvas.show {
    display: block !important;
  }

}

/* Consolidated mobile offcanvas styling for all layouts */
@media (max-width: 991.98px) {
  .navbar .btn[aria-controls='sidebarOffcanvas'] {
    border: 0;
    background: transparent;
    color: #fff;
    font-size: 1.1rem;
  }

  .navbar .btn-outline-light {
    border-color: rgba(255, 255, 255, 0.5);
    color: rgba(255, 255, 255, 0.85);
  }

  .navbar .btn-outline-light:hover {
    border-color: #ffffff;
    color: #ffffff;
  }

  .offcanvas {
    z-index: 1050;
    background-color: #f8f9fa !important;
  }

  .offcanvas.offcanvas-start {
    width: 85vw !important;
    max-width: 350px;
  }

  .offcanvas-header {
    background-color: #002973;
    color: #ffffff;
    border-bottom: 1px solid #dee2e6;
  }

  .offcanvas-header .offcanvas-title {
    color: #ffffff;
  }

  .offcanvas-header .btn-close {
    filter: brightness(0) invert(1);
  }

  .offcanvas-body {
    padding: 1rem 1rem 1rem 1.2rem;
    background-color: #f8f9fa;
    max-height: calc(100vh - 56px);
    overflow-y: auto;
  }

  .offcanvas-body > .mb-3:first-child,
  .offcanvas-body > .nav-link:first-child {
    margin-top: 0.35rem;
  }

  .offcanvas-body > .mb-3 {
    margin-bottom: 0.35rem !important;
  }

  .offcanvas-body > .mb-3:last-child {
    margin-bottom: 0 !important;
  }

  .offcanvas-body .nav-link {
    padding: 0.75rem 0.5rem;
    color: #212529 !important;
    text-decoration: none;
    border-left: 3px solid transparent;
    transition: all 0.3s ease;
    display: block;
  }

  .offcanvas-body .nav-link:hover {
    background-color: #e9ecef;
    border-left-color: #002973;
    padding-left: 1rem;
  }

  .offcanvas-body .nav-link.active {
    background-color: #e9ecef;
    border-left-color: transparent;
    font-weight: 500;
    color: #002973 !important;
  }

  .offcanvas-body .btn-link {
    color: #212529 !important;
    text-decoration: none;
    font-weight: 500;
    padding: 0.6rem 0.5rem 0.6rem 1.1rem;
    border-left: 3px solid transparent;
    border-top: 0;
    border-right: 0;
    border-bottom: 0;
    border-radius: 0 !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    transition: all 0.3s ease;
    text-align: left;
    width: 100%;
  }

  .offcanvas-body .btn-link:hover:not(.collapsed) {
    background-color: #e9ecef;
  }

  .offcanvas-body .btn-link:not(.collapsed) {
    background-color: #e9ecef;
    border-left-color: #002973;
    padding-left: 1.3rem;
    color: #002973 !important;
  }

  .offcanvas-body .btn-link:focus {
    box-shadow: none;
  }

  .offcanvas-body .btn-link.active {
    background-color: #e9ecef;
    border-left-color: #002973;
    font-weight: 600;
    color: #002973 !important;
  }

  .offcanvas-body .collapse {
    margin-left: 0;
  }

  .offcanvas-body .ps-3 .nav-link {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    font-size: 0.95rem;
    padding-left: 1rem;
  }

  .offcanvas-body .ps-3 .nav-link.active {
    background-color: #e9ecef;
    border-left-color: transparent;
    font-weight: 500;
  }

  .sidebar-items {
    display: flex;
    flex-direction: column;
  }

  .sidebar-items .nav-link {
    padding: 0.75rem 0.5rem;
    color: #212529 !important;
    text-decoration: none;
    border-left: 3px solid transparent;
    transition: all 0.3s ease;
  }

  .sidebar-items .nav-link:hover {
    background-color: #e9ecef;
    border-left-color: #002973;
    padding-left: 1rem;
  }

  .sidebar-items .nav-link.active {
    background-color: #e9ecef;
    border-left-color: transparent;
    font-weight: 500;
    color: #002973 !important;
  }
}

.offcanvas-backdrop {
  z-index: 1040;
  background-color: rgba(0, 0, 0, 0.1) !important;
}