/*
 * ============================================================================
 * PROJECT: RISE - Responsible Infrastructure for Social Empowerment
 * DEVELOPER: Justin DePaolis-Metz
 * FILE: public/brand-assets.css
 * PURPOSE: Provides shared RISE brand assets, header/footer treatments, account icon styling, and responsive brand chrome across protected pages.
 * LAST REVIEWED: 2026-05-30
 * ============================================================================
 */

/* === Foundation And Brand Asset Variables === */
:root {
  --asset-rise-hero: url("./assets/brand/RISE%20Hero.png");
  --asset-rise-header-logo: url("./assets/brand/RISE%20White%20Logo%20-%20Large.png");
  --asset-rise-footer-logo: url("./assets/brand/RISE%20Logo%20-%20Large.png");
  --asset-icon-architect: url("./assets/account-icons/Architect%20Icon.png");
  --asset-icon-admin: url("./assets/account-icons/Admin%20Icon.png");
  --asset-icon-organizer: url("./assets/account-icons/Organizer%20Icon.png");
  --asset-icon-activist: url("./assets/account-icons/Activist%20Icon.png");
  --asset-icon-demo: url("./assets/account-icons/Demo%20Icon.png");
}

@media (min-width: 900px) and (max-width: 1400px) and (orientation: landscape) and (pointer: coarse) {
  body.home-page #campaign-glance-widget .issue-row.issue-detail-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) max-content max-content !important;
    column-gap: 12px !important;
    row-gap: 2px !important;
    align-items: start !important;
  }

  body.home-page #campaign-glance-widget .issue-row.issue-detail-row strong {
    min-width: 0 !important;
    line-height: 1.16 !important;
    overflow-wrap: anywhere !important;
  }

  body.home-page #campaign-glance-widget .issue-row.issue-detail-row .issue-count {
    justify-self: end !important;
    min-width: 0 !important;
    text-align: right !important;
    white-space: nowrap !important;
    line-height: 1.12 !important;
  }

  body.home-page #campaign-glance-widget .issue-row.issue-detail-row .issue-context {
    font-size: .74rem !important;
    line-height: 1.12 !important;
    justify-self: end !important;
    text-align: right !important;
    white-space: nowrap !important;
  }
}

body {
  padding-bottom: 0 !important;
}

.utility-header,
.topbar {
  min-height: 108px !important;
  height: 108px !important;
  padding: 0 44px 0 76px !important;
  color: #fff !important;
  background: linear-gradient(90deg, var(--rise-blue) 0%, var(--rise-blue) 66%, #c9ccef 84%, #fff 100%) !important;
  border-bottom: 9px solid var(--rise-yellow) !important;
}

.utility-header {
  display: flex !important;
  align-items: stretch !important;
  justify-content: space-between !important;
}

.utility-brand,
.brand-block {
  height: 100% !important;
  display: flex !important;
  align-items: flex-end !important;
  gap: 10px !important;
  min-width: 0 !important;
  text-decoration: none !important;
  cursor: pointer !important;
}

.tiny-logo,
.brand-mark {
  order: 0 !important;
  flex: 0 0 98px !important;
  align-self: flex-end !important;
  width: 98px !important;
  height: 100% !important;
  display: block !important;
  border: 0 !important;
  color: transparent !important;
  font-size: 0 !important;
  letter-spacing: 0 !important;
  background: var(--asset-rise-header-logo) left bottom -2px / auto 90px no-repeat !important;
}

.utility-brand span:last-child,
.tagline {
  display: none !important;
}

.utility-brand::before,
.role-label::before {
  content: "" !important;
  order: 1 !important;
  width: 28px !important;
  height: 28px !important;
  flex: 0 0 28px !important;
  display: inline-block !important;
  margin: 0 -6px 9px 0 !important;
  background: var(--asset-icon-architect) center / contain no-repeat !important;
}

.utility-brand::after,
.role-label {
  order: 2 !important;
  display: inline-flex !important;
  align-items: center !important;
  margin: 0 0 12px 0 !important;
  color: #fff !important;
  font-family: "Helvetica Now Text", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
  font-size: 1.08rem !important;
  font-weight: 900 !important;
  letter-spacing: .20em !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

.utility-brand::after {
  content: "ARCHITECT" !important;
}

.account-brand::before {
  background-image: var(--asset-icon-architect) !important;
}

.account-brand::after {
  content: attr(data-account-label) !important;
}

.account-brand.account-admin::before,
.account-brand.account-administrator::before {
  background-image: var(--asset-icon-admin) !important;
}

.account-brand.account-organizer::before {
  background-image: var(--asset-icon-organizer) !important;
}

.account-brand.account-activist::before {
  background-image: var(--asset-icon-activist) !important;
}

.account-brand.account-demo::before {
  background-image: var(--asset-icon-demo) !important;
}

.role-label.role-admin::before,
.role-label.administrator::before {
  background-image: var(--asset-icon-admin) !important;
}

.role-label.role-admin,
.role-label.administrator {
  font-size: 1.86rem !important;
}

.role-label.role-admin::after,
.role-label.administrator::after {
  content: "ISTRATOR";
}

.role-label.role-organizer::before {
  background-image: var(--asset-icon-organizer) !important;
}

.role-label.role-activist::before {
  background-image: var(--asset-icon-activist) !important;
}

.role-label.role-demo::before {
  background-image: var(--asset-icon-demo) !important;
}

.utility-actions {
  align-self: stretch !important;
  display: flex !important;
  align-items: center !important;
  gap: 18px !important;
}

.utility-actions .btn,
.topbar .btn {
  padding: 8px 12px !important;
  color: var(--rise-blue) !important;
  background: rgba(255, 255, 255, .76) !important;
  border: 2px solid var(--rise-blue) !important;
  border-radius: 7px !important;
  box-shadow: none !important;
  font-family: "Helvetica Now Text", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
  font-size: .9rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

.bell,

/* === Overlays And Feedback === */
.notification-bell {
  color: var(--rise-blue) !important;
}

.notification-bell {
  width: 44px !important;
  height: 44px !important;
  font-size: 0 !important;
  padding: 0 !important;
}

.notification-bell::before {
  content: "" !important;
  display: block !important;
  width: 34px !important;
  height: 40px !important;
  margin: 2px auto 0 !important;
  border: 4px solid currentColor !important;
  border-bottom: 0 !important;
  border-top-left-radius: 22px !important;
  border-top-right-radius: 22px !important;
}

.notification-bell::after {
  content: "" !important;
  display: block !important;
  width: 40px !important;
  height: 4px !important;
  margin: -3px auto 0 !important;
  background: currentColor !important;
  border-radius: 999px !important;
}

.notification-bell span {
  display: none !important;
}

.notification-bell:has(svg)::before,
.notification-bell:has(svg)::after {
  display: none !important;
  content: none !important;
}

.notification-bell svg {
  display: block !important;
  width: 28px !important;
  height: 28px !important;
  margin: 8px auto 0 !important;
}

.notification-bell.bell-active {
  color: #b80f43 !important;
  animation: riseBellRing 1.8s ease-in-out infinite;
  transform-origin: 50% 12%;
}

.notification-bell.bell-idle {
  color: var(--rise-blue) !important;
  opacity: .72 !important;
  animation: none !important;
}

@keyframes riseBellRing {
  0%, 45%, 100% { transform: rotate(0); }
  7% { transform: rotate(13deg); }
  14% { transform: rotate(-11deg); }
  21% { transform: rotate(8deg); }
  28% { transform: rotate(-6deg); }
  35% { transform: rotate(3deg); }
}

.notification-tray {
  top: 116px !important;
}

.source-tray.notification-tray {
  top: 0 !important;
}

.pulse-header {
  min-height: 188px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 28px 24px 30px !important;
  background: #f2f4f7 !important;
  text-align: center !important;
}

.pulse-header::before {
  content: "" !important;
  display: block !important;
  width: min(34vw, 230px) !important;
  height: 96px !important;
  margin: 0 0 6px !important;
  background: var(--asset-rise-hero) center / contain no-repeat !important;
}

.pulse-header > * {
  display: block !important;
}

.pulse-header .rise-lockup,
.pulse-header .rise-strip {
  display: none !important;
}

.pulse-header h2 {
  margin: 0 !important;
  color: var(--rise-blue) !important;
  font-family: "Helvetica Now Text", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
  font-size: .92rem !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  line-height: 1.05 !important;
}

.pulse-header p {
  margin: 2px 0 0 !important;
  color: #7b8288 !important;
  font-family: "Helvetica Now Text", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
  font-size: .68rem !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
}

.app-container.dashboard-container {
  margin-top: 0 !important;
}

.quick-search-trigger {
  display: inline-flex !important;
  align-items: center !important;
  gap: .42em !important;
}

.quick-search-trigger::before {
  content: "" !important;
  display: inline-block !important;
  width: 1.14em !important;
  height: 1.14em !important;
  background: currentColor !important;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M10.8 4a6.8 6.8 0 0 1 5.36 10.98l3.43 3.43-2.12 2.12-3.43-3.43A6.8 6.8 0 1 1 10.8 4Zm0 3a3.8 3.8 0 1 0 0 7.6 3.8 3.8 0 0 0 0-7.6Z'/%3E%3C/svg%3E") center / contain no-repeat !important;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M10.8 4a6.8 6.8 0 0 1 5.36 10.98l3.43 3.43-2.12 2.12-3.43-3.43A6.8 6.8 0 1 1 10.8 4Zm0 3a3.8 3.8 0 1 0 0 7.6 3.8 3.8 0 0 0 0-7.6Z'/%3E%3C/svg%3E") center / contain no-repeat !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  transform: translateY(.03em) !important;
}

.schedule-card-list {
  display: none !important;
}

.page-footer,
.footer {
  margin: 42px 0 0 !important;
  padding: 24px 22px 32px !important;
  color: #6c757d !important;
  background: #f4f6f8 !important;
  border-top: 5px solid var(--rise-yellow) !important;
  font-size: .74rem !important;
  font-weight: 400 !important;
  line-height: 1.32 !important;
}

.page-footer-inner {
  align-items: end !important;
  display: grid !important;
  gap: 28px !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  margin: 0 auto !important;
  max-width: 1280px !important;
}

.page-footer-brand {
  max-width: 560px !important;
  text-align: left !important;
}

.page-footer-logo {
  display: block !important;
  width: 54px !important;
  height: 54px !important;
  object-fit: contain !important;
  margin: 0 0 8px !important;
}

.page-footer strong,
.footer strong {
  display: block !important;
  margin: 0 0 18px !important;
  color: #4f596f !important;
  font-weight: 900 !important;
}

.page-footer span,
.footer span {
  display: block !important;
  margin: 0 !important;
  font-weight: 400 !important;
}

.page-footer-brand span + span {
  margin-top: 12px !important;
}

.page-footer-links {
  display: grid !important;
  justify-items: end !important;
  min-width: 220px !important;
  text-align: right !important;
}

.page-footer-site {
  align-items: center !important;
  color: var(--rise-blue) !important;
  display: inline-flex !important;
  gap: 7px !important;
  font-size: .84rem !important;
  font-weight: 900 !important;
  text-decoration: none !important;
}

.page-footer-site span,
.page-footer-legal-links span {
  display: inline !important;
  margin: 0 !important;
  max-width: none !important;
}

.page-footer-site-icon {
  align-items: center !important;
  display: inline-flex !important;
  height: 18px !important;
  justify-content: center !important;
  line-height: 1 !important;
  width: 18px !important;
}

.page-footer-site-icon svg {
  display: block !important;
  height: 18px !important;
  stroke: currentColor !important;
  stroke-width: 2.2 !important;
  width: 18px !important;
}

.page-footer-link-divider {
  background: #66717d !important;
  height: 2px !important;
  margin: 10px 0 9px !important;
  width: 100% !important;
}

.page-footer-legal-links {
  align-items: center !important;
  display: flex !important;
  gap: 12px !important;
  justify-content: flex-end !important;
}

.page-footer-legal-links button {
  background: transparent !important;
  border: 0 !important;
  color: #66717d !important;
  cursor: pointer !important;
  font: inherit !important;
  padding: 0 !important;
  text-decoration: none !important;
}

.page-footer-legal-links button:hover,
.page-footer-legal-links button:focus,
.page-footer-site:hover,
.page-footer-site:focus {
  color: var(--rise-blue) !important;
  outline: 0 !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
}

.page-footer::before,
.footer::before {
  content: none !important;
  display: none !important;
}

.page-footer::after,
.footer::after {
  content: none !important;
  display: block !important;
  max-width: 1280px !important;
  margin: 0 auto !important;
  white-space: pre-line !important;
}

.rise-legal-modal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 2200 !important;
  display: none !important;
  place-items: center !important;
  padding: 20px !important;
  background: rgba(17,24,39,.58) !important;
}

.rise-legal-modal.open {
  display: grid !important;
}

.rise-legal-dialog {
  width: min(920px, 100%) !important;
  max-height: min(86vh, 820px) !important;
  background: #fff !important;
  border-radius: 8px !important;
  box-shadow: 0 20px 70px rgba(0,0,0,.35) !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
}

.rise-legal-dialog header {
  align-items: start !important;
  border-bottom: 1px solid #dde1ea !important;
  display: flex !important;
  gap: 18px !important;
  justify-content: space-between !important;
  padding: 22px 26px 18px !important;
}

.rise-legal-dialog h2 {
  color: var(--rise-blue) !important;
  font-size: 1.45rem !important;
  font-weight: 900 !important;
  line-height: 1.12 !important;
  margin: 0 !important;
}

.rise-legal-close {
  background: transparent !important;
  border: 0 !important;
  color: #6c757d !important;
  cursor: pointer !important;
  font-size: 2rem !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  padding: 0 !important;
}

.rise-legal-body {
  color: #343a40 !important;
  font-size: .98rem !important;
  line-height: 1.48 !important;
  overflow: auto !important;
  padding: 24px 30px 32px !important;
}

.rise-legal-body p {
  margin: 0 0 14px !important;
}

.rise-legal-body h3 {
  color: #212529 !important;
  font-size: 1.08rem !important;
  font-weight: 900 !important;
  margin: 22px 0 8px !important;
}

.rise-legal-body ul {
  margin: 0 0 16px 22px !important;
  padding: 0 !important;
}

.rise-legal-body li {
  margin: 0 0 6px !important;
}


/* === Responsive Rules === */
@media (max-width: 640px) {
  body {
    padding-bottom: calc(104px + env(safe-area-inset-bottom)) !important;
    overflow-x: hidden !important;
  }

  .utility-header,
  .topbar {
    width: 100vw !important;
    max-width: 100vw !important;
    min-height: 74px !important;
    height: 74px !important;
    padding: 0 12px 0 0 !important;
    overflow: hidden !important;
  }

  .utility-brand,
  .brand-block {
    align-items: flex-end !important;
    gap: 6px !important;
    min-width: 0 !important;
    overflow: hidden !important;
    padding-left: 10px !important;
  }

  .tiny-logo,
  .brand-mark {
    align-self: flex-end !important;
    flex: 0 0 48px !important;
    width: 48px !important;
    height: 58px !important;
    background: var(--asset-rise-header-logo) left bottom -2px / auto 54px no-repeat !important;
  }

  .utility-brand::before,
  .role-label::before {
    width: 16px !important;
    height: 16px !important;
    flex-basis: 16px !important;
    margin: 0 0 4px 0 !important;
  }

  .utility-brand::after,
  .role-label {
    margin: 0 0 6px 0 !important;
    font-size: .68rem !important;
    letter-spacing: .11em !important;
  }

  .utility-actions {
    align-items: center !important;
    gap: 7px !important;
    flex: 0 0 auto !important;
  }

  .utility-actions .btn,
  .topbar .btn {
    min-width: 38px !important;
    height: 38px !important;
    display: inline-grid !important;
    place-items: center !important;
    padding: 0 9px !important;
    border-width: 2px !important;
    border-radius: 7px !important;
    font-size: .72rem !important;
    line-height: 1 !important;
  }

  .notification-bell {
    width: 38px !important;
    height: 38px !important;
    display: inline-grid !important;
    place-items: center !important;
    margin: 0 !important;
  }

  .notification-bell svg {
    width: 23px !important;
    height: 23px !important;
    margin: 0 !important;
  }

  .source-tray.notification-tray {
    display: none !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    transform: translateX(100%) !important;
    transition: transform .3s cubic-bezier(.4,0,.2,1) !important;
  }

  .source-tray.notification-tray.open {
    display: flex !important;
    transform: translateX(0) !important;
  }

  .source-tray .tray-header {
    padding: 14px 16px 8px !important;
  }

  .source-tray .tray-header .btn {
    min-width: 64px !important;
    min-height: 38px !important;
    padding: 0 12px !important;
    font-size: .76rem !important;
  }

  .source-tray .tray-content {
    padding: 10px 16px 18px !important;
  }

  .source-tray .tray-widget {
    margin-bottom: 18px !important;
    padding: 14px 12px !important;
    background: #fff !important;
    border: 1px solid #dde3ea !important;
    border-left: 5px solid var(--rise-blue) !important;
    border-radius: 12px !important;
    box-shadow: 0 2px 10px rgba(25, 32, 56, .05) !important;
  }

  .source-tray .tray-widget:nth-child(1) {
    border-left-color: #198754 !important;
  }

  .source-tray .tray-widget:nth-child(2) {
    border-left-color: var(--rise-blue) !important;
  }

  .source-tray .tray-widget:nth-child(3) {
    border-left-color: #dc3545 !important;
  }

  .source-tray .tray-widget:nth-child(4) {
    border-left-color: var(--rise-yellow) !important;
  }

  .source-tray .widget-expanded {
    padding: 0 !important;
  }

  .source-tray .widget-expanded h3 {
    line-height: 1.08 !important;
  }

  .source-tray .widget-table-wrap {
    background: #f8fafc !important;
    border-color: #dde3ea !important;
  }

  .source-tray .source-table {
    table-layout: fixed !important;
  }

  .source-tray .source-table th,
  .source-tray .source-table td {
    overflow-wrap: anywhere !important;
  }

  .source-tray .source-table th:last-child,
  .source-tray .source-table td:last-child {
    width: 70px !important;
    text-align: center !important;
  }

  .source-tray .tray-action-btn {
    min-width: 56px !important;
    height: 34px !important;
    padding: 0 8px !important;
    white-space: nowrap !important;
    font-size: .72rem !important;
    line-height: 1 !important;
  }

  .source-tray .field-assignment-widget {
    background: #fff !important;
    box-shadow: 0 2px 10px rgba(25, 32, 56, .05) !important;
  }

  .field-assignment-metrics div {
    min-height: 78px !important;
    padding: 10px 6px 12px !important;
    align-content: center !important;
  }

  .field-assignment-metrics strong {
    line-height: 1.18 !important;
    padding-top: 2px !important;
  }

.page-footer,
  .footer {
    margin-top: 28px !important;
    padding: 18px 14px calc(28px + env(safe-area-inset-bottom)) !important;
    border-top-width: 4px !important;
    font-size: .72rem !important;
    line-height: 1.25 !important;
  }

  .page-footer-inner {
    align-items: start !important;
    gap: 18px !important;
    grid-template-columns: 1fr !important;
  }

  .page-footer-brand,
  .page-footer-links {
    max-width: 34rem !important;
    min-width: 0 !important;
    text-align: left !important;
    width: 100% !important;
  }

  .page-footer-links {
    justify-items: center !important;
    text-align: center !important;
  }

  .page-footer strong,
  .footer strong {
    margin-bottom: 8px !important;
    font-size: .76rem !important;
  }

  .page-footer span,
  .footer span {
    max-width: 34rem !important;
  }

  .page-footer span + span,
  .footer span + span {
    margin-top: 6px !important;
  }

  .page-footer::before,
  .footer::before {
    content: none !important;
    display: none !important;
  }

.page-footer-logo {
    width: 42px !important;
    height: 42px !important;
    margin-bottom: 8px !important;
  }

  .page-footer-legal-links {
    justify-content: center !important;
  }

  .page-footer-site {
    font-size: .82rem !important;
  }

  .rise-legal-modal {
    padding: 12px !important;
  }

  .rise-legal-dialog {
    max-height: calc(100dvh - 24px) !important;
  }

  .rise-legal-dialog header {
    padding: 16px 18px 14px !important;
  }

  .rise-legal-dialog h2 {
    font-size: 1.12rem !important;
  }

  .rise-legal-body {
    font-size: .9rem !important;
    padding: 18px !important;
  }

  .fab-wrapper {
    bottom: max(18px, env(safe-area-inset-bottom)) !important;
  }

  .fab-wrapper.fab-idle {
    opacity: .72 !important;
    filter: none !important;
  }

  .fab-btn {
    width: 54px !important;
    height: 54px !important;
    gap: 3px !important;
  }

  .fab-btn span {
    width: 24px !important;
    height: 3px !important;
  }

  .mode-right {
    left: 14px !important;
  }

  .mode-left {
    right: 14px !important;
  }

  .fab-panel {
    bottom: 62px !important;
    height: auto !important;
    min-height: max-content !important;
    min-width: 230px !important;
    width: min(250px, calc(100vw - 28px)) !important;
    max-height: none !important;
    overflow: visible !important;
    overflow-y: visible !important;
    overscroll-behavior: auto !important;
    border-radius: 10px !important;
    padding: 6px !important;
  }

  .fab-panel.active {
    height: auto !important;
    min-height: max-content !important;
    max-height: none !important;
    overflow: visible !important;
    overflow-y: visible !important;
  }

  .panel-header {
    padding: 7px 12px 4px !important;
    font-size: .66rem !important;
  }

  .panel-item {
    min-height: 38px !important;
    padding: 8px 12px !important;
    border-radius: 7px !important;
    font-size: .82rem !important;
  }

  .panel-divider {
    margin: 5px 0 !important;
  }

  .pulse-header {
    min-height: 166px !important;
  }

  .pulse-header::before {
    width: 70vw !important;
    height: 104px !important;
  }
}

@media (max-width: 640px) {
  body.home-page {
    overflow-x: hidden !important;
    padding-bottom: calc(104px + env(safe-area-inset-bottom)) !important;
  }

  body.home-page .utility-header {
    width: 100vw !important;
    max-width: 100vw !important;
    min-height: 74px !important;
    height: 74px !important;
    padding: 0 12px 0 0 !important;
  }

  body.home-page .utility-brand {
    gap: 6px !important;
    min-width: 0 !important;
    overflow: hidden !important;
    padding-left: 10px !important;
  }

  body.home-page .tiny-logo {
    align-self: flex-end !important;
    flex: 0 0 48px !important;
    width: 48px !important;
    height: 58px !important;
    background: var(--asset-rise-header-logo) left bottom -2px / auto 54px no-repeat !important;
  }

  body.home-page .utility-brand::before {
    width: 16px !important;
    height: 16px !important;
    flex-basis: 16px !important;
    margin: 0 0 4px 0 !important;
  }

  body.home-page .utility-brand::after {
    margin: 0 0 6px 0 !important;
    font-size: .68rem !important;
    letter-spacing: .11em !important;
  }

  body.home-page .utility-actions {
    align-items: center !important;
    gap: 7px !important;
    flex: 0 0 auto !important;
  }

  body.home-page .source-tray.notification-tray {
    display: none !important;
    right: 0 !important;
    transform: translateX(100%) !important;
    transition: transform .3s cubic-bezier(.4,0,.2,1) !important;
  }

  body.home-page .source-tray.notification-tray.open {
    display: flex !important;
    transform: translateX(0) !important;
  }

  body.home-page .utility-actions .btn,
  body.home-page .notification-bell {
    width: auto !important;
    min-width: 38px !important;
    height: 38px !important;
    display: inline-grid !important;
    place-items: center !important;
    margin: 0 !important;
  }

  body.home-page .utility-actions .btn {
    padding: 0 9px !important;
    font-size: .72rem !important;
    line-height: 1 !important;
  }

  body.home-page .notification-bell svg {
    width: 23px !important;
    height: 23px !important;
    margin: 0 !important;
  }

  body.home-page .pulse-header {
    min-height: 128px !important;
    padding: 16px 16px 18px !important;
  }

  body.home-page .pulse-header::before {
    width: min(48vw, 195px) !important;
    height: 70px !important;
    margin: 0 auto 3px !important;
  }

  body.home-page .pulse-header h2,
  body.home-page .pulse-header p {
    width: 100% !important;
    text-align: center !important;
  }

  body.home-page .app-container.dashboard-container.source-home {
    width: calc(100vw - 16px) !important;
    margin: 0 8px !important;
    padding: 24px 12px 22px !important;
    border-radius: 8px !important;
  }

  body:has(.outreach-page):not(.public-outreach-page) .outreach-page {
    width: calc(100vw - 16px) !important;
    margin: 16px 8px 0 !important;
    padding: 24px 12px 72px !important;
    border-radius: 8px !important;
  }

  body.home-page .source-home .mb-5 {
    margin-bottom: 28px !important;
  }

  body.home-page .page-title {
    font-size: clamp(1.85rem, 9vw, 2.55rem) !important;
    line-height: .96 !important;
  }

  body.home-page .quick-search-trigger {
    width: min(100%, 290px) !important;
    min-height: 48px !important;
    justify-content: center !important;
    font-size: 1rem !important;
  }

  body.home-page .demo-link {
    display: block !important;
    line-height: 1.08 !important;
  }

  body.home-page .membership-card {
    padding: 14px 8px 16px !important;
  }

  body.home-page .membership-card .card-header {
    font-size: .95rem !important;
    letter-spacing: .12em !important;
  }

  body.home-page .rise-chart-wrapper {
    width: calc(100% + 16px) !important;
    height: clamp(180px, 47vw, 212px) !important;
    margin: 0 -8px 14px !important;
  }

  body.home-page .rise-chart-wrapper svg text {
    font-size: 9px !important;
  }

  body.home-page .source-insights,
  body.home-page .glance-live {
    grid-template-columns: 1fr !important;
  }

  body.home-page .source-insights {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  body.home-page .source-insights .metric,
  body.home-page .threshold-panel {
    width: 100% !important;
    min-width: 0 !important;
  }

  body.home-page .source-insights .metric {
    min-height: 76px !important;
    padding: 8px 4px !important;
    border-radius: 7px !important;
  }

  body.home-page .source-insights .metric span {
    font-size: .56rem !important;
    line-height: 1.05 !important;
  }

  body.home-page .source-insights .metric strong {
    font-size: clamp(1.22rem, 6vw, 1.72rem) !important;
    line-height: 1 !important;
  }

  body.home-page .threshold-panel {
    grid-column: 1 / -1 !important;
  }

  body.home-page .threshold-control {
    grid-template-columns: minmax(84px, max-content) minmax(0, 1fr) 54px !important;
    gap: 8px !important;
    align-items: center !important;
  }

  body.home-page .threshold-control label {
    font-size: .78rem !important;
    line-height: 1 !important;
  }

  body.home-page .threshold-control input[type="range"] {
    width: 100% !important;
    min-width: 0 !important;
  }

  body.home-page .threshold-number {
    width: 100% !important;
    min-width: 0 !important;
  }

  body.home-page .threshold-actions {
    justify-content: stretch !important;
  }

  body.home-page .threshold-actions .btn {
    flex: 1 1 130px !important;
  }

  body.home-page .fab-wrapper {
    bottom: max(18px, env(safe-area-inset-bottom)) !important;
  }

  body.home-page .treemap-container {
    height: 330px !important;
  }

  body.home-page .density-legend {
    width: min(100%, 230px) !important;
    margin: 8px auto 0 !important;
  }

  body.home-page .glance-summary {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    column-gap: 0 !important;
    row-gap: 8px !important;
    align-items: start !important;
    justify-items: stretch !important;
    margin-bottom: 16px !important;
  }

  body.home-page .glance-summary b {
    display: flex !important;
    min-height: 44px !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    min-width: 0 !important;
    width: 100% !important;
    font-size: .84rem !important;
    line-height: 1.05 !important;
    text-align: center !important;
    overflow-wrap: anywhere !important;
  }

  body.home-page .glance-summary .glance-summary-label,
  body.home-page .glance-summary .glance-summary-value {
    display: block !important;
    margin-top: 2px !important;
    max-width: 100% !important;
    text-align: center !important;
  }

  body.home-page .glance-summary .glance-summary-label {
    font-size: .84rem !important;
    line-height: 1.05 !important;
    white-space: normal !important;
  }

  body.home-page .glance-summary .glance-summary-value {
    font-size: .98rem !important;
    line-height: 1 !important;
  }

  body.home-page .glance-right .grid-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  body.home-page .glance-right .grid-2 .metric {
    min-height: 80px !important;
    padding: 10px 6px !important;
  }

  body.home-page .glance-left,
  body.home-page .glance-right {
    width: 100% !important;
    min-width: 0 !important;
    border-left: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  body.home-page #campaign-glance-widget {
    padding: 16px 12px !important;
  }

  body.home-page #campaign-glance-widget .card-header {
    margin-bottom: 12px !important;
  }

  body.home-page .glance-title {
    margin: 18px 0 10px !important;
  }

  body.home-page .density-note {
    margin-bottom: 10px !important;
    font-size: .95rem !important;
    line-height: 1.15 !important;
  }

  body.home-page .micro-title {
    font-size: clamp(1.25rem, 7vw, 1.75rem) !important;
    line-height: 1.05 !important;
    margin: 0 0 12px !important;
    overflow-wrap: anywhere !important;
  }

  body.home-page .source-table-wrap {
    width: 100% !important;
    max-width: 100% !important;
    max-height: 360px !important;
    overflow: auto !important;
  }

  body.home-page .source-table {
    width: 100% !important;
    table-layout: fixed !important;
    font-size: .78rem !important;
  }

  body.home-page .source-table th,
  body.home-page .source-table td {
    padding: 7px 6px !important;
    overflow-wrap: anywhere !important;
    vertical-align: top !important;
  }

  body.home-page .source-table th:nth-child(1),
  body.home-page .source-table td:nth-child(1) { width: 27% !important; }
  body.home-page .source-table th:nth-child(2),
  body.home-page .source-table td:nth-child(2) { width: 31% !important; }
  body.home-page .source-table th:nth-child(3),
  body.home-page .source-table td:nth-child(3) { width: 13% !important; }
  body.home-page .source-table th:nth-child(4),
  body.home-page .source-table td:nth-child(4) { width: 16% !important; }

  body.home-page #glance-state3-left .text-end {
    text-align: left !important;
  }

  body.home-page #glance-state3-left .text-end .btn {
    width: 100% !important;
    white-space: normal !important;
  }

  body.home-page .target-box,
  body.home-page .callout-box {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  body.home-page .stacked-bar {
    height: 16px !important;
    margin: 8px 0 8px !important;
  }

  body.home-page .scale-row {
    margin: 0 0 16px !important;
    font-size: .62rem !important;
  }

  body.home-page .hover-note {
    margin: 2px 0 16px !important;
  }

  body.home-page .hover-label {
    font-size: 0 !important;
  }

  body.home-page .hover-label::before {
    content: "Tap" !important;
    font-size: .72rem !important;
  }

  body.home-page .callout-box {
    padding: 10px !important;
    margin-bottom: 16px !important;
  }

  body.home-page #global-issues-list {
    max-height: none !important;
    overflow: visible !important;
  }

  body.home-page .issue-row,
  body.home-page .issue-row.issue-detail-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(112px, max-content) !important;
    gap: 8px !important;
    align-items: start !important;
    padding: 8px 0 !important;
    font-size: .82rem !important;
  }

  body.home-page .issue-row strong {
    min-width: 0 !important;
    line-height: 1.16 !important;
    overflow-wrap: anywhere !important;
  }

  body.home-page .issue-row.issue-detail-row .issue-count {
    justify-self: end !important;
    min-width: 0 !important;
    text-align: right !important;
    white-space: nowrap !important;
  }

  body.home-page .issue-row.issue-detail-row .issue-context {
    grid-column: 1 / -1 !important;
    justify-self: end !important;
    min-width: 0 !important;
    text-align: right !important;
    white-space: normal !important;
  }

  body.home-page .issue-row span,
  body.home-page .issue-row.issue-detail-row span {
    display: grid !important;
    gap: 2px !important;
    min-width: 0 !important;
    text-align: right !important;
    line-height: 1.12 !important;
  }

  body.home-page .issue-row.issue-detail-row .issue-context {
    font-size: .72rem !important;
    line-height: 1.12 !important;
  }

  body.home-page .target-box {
    max-height: 160px !important;
    font-size: .82rem !important;
  }

  body.home-page .source-modal {
    align-items: start !important;
    padding: 122px 22px 22px !important;
  }

  body.home-page #demoOverviewModal.source-modal {
    align-items: center !important;
    padding: 18px 22px !important;
  }

  body.home-page #demoOverviewModal .modal-content {
    width: 100% !important;
    max-height: calc(100dvh - 36px) !important;
    border-radius: 14px !important;
    overflow: hidden !important;
  }

  body.home-page #demoOverviewModal .modal-header {
    padding: 16px 22px !important;
  }

  body.home-page #demoOverviewModal .modal-header h2 {
    font-size: clamp(1.35rem, 6.4vw, 1.9rem) !important;
    line-height: 1.05 !important;
  }

  body.home-page #demoOverviewModal .modal-body {
    max-height: calc(100dvh - 142px) !important;
    overflow: auto !important;
    padding: 22px !important;
  }

  body.home-page .quick-search-modal-content {
    width: 100% !important;
    max-height: calc(100dvh - 152px) !important;
    border-radius: 0 0 14px 14px !important;
    overflow: visible !important;
  }

  body.home-page .quick-search-modal-content .modal-header {
    padding: 16px 22px !important;
  }

  body.home-page .quick-search-modal-content .modal-header h2 {
    font-size: clamp(1.45rem, 7vw, 2rem) !important;
    line-height: 1 !important;
  }

  body.home-page .quick-search-modal-content .modal-body {
    max-height: calc(100dvh - 236px) !important;
    overflow: auto !important;
    padding: 22px !important;
  }

  body.home-page #quickSearchModal:not(.has-member-result) .quick-search-modal-content .modal-body {
    overflow: visible !important;
  }

  body.home-page .quick-search-box {
    margin-bottom: 18px !important;
  }

  body.home-page .qs-details {
    grid-template-columns: minmax(0, 1fr) 96px !important;
    gap: 12px !important;
    align-items: start !important;
  }

  body.home-page .qs-main {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 12px !important;
    border-right: 0 !important;
    padding-right: 0 !important;
  }

  body.home-page .qs-main h3 {
    grid-column: 1 !important;
    max-width: 100% !important;
    font-size: clamp(1.8rem, 9vw, 2.45rem) !important;
    line-height: 1.02 !important;
    margin: 0 !important;
    overflow-wrap: anywhere !important;
  }

  body.home-page .qs-main > .muted {
    grid-column: 1 !important;
    margin: 0 !important;
    font-size: .96rem !important;
    line-height: 1.15 !important;
  }

  body.home-page .qs-side {
    grid-column: 2 !important;
    grid-row: 1 !important;
    display: grid !important;
    gap: 8px !important;
    width: 96px !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
  }

  body.home-page .qs-assessment-card {
    width: 96px !important;
    height: 96px !important;
    min-height: 96px !important;
    overflow: hidden !important;
    padding: 10px 7px !important;
    border: 1px solid var(--line) !important;
    border-radius: 8px !important;
    background: #f8f9fa !important;
    text-align: center !important;
  }

  body.home-page .qs-side span,
  body.home-page .qs-assessment-card span {
    font-size: .58rem !important;
    letter-spacing: .05em !important;
  }

  body.home-page .qs-assessment-card strong {
    font-size: 2rem !important;
    margin: 6px 0 3px !important;
  }

  body.home-page .qs-assessment-card[data-cfs-assessment="true"] span,
  body.home-page .qs-assessment-card[data-cfs-assessment="true"] strong,
  body.home-page .qs-assessment-card[data-cfs-assessment="true"] small,
  body.home-page .schedule-assess-box[data-cfs-assessment="true"] span,
  body.home-page .schedule-assess-box[data-cfs-assessment="true"] strong {
    color: var(--assessment-text-color, #212529) !important;
  }

  body.home-page .qs-assessment-card b {
    display: none !important;
  }

  body.home-page .qs-side .schedule-alert-box {
    display: grid !important;
    gap: 6px !important;
    width: 96px !important;
    margin: 0 !important;
    padding: 8px 6px !important;
    font-size: .66rem !important;
    line-height: 1.12 !important;
    text-align: center !important;
  }

body.home-page .qs-side .schedule-alert-box .btn {
  width: 100% !important;
  min-height: 30px !important;
  padding: 0 6px !important;
}

body.home-page .utility-actions .btn,
body.home-page .quick-search-trigger,
body.home-page .source-modal .btn,
body.home-page .qs-side .schedule-alert-box .btn,
body.home-page .threshold-actions .btn,
body.home-page .activist-map-actions .btn,
body.home-page .activist-modal-actions .btn,
body.home-page .map-person-actions .btn {
  border-radius: 999px !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
}

  body.home-page #quickSearchModal.has-member-result .qs-results-dropdown,
  body.home-page #quickSearchModal.has-member-result .quick-search-box > span {
    display: none !important;
  }

  body.home-page .qs-assessment-card.score-1 { background: #cfe2f3 !important; border-color: #9fc5e8 !important; }
  body.home-page .qs-assessment-card.score-2 { background: #d9ead3 !important; border-color: #b6d7a8 !important; }
  body.home-page .qs-assessment-card.score-3 { background: #ffe599 !important; border-color: #f1c232 !important; }
  body.home-page .qs-assessment-card.score-4 { background: #f4cccc !important; border-color: #e6b8af !important; }

  body.home-page .qs-grid {
    grid-column: 1 / -1 !important;
    grid-template-columns: 1fr !important;
    gap: 4px !important;
  }

  body.home-page .qs-grid span {
    margin-top: 8px !important;
  }

  body.home-page .qs-grid strong {
    line-height: 1.08 !important;
  }

  body.home-page .qs-grid small {
    margin: 1px 0 !important;
    line-height: 1.12 !important;
  }

  body.home-page .qs-grid .qs-work-location-row {
    display: grid !important;
    gap: 2px !important;
    grid-template-columns: 1fr !important;
  }

  body.home-page .qs-grid .qs-work-location-row .qs-work-location-divider {
    display: none !important;
  }

  body.home-page .qs-grid .qs-work-location-row .qs-work-location-field {
    display: block !important;
    min-width: 0 !important;
    overflow-wrap: anywhere !important;
  }

  body.home-page .qs-grid .qs-work-location-row .qs-work-location-field span,
  body.home-page .qs-grid .qs-work-location-row .qs-work-location-field b {
    display: inline !important;
    margin-top: 0 !important;
  }

  body.home-page #qs-work-details-label {
    font-size: 0 !important;
  }

  body.home-page #qs-work-details-label::before {
    content: "College/Department" !important;
    font-size: .68rem !important;
  }

  body.home-page .schedule-modal-content {
    width: 100% !important;
    max-height: calc(100dvh - 122px) !important;
    border-radius: 0 0 14px 14px !important;
    overflow: hidden !important;
  }

  body.home-page .schedule-modal-content .modal-body {
    max-height: calc(100dvh - 212px) !important;
    overflow: auto !important;
    padding: 18px !important;
  }

  body.home-page .schedule-modal-card {
    padding: 16px !important;
    border-top-width: 4px !important;
    border-radius: 8px !important;
  }

  body.home-page .schedule-header {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 104px !important;
    gap: 12px !important;
    align-items: start !important;
    margin-bottom: 14px !important;
  }

  body.home-page .schedule-header h3 {
    max-width: 100% !important;
    font-size: clamp(1.55rem, 8vw, 2.05rem) !important;
    line-height: 1.08 !important;
    overflow-wrap: anywhere !important;
  }

  body.home-page .schedule-header p {
    font-size: .95rem !important;
    line-height: 1.18 !important;
  }

  body.home-page .schedule-assess-box {
    width: 104px !important;
    min-width: 0 !important;
    min-height: 92px !important;
    padding: 10px 8px !important;
    display: grid !important;
    place-items: center !important;
    text-align: center !important;
  }

  body.home-page .schedule-assess-box span {
    font-size: .58rem !important;
    line-height: 1.05 !important;
  }

  body.home-page .schedule-assess-box strong {
    font-size: 1.9rem !important;
  }

  body.home-page .schedule-mini-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0 !important;
    margin: 10px 0 18px !important;
    border-top: 1px solid #eef1f5 !important;
  }

  body.home-page .schedule-mini-grid div {
    display: grid !important;
    grid-template-columns: 82px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: baseline !important;
    min-width: 0 !important;
    padding: 10px 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-bottom: 1px solid #eef1f5 !important;
    border-radius: 0 !important;
  }

  body.home-page .schedule-mini-grid span {
    font-size: .68rem !important;
  }

  body.home-page .schedule-mini-grid strong {
    min-width: 0 !important;
    font-size: 1rem !important;
    line-height: 1.15 !important;
    overflow-wrap: anywhere !important;
  }

  body.home-page .schedule-table-wrap {
    display: none !important;
  }

  body.home-page .schedule-card-list {
    display: grid !important;
    gap: 10px !important;
  }

  body.home-page .schedule-course-card {
    display: grid !important;
    gap: 8px !important;
    padding: 12px !important;
    border: 1px solid var(--line) !important;
    border-left: 4px solid var(--rise-blue) !important;
    border-radius: 8px !important;
    background: #fff !important;
  }

  body.home-page .schedule-course-time {
    display: flex !important;
    justify-content: space-between !important;
    gap: 10px !important;
    color: var(--muted) !important;
    font-size: .8rem !important;
    font-weight: 900 !important;
  }

  body.home-page .schedule-course-main strong {
    display: block !important;
    color: #212529 !important;
    font-size: 1.06rem !important;
    line-height: 1.1 !important;
  }

  body.home-page .schedule-course-main span,
  body.home-page .schedule-course-room {
    display: block !important;
    color: var(--muted) !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
    overflow-wrap: anywhere !important;
  }
}

@media (max-width: 900px) {
  body.home-page #campaign-glance-widget .glance-summary {
    display: grid !important;
    align-items: flex-start !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 0 !important;
    width: 100% !important;
  }

  body.home-page #campaign-glance-widget .glance-summary .glance-summary-item {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    min-width: 0 !important;
    width: 100% !important;
  }

  body.home-page #campaign-glance-widget .glance-summary .glance-summary-item:nth-child(1) {
    align-items: flex-start !important;
    text-align: left !important;
  }

  body.home-page #campaign-glance-widget .glance-summary .glance-summary-item:nth-child(2) {
    align-items: center !important;
    text-align: center !important;
  }

  body.home-page #campaign-glance-widget .glance-summary .glance-summary-item:nth-child(3) {
    align-items: flex-end !important;
    text-align: right !important;
  }

  body.home-page #campaign-glance-widget .glance-summary .glance-summary-label,
  body.home-page #campaign-glance-widget .glance-summary .glance-summary-value {
    text-align: inherit !important;
  }
}
