:root {
  --primary-color: #17659C; /* #003566; */
  --primary-color-hover: #165F93;
  --secondary-color: #DE6834; /* #F5CC00; */
  --secondary-color-hover: #D56231;
  --secondary-color2: #749EC2;
  --secondary-color3: #ABABAB;
  /* App bar: admin strip + public top row + mobile; menu row uses --site-header-menu-height */
  --site-header-height: 50px;
  --site-header-menu-height: 34px;
  /* Fixed sidebar sits below sticky admin bar (header + small gap so labels clear shadow) */
  --admin-sidebar-top: calc(var(--site-header-height) + 8px);
  /* Material Design–style elevation (ambient + key shadow, strongest downward) */
  --app-bar-elevation:
    0 3px 1px -2px rgba(0, 0, 0, 0.2),
    0 2px 2px 0 rgba(0, 0, 0, 0.14),
    0 1px 5px 0 rgba(0, 0, 0, 0.12);
  /*
   * Fixed donor header: height match for `main.site-donor-main` padding-top.
   * Mobile = single bar (--site-header-height). Desktop (uk-visible@l) = two rows (~92px).
   * Include safe-area-inset-top so content clears notch + tinted status region.
   */
  --site-public-header-offset: calc(var(--site-header-height) + env(safe-area-inset-top, 0px));
}

@media (min-width: 1200px) {
  :root {
    --site-public-header-offset: calc(92px + env(safe-area-inset-top, 0px));
  }
}

/* Hint browser UI / form controls; pairs with meta theme-color + color-scheme */
html {
  color-scheme: light;
}

/* Donor / public layout: header fixed, main scrolls beneath with top inset */
header.site-donor-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 990;
  box-sizing: border-box;
  /* OS status / notch area matches nav so theme-color + iOS translucent bar look correct */
  padding-top: env(safe-area-inset-top, 0px);
  background-color: var(--primary-color);
}

main.site-donor-main {
  padding-top: var(--site-public-header-offset);
  box-sizing: border-box;
  max-width: 100%;
  overflow-x: clip;
}

/* In-page anchors / scroll restore: keep content below fixed header */
body.site-donor-body {
  scroll-padding-top: var(--site-public-header-offset);
  overflow-x: clip;
}

/* Fixed “Join UWI Connect” bar (home only): keep main/footer above bar + home indicator */
@media (max-width: 959px) {
  body.site-donor-body.site-donor-body--uwi-connect-prompt {
    padding-bottom: calc(48px + env(safe-area-inset-bottom, 0px));
  }
}

/* Shared header: crest + app title (admin + public) */
.site-nav-brand {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none !important;
  color: #fff !important;
  padding: 0;
  min-height: 0;
  box-sizing: border-box;
}

.site-nav-brand:hover,
.site-nav-brand:focus {
  color: #fff !important;
  opacity: 0.92;
}

.site-nav-logo {
  height: 26px;
  width: auto;
  max-height: 26px;
  display: block;
  flex-shrink: 0;
  object-fit: contain;
}

.site-nav-title-cluster {
  display: inline-flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.35em 0.5em;
  min-width: 0;
}

.site-nav-title {
  font-size: 0.9375rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  line-height: 1.2;
  margin: 0;
  color: inherit;
  white-space: nowrap;
}

.site-nav-admin-divider {
  opacity: 0.65;
  font-weight: 400;
  margin: 0;
}

.site-nav-admin-label {
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  opacity: 0.95;
  white-space: nowrap;
}

/* Long title on small *desktop* top row only — mobile header uses ellipsis below */
@media (max-width: 1199px) {
  .site-public-header-top .site-nav-title {
    font-size: 0.8125rem;
    white-space: normal;
    max-width: min(42vw, 280px);
  }
}

/* Admin sticky bar strip */
.site-header-inner {
  background-color: var(--primary-color);
  box-shadow: var(--app-bar-elevation);
  min-height: var(--site-header-height);
  max-height: var(--site-header-height);
  display: flex;
  align-items: center;
  box-sizing: border-box;
}

/* Let the UIkit navbar row span the full bar so `.uk-navbar-right { margin-left: auto }` reaches the far edge */
.site-header-inner > div[uk-navbar] {
  flex: 1 1 auto;
  width: 100%;
  min-width: 0;
}

.site-header-nav.uk-navbar-container {
  padding: 0;
  min-height: var(--site-header-height) !important;
  box-sizing: border-box;
}

.site-header-nav .uk-navbar {
  min-height: var(--site-header-height);
  height: var(--site-header-height);
  max-height: var(--site-header-height);
  padding: 0;
  box-sizing: border-box;
}

.site-header-nav .uk-navbar > .uk-navbar-left,
.site-header-nav .uk-navbar > .uk-navbar-right {
  min-height: 0;
  height: 100%;
  align-items: center;
}

.site-header-nav .uk-navbar-item {
  min-height: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  box-sizing: border-box;
}

.site-header-nav .site-nav-title-cluster {
  flex-wrap: nowrap;
}

.site-header-nav .uk-navbar-nav > li > a {
  min-height: var(--site-header-height);
  height: var(--site-header-height);
  max-height: var(--site-header-height);
  padding: 0 12px;
  box-sizing: border-box;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Public / donor site: two-row compact header, single Material-style elevation.
   UIkit sets `.uk-navbar-container:not(.uk-navbar-transparent) { background: #f8f8f8 }`
   (two class slots), which overrides a lone `.site-public-header` rule — match specificity. */
.uk-navbar-container.site-public-header {
  background: var(--primary-color);
  background-color: var(--primary-color);
  box-shadow: var(--app-bar-elevation);
}

.uk-navbar-container.site-public-header .uk-navbar-nav > li > a,
.uk-navbar-container.site-public-header .uk-navbar-item,
.uk-navbar-container.site-public-header .uk-navbar-toggle {
  color: #fff;
}

.uk-navbar-container.site-public-header .uk-navbar-nav > li > a:hover,
.uk-navbar-container.site-public-header .uk-navbar-toggle:hover {
  color: rgba(255, 255, 255, 0.85);
}

.site-public-header-menu {
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  padding-top: 4px;
  padding-bottom: 4px;
  box-sizing: border-box;
}

.site-public-header-menu .uk-navbar {
  min-height: var(--site-header-menu-height);
}

.site-public-header-menu .uk-navbar-nav > li > a,
.site-public-header-menu .navbar-options li a {
  min-height: var(--site-header-menu-height);
  padding: 0 10px;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  display: inline-flex;
  align-items: center;
}

/* Top row (brand + search): compact — UIkit sets `input { height: 40px }`; override height, not only min-height */
.site-public-header-top {
  min-height: 0;
  box-sizing: border-box;
  margin: 0;
  padding: 6px 0 8px;
}

@media (min-width: 960px) {
  .site-public-header-top {
    flex-wrap: nowrap;
  }
}

.site-public-header-top .uk-navbar-item {
  min-height: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.site-public-header-top .uk-inline .uk-input {
  max-width: min(400px, 38vw);
  font-size: 0.8125rem;
  line-height: 1.2;
  height: 30px;
  min-height: 30px;
  box-sizing: border-box;
  padding: 2px 10px 2px 34px;
  border-radius: 4px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
  border: none;
  color: #263238;
}

.site-public-header-top .site-nav-brand {
  line-height: 1;
}

.site-public-header-top .site-nav-title {
  line-height: 1.2;
}

/* Desktop header: solid install CTA (matches mobile orange — readable on blue bar) */
.site-public-header-top .site-pwa-install-btn--desktop {
  white-space: nowrap;
  line-height: 1.25;
  padding: 0 14px;
  min-height: 32px;
  box-sizing: border-box;
  background: var(--secondary-color) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 6px !important;
  font-weight: 600;
  font-size: 0.8125rem;
  letter-spacing: 0.02em;
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.2);
  text-transform: none;
}

.site-public-header-top .site-pwa-install-btn--desktop:hover,
.site-public-header-top .site-pwa-install-btn--desktop:focus {
  background: var(--secondary-color-hover) !important;
  color: #fff !important;
}

.site-public-header-top .site-pwa-install-btn--desktop .uk-icon,
.site-public-header-top .site-pwa-install-btn--desktop svg {
  color: #fff !important;
}

.site-mobile-header.uk-navbar-container {
  padding: 0;
}

.site-mobile-header .uk-navbar {
  min-height: var(--site-header-height);
  height: var(--site-header-height);
  max-height: var(--site-header-height);
  padding: 0;
  box-sizing: border-box;
  gap: 4px;
}

.site-mobile-header .uk-navbar > .uk-navbar-left,
.site-mobile-header .uk-navbar > .uk-navbar-right {
  align-items: center;
  min-height: 0;
  height: 100%;
}

.site-mobile-header .uk-navbar-item {
  min-height: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* Single-row mobile/tablet nav: brand shrinks, controls stay tappable */
.site-mobile-header .uk-container {
  padding-left: max(12px, env(safe-area-inset-left)) !important;
  padding-right: max(12px, env(safe-area-inset-right)) !important;
  box-sizing: border-box;
}

.site-mobile-header .uk-navbar-left {
  flex: 1 1 auto;
  min-width: 0;
}

.site-mobile-header .site-nav-brand {
  min-width: 0;
  max-width: 100%;
  padding-right: 4px;
}

.site-mobile-header .site-nav-title {
  flex: 1 1 auto;
  min-width: 0;
  font-size: clamp(0.7rem, 2.8vw, 0.8125rem);
  line-height: 1.15;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.site-mobile-header .uk-navbar-right {
  flex: 0 0 auto;
  margin-left: auto;
}

.site-mobile-header .uk-navbar-nav > li > a.uk-navbar-toggle {
  min-width: 40px;
  min-height: 40px;
  padding: 0 8px;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* Expanded mobile search row */
.site-mobile-header .nav-overlay {
  padding-left: max(12px, env(safe-area-inset-left));
  padding-right: max(12px, env(safe-area-inset-right));
  box-sizing: border-box;
  align-items: center;
  min-height: var(--site-header-height);
}

.site-mobile-header .nav-overlay .uk-search-input {
  font-size: 1rem;
}

/* Medium breakpoint: in-bar search without forcing horizontal scroll */
.site-mobile-header .site-med-livesearch-input {
  width: min(400px, calc(100vw - 220px));
  max-width: 100%;
  font-size: 0.8125rem;
  height: 32px;
  min-height: 32px;
  box-sizing: border-box;
}

/* Donor auth / gray shell pages */
.site-donor-auth-shell {
  padding: 24px 16px !important;
  box-sizing: border-box;
}

@media (min-width: 640px) {
  .site-donor-auth-shell {
    padding: 40px 24px !important;
  }
}

@media (min-width: 960px) {
  .site-donor-auth-shell {
    padding: 50px 32px !important;
  }
}

/* Modals: never wider than viewport */
.uk-modal-dialog.site-donor-modal-dialog {
  width: 450px;
  max-width: calc(100vw - 32px);
  box-sizing: border-box;
}

.uk-modal-dialog.site-donor-modal-dialog-sm {
  width: 350px;
  max-width: calc(100vw - 32px);
  box-sizing: border-box;
}

/*
 * Donor mobile offcanvas — align with admin `.custom-sidebar` (light slate panel, padded rows).
 */
.site-donor-offcanvas.uk-offcanvas-bar {
  width: min(280px, 88vw) !important;
  max-width: 88vw;
  box-sizing: border-box;
  padding: calc(14px + env(safe-area-inset-top, 0px)) 16px max(28px, env(safe-area-inset-bottom, 0px)) 18px !important;
  background: #fafbfc !important;
  color: #334155 !important;
  border-left: 1px solid #e2e8f0;
  box-shadow: -4px 0 24px rgba(15, 23, 42, 0.06);
  font-size: 0.9375rem;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-height: 100dvh;
}

.site-donor-offcanvas__close.uk-offcanvas-close {
  color: #64748b !important;
  padding: 8px;
  margin: -4px -4px 4px 0;
  transition: color 0.15s ease, background 0.15s ease;
  border-radius: 8px;
}

.site-donor-offcanvas__close.uk-offcanvas-close:hover {
  color: #0f172a !important;
  background: #f1f5f9;
}

.site-donor-offcanvas__nav {
  margin: 0 !important;
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.site-donor-offcanvas__footer.site-donor-offcanvas__pwa {
  flex-shrink: 0;
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid #e2e8f0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Extra space above fixed “Join UWI Connect” bar on home (offcanvas + bottom bar stack) */
@media (max-width: 959px) {
  body.site-donor-body--uwi-connect-prompt .site-donor-offcanvas__footer.site-donor-offcanvas__pwa {
    padding-bottom: 12px;
    margin-bottom: 8px;
  }
}

.site-donor-offcanvas__install-btn.site-pwa-install-btn {
  margin: 0 0 28px 0;
  box-sizing: border-box;
  background: var(--secondary-color) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 10px !important;
  font-weight: 700;
  font-size: 0.9375rem;
  min-height: 48px;
  line-height: 1.2;
  box-shadow: 0 2px 10px rgba(222, 104, 52, 0.35);
  text-transform: none;
  letter-spacing: 0.01em;
}

.site-donor-offcanvas__install-btn.site-pwa-install-btn:hover,
.site-donor-offcanvas__install-btn.site-pwa-install-btn:focus {
  background: var(--secondary-color-hover) !important;
  color: #fff !important;
}

.site-donor-offcanvas__nav > li.uk-parent > a.uk-nav-header {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #475569 !important;
  padding: 14px 0 10px 0;
  margin: 0;
  line-height: 1.2;
}

.site-donor-offcanvas__nav > li.uk-parent:first-child > a.uk-nav-header {
  padding-top: 4px;
}

.site-donor-offcanvas__nav .uk-nav-header .uk-icon {
  width: 1.15em;
  height: 1.15em;
  color: #64748b;
  margin-right: 0.5rem !important;
}

.site-donor-offcanvas__nav .uk-nav-sub {
  padding-left: 0.35rem;
  margin: 6px 0 8px 0;
}

.site-donor-offcanvas__nav .uk-nav-sub > li {
  margin: 3px 0;
}

.site-donor-offcanvas__nav .uk-nav-sub > li > a,
.site-donor-offcanvas__nav .uk-nav-sub > li > .uk-inline > a {
  display: block;
  padding: 10px 12px 10px 10px;
  border-radius: 8px;
  color: #64748b !important;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.35;
  text-decoration: none !important;
  transition: background 0.15s ease, color 0.15s ease;
}

.site-donor-offcanvas__nav .uk-nav-sub > li > a:hover,
.site-donor-offcanvas__nav .uk-nav-sub > li > .uk-inline > a:hover {
  background: #f1f5f9;
  color: #0f172a !important;
}

.site-donor-offcanvas__nav .uk-nav-divider {
  margin: 1.35rem 0;
  border-top: 1px solid #e2e8f0;
}

/* Faculty picker dropdown inside offcanvas */
.site-donor-offcanvas__dropdown {
  box-shadow: 0 10px 40px rgba(15, 23, 42, 0.12);
  border: 1px solid #e2e8f0;
  background: #fff;
  border-radius: 10px !important;
  padding: 6px 0;
  max-height: min(70vh, 420px);
  overflow-y: auto;
}

.site-donor-offcanvas__dropdown .uk-dropdown-nav > li > a {
  padding: 9px 14px;
  font-size: 0.875rem;
  font-weight: 500;
  color: #64748b !important;
  border-radius: 6px;
  margin: 2px 8px;
}

.site-donor-offcanvas__dropdown .uk-dropdown-nav > li > a:hover {
  background: #f1f5f9 !important;
  color: #0f172a !important;
}

/* Primary Styles */
.primary {
background-color: var(--primary-color);
color: #ffffff; /* white text on primary */
}

.primary:hover {
  background-color: var(--primary-color-hover);
  color: #ffffff; /* white text on primary */
}

.secondary {
background-color: var(--secondary-color);
color: #ffffff; /* white text on secondary */ 
}

.secondary:hover {
  background-color: var(--secondary-color-hover);  
  color: #ffffff; /* white text on secondary */   
}

.secondary-button {
  border-color: var(--secondary-color) ;
  background-color: #ffffff;
  color: var(--secondary-color);        
}

.secondary-button:hover {
  background-color: #f9f9f9;
  color: var(--secondary-color);
  text-decoration: none;
  border-color: var(--secondary-color);
}

.secondary2 {
background-color: var(--secondary-color2);
color: #000000; /* black text on secondary2 */
}

.secondary3 {
background-color: var(--secondary-color3);
color: #000000; /* black text on secondary3 */ 
}

/* Overrides */
.background {
  background-color: #fffdf2 ;
}


.secondary .waves-effect .waves-light{
  background-color: var(--secondary-color);
}

.background-text {
  color: #000000; /* text color on background */
}


.btn:hover, .btn-small:hover {   
    background-color: #F5CC00;    
}

.btn:focus, .btn-large:focus, .btn-small:focus,
.btn-floating:focus {
  background-color: var(--secondary-color);
}

.dropdown-content li a{
  
  color: #000000;
}

.uk-progress::-webkit-progress-value {
  background-color: var(--primary-color);
}

