/* MyStay-inspired UI overrides (Bootstrap 5 + Phoenix) */
:root{
  --phoenix-font-sans-serif: 'Roboto', system-ui, -apple-system, 'Segoe UI', Arial, sans-serif;
  --phoenix-body-font-family: var(--phoenix-font-sans-serif);
  --rd-green: #0ea86b;
  --rd-green-700: #008245;
  --rd-primary: var(--rd-green);
  --rd-primary-700: var(--rd-green-700);
  --rd-primary-rgb: 14 168 107;
  --rd-primary-700-rgb: 0 130 69;
  --rd-bg: #F1F5F9;
  --rd-border: #CBD5E1;
  --rd-shadow: 0 6px 16px rgba(15, 23, 42, 0.06);
  --rd-radius: 12px;
  --rd-ink: #1E293B;
  --rd-muted: #64748B;
  --rd-card: #FFFFFF;
  --rd-row-hover: #F8FAFC;
  --rd-font-root: 16px;
  --rd-font-page-title: 1.5rem;      /* 24px */
  --rd-font-section-title: 1.125rem; /* 18px */
  --rd-font-card-title: 1rem;        /* 16px */
  --rd-font-body: 0.875rem;          /* 14px */
  --rd-font-ui: 0.875rem;      /* 14px */
  --rd-font-table: 0.8125rem;        /* 13px */
  --rd-font-meta: 0.75rem;           /* 12px */
  --phoenix-navbar-vertical-width: 14rem; /* 224px */
}

html{
  font-size: var(--rd-font-root);
}

.rd-app{
  background: var(--rd-bg);
  color: var(--rd-ink);
  font-size: var(--rd-font-body);
  line-height: 1.45;
  font-family: var(--phoenix-font-sans-serif);
  letter-spacing: -0.01em;
}

.rd-app h1,
.rd-app .page-title{
  font-size: var(--rd-font-page-title);
  line-height: 1.2;
  font-weight: 600;
}

.rd-app h2,
.rd-app h3,
.rd-app .section-title,
.rd-app .rd-section-title{
  font-size: var(--rd-font-section-title);
  line-height: 1.2;
  font-weight: 600;
}

.rd-app .card-title,
.rd-app .rd-card-title{
  font-size: var(--rd-font-card-title);
  line-height: 1.25;
  font-weight: 500;
}

.rd-app label,
.rd-app .form-label,
.rd-app input,
.rd-app select,
.rd-app textarea,
.rd-app .form-control,
.rd-app .form-select,
.rd-app .btn,
.rd-app .nav-link{
  font-size: var(--rd-font-ui);
  line-height: 1.45;
}

.rd-app table{
  font-size: var(--rd-font-table);
  line-height: 1.35;
}

.rd-app th{
  font-size: var(--rd-font-table);
  line-height: 1.35;
  font-weight: 500;
}

.rd-app td{
  font-size: var(--rd-font-ui);
  line-height: 1.4;
}

.rd-app small,
.rd-app .small,
.rd-app .muted,
.rd-app .text-body-secondary.small,
.rd-app .rd-help,
.rd-app .badge{
  font-size: var(--rd-font-meta) !important;
  line-height: 1.4;
}

.rd-app .content{
  background: linear-gradient(180deg, #f8fafc 0%, var(--rd-bg) 220px);
  padding-top: 72px;
  padding-left: 0 !important;
  padding-right: 0 !important;
  overflow-x: clip;
  min-height: calc(100vh - 64px);
}

.rd-app .content > .container-fluid{
  max-width: 100% !important;
  padding-left: 0.5rem !important;
  padding-right: 0.5rem !important;
}

@media (min-width: 992px){
  /* Strong override for Phoenix default desktop content gutters. */
  .rd-app .navbar-vertical.navbar-expand-lg ~ .navbar-top ~ .content{
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Keep a small margin on desktop. */
  .rd-app .content > .container-fluid{
    padding-left: 0.75rem !important;
    padding-right: 0.75rem !important;
  }
}

.rd-app #dashboard-filters.rd-card{
  padding: 14px 18px;
}

@media (min-width: 640px){
  .rd-app #dashboard-filters.rd-card{
    padding: 16px 22px;
  }
}

.rd-app #dashboard-filters.rd-card > summary{
  gap: 12px;
}

.rd-app #dashboard-filters.rd-card .rd-help{
  margin-top: 2px;
  font-size: 0.8125rem;
  line-height: 1.2;
}

.rd-app #dashboard-filters.rd-card > div{
  margin-top: 12px;
  padding-top: 12px;
}

.rd-app .nav-link-icon svg{ width: 18px; height: 18px; }

.rd-app .card{
  border-radius: var(--rd-radius);
  border-color: var(--rd-border);
  box-shadow: var(--rd-shadow);
  background: var(--rd-card);
  border: 1px solid var(--rd-border);
}

.rd-app .card-header{
  border-bottom-color: var(--rd-border);
}

.rd-app .card-body,
.rd-app .card-header,
.rd-app .card-footer{
  padding: 1rem;
}

.rd-app .btn-success{
  background: var(--rd-green);
  border-color: var(--rd-green);
  box-shadow: 0 4px 10px rgb(var(--rd-primary-rgb) / 0.20);
  border-radius: 10px;
  font-weight: 700;
  color: #fff;
}
.rd-app .btn-success:hover,
.rd-app .btn-success:focus{
  background: var(--rd-green-700);
  border-color: var(--rd-green-700);
  color: #fff;
  box-shadow: 0 6px 14px rgb(var(--rd-primary-rgb) / 0.24);
}
.rd-app .btn-success:active{
  background: var(--rd-green-700);
  border-color: var(--rd-green-700);
}
.rd-app .btn-success:focus{
  box-shadow: 0 0 0 .2rem rgb(var(--rd-primary-rgb) / 0.22);
}

.rd-app .navbar-vertical{
  border-right: 1px solid rgba(15, 36, 55, 0.10);
  background: #fff;
  box-shadow: none;
}

.rd-app .navbar-vertical .navbar-brand{
  letter-spacing: -0.01em;
}

.rd-app .navbar-vertical .nav-item-wrapper{
  padding: 0 8px;
}
.rd-app .navbar-vertical .navbar-nav .nav-link{
  border-radius: 12px;
  margin: 2px 0;
  padding: 8px 12px;
  font-size: var(--rd-font-ui);
  font-weight: 500;
}

.rd-app .navbar-vertical .navbar-nav .nav-link:hover{
  background: rgb(var(--rd-primary-rgb) / 0.06);
}

.rd-app .navbar-vertical .navbar-nav .nav-link.active{
  background: rgb(var(--rd-primary-rgb) / 0.10);
  color: var(--rd-green-700);
  position: relative;
  box-shadow: none;
}
.rd-app .navbar-vertical .navbar-nav .nav-link.active::before{
  content: '';
  position: absolute;
  left: 10px;
  top: 8px;
  bottom: 8px;
  width: 3px;
  border-radius: 999px;
  background: rgb(var(--rd-primary-rgb) / 0.62);
}

.rd-app .navbar-top{
  border-bottom: 1px solid rgba(15, 36, 55, 0.08);
  background: #fff;
  box-shadow: none;
  height: 60px;
  min-height: 60px;
  padding: 0;
  z-index: 1040;
}

.rd-app .navbar-top .dropdown-menu{
  z-index: 1060;
}

.rd-app .modal .choices__list--dropdown,
.rd-app .modal .choices__list[aria-expanded]{
  z-index: 2000;
}

.rd-app #move-payments-modal .modal-body{
  overflow: visible;
}

/* Tenants: compact status cards row */
.rd-app .rd-tenant-status-cards{
  gap: 10px !important;
}
.rd-app .rd-tenant-status-cards .rd-surface{
  padding: 12px 14px !important;
}
.rd-app .rd-tenant-status-cards .rd-kicker{
  margin-bottom: 4px;
}
.rd-app .rd-tenant-status-cards .rd-surface .text-4xl{
  font-size: 32px !important;
  line-height: 1.05 !important;
}
.rd-app .rd-tenant-status-cards .rd-surface .rd-help{
  margin-top: 6px !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rd-app .rd-tenant-status-cards .rd-surface .rd-badge{
  padding: 6px 12px;
}

/* Tenants: compact hero header card */
.rd-app .rd-tenants-hero.rd-card{
  padding: 16px 18px !important;
}
@media (min-width: 640px){
  .rd-app .rd-tenants-hero.rd-card{
    padding: 18px 22px !important;
  }
}
.rd-app .rd-tenants-hero .rd-title{
  margin-top: 6px !important;
  font-size: 28px !important;
  line-height: 1.1 !important;
}
.rd-app .rd-tenants-hero .rd-subtitle{
  margin-top: 4px !important;
  font-size: 0.95rem;
}
.rd-app .rd-tenants-hero .rd-btn{
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}
.rd-app .rd-tenants-hero .rd-badge{
  padding-top: 4px !important;
  padding-bottom: 4px !important;
}

.rd-app .navbar-top::after{
  display: none;
}

.rd-app .navbar-top .collapse.navbar-collapse{
  height: 60px;
  min-height: 60px;
  padding: 0 16px;
  align-items: center;
  flex-wrap: nowrap;
}

.rd-app .navbar-top .navbar-toggler{
  padding: 6px 10px;
  border-radius: 14px;
}

.rd-app .navbar-top .navbar-toggler:hover{
  background: rgb(var(--rd-primary-rgb) / 0.06);
}

.rd-mobile-nav{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1030;
  padding: 10px 10px calc(10px + env(safe-area-inset-bottom));
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(12px);
  border-top: 1px solid rgba(15, 36, 55, 0.10);
  box-shadow: 0 -12px 28px rgba(15, 36, 55, 0.08);
}

.rd-mobile-nav-inner{
  display: flex;
  gap: 8px;
  align-items: stretch;
  justify-content: space-between;
}

.rd-mobile-nav-item{
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 6px;
  border-radius: 16px;
  border: 1px solid rgba(15, 36, 55, 0.16);
  background: rgba(255, 255, 255, 0.85);
  color: var(--rd-ink);
  text-decoration: none;
  font-weight: 800;
  min-height: 56px;
}

.rd-mobile-nav-item:hover{
  background: rgb(var(--rd-primary-rgb) / 0.06);
  color: var(--rd-ink);
}

.rd-mobile-nav-item.is-active{
  background: rgb(var(--rd-primary-rgb) / 0.10);
  border-color: rgb(var(--rd-primary-rgb) / 0.28);
  color: var(--rd-green-700);
}

.rd-mobile-nav-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
}

.rd-mobile-nav-icon svg{ width: 20px; height: 20px; }

.rd-mobile-nav-label{
  font-size: 11px;
  line-height: 1.1;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

@media (max-width: 767.98px){
  .rd-app .content{
    padding-top: 16px;
    padding-bottom: 90px;
  }

  .rd-app .navbar-top{
    height: auto;
    min-height: 52px;
    padding: 0;
    padding-top: env(safe-area-inset-top, 0px);
  }

  .rd-app .navbar-top.fixed-top{
    position: relative !important;
    top: auto;
  }

  .rd-app .navbar-top .collapse.navbar-collapse{
    height: auto;
    min-height: 52px;
    padding: 10px 10px 8px;
    align-items: center;
    flex-wrap: wrap;
    row-gap: 10px;
  }

  .rd-app .navbar-top .navbar-toggler{
    padding: 4px 6px;
  }

  .rd-app .navbar-top .navbar-logo{
    order: 1;
    flex: 1 1 auto;
    min-width: 0;
  }

  .rd-app .navbar-top .navbar-nav.navbar-nav-icons{
    order: 2;
    margin-left: auto;
    flex: 0 0 auto;
  }

  .rd-app .navbar-top .rd-top-search-mobile{
    order: 3;
    flex: 1 0 100%;
  }

  .rd-app .rd-brand-fallback{
    width: 24px;
    height: 24px;
  }

  .rd-app .rd-topnav-user{
    padding: 2px 6px;
    gap: 6px;
    border-radius: 12px;
    box-shadow: none;
  }

  .rd-app .navbar-top .avatar.avatar-l{
    width: 2rem;
    height: 2rem;
  }
}

.rd-module-btn{
  border-radius: 10px;
  padding: 10px 14px;
  font-weight: 800;
  border: 1px solid rgba(15, 36, 55, 0.18);
  background: rgba(255,255,255,0.94);
  color: var(--rd-ink);
  box-shadow: none;
}
.rd-module-btn:hover{
  background: #fff;
  border-color: rgba(15, 36, 55, 0.26);
}
.rd-module-btn.is-active{
  background: var(--rd-green);
  border-color: var(--rd-green);
  color: #fff;
}
.rd-module-btn.active{
  background: var(--rd-green);
  border-color: var(--rd-green);
  color: #fff;
}
.rd-module-btn.is-active:hover{
  background: var(--rd-green-700);
  border-color: var(--rd-green-700);
}
.rd-module-btn.active:hover{
  background: var(--rd-green-700);
  border-color: var(--rd-green-700);
}

.rd-soft{
  background: rgb(var(--rd-primary-rgb) / 0.06);
  border: 0;
  box-shadow: none;
}

.rd-icon-bubble{
  width: 48px;
  height: 48px;
  border-radius: 16px;
  background: rgb(var(--rd-primary-rgb) / 0.10);
  color: var(--rd-green);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.rd-progress{
  height: 12px;
  border-radius: 999px;
  background: rgb(var(--rd-primary-rgb) / 0.14);
}
.rd-progress .progress-bar{
  border-radius: 999px;
}

.rd-check-item{
  border-radius: 16px;
  border: 1px solid rgba(15, 36, 55, 0.08);
  background: var(--rd-card);
}

.rd-check-item.is-done{
  border-color: rgb(var(--rd-primary-rgb) / 0.22);
  background: rgb(var(--rd-primary-rgb) / 0.08);
}

.rd-kpi-title{
  letter-spacing: .18em;
}

.rd-toolbar{
  background: #fff;
  border: 1px solid rgba(15, 36, 55, 0.08);
  border-radius: var(--rd-radius);
  padding: 12px;
  box-shadow: none;
}

.rd-accordion-item{
  border: 1px solid rgba(15, 36, 55, 0.08);
  border-radius: var(--rd-radius);
  overflow: hidden;
  box-shadow: none;
  background: var(--rd-card);
}

.rd-accordion-item .accordion-button{
  background: var(--rd-card);
}

.rd-accordion-item .accordion-button:focus{
  box-shadow: 0 0 0 .2rem rgb(var(--rd-primary-rgb) / 0.16);
}

.rd-page-hero{
  border-radius: calc(var(--rd-radius) + 4px);
  border: 1px solid var(--rd-border);
  background: #fff;
  box-shadow: none;
  padding: 1rem 1.125rem !important;
}

.rd-page-hero .rd-page-kicker{
  letter-spacing: .22em;
}

.rd-report-card{
  border-radius: var(--rd-radius);
  border: 1px solid rgba(15, 36, 55, 0.08);
  box-shadow: none;
  background: var(--rd-card);
  transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.rd-report-card:hover{
  transform: none;
  box-shadow: none;
  border-color: rgb(var(--rd-primary-rgb) / 0.18);
}

.rd-report-card--disabled{
  opacity: .65;
  box-shadow: none;
}

.rd-report-card--disabled:hover{
  transform: none;
  border-color: rgba(15, 36, 55, 0.08);
}

.rd-report-title{
  letter-spacing: .16em;
}

.rd-stat-card{
  border: 1px solid rgba(15, 36, 55, 0.08);
  border-radius: var(--rd-radius);
  background: var(--rd-card);
  box-shadow: none;
}

.rd-stat-card.is-active{
  border-color: rgb(var(--rd-primary-rgb) / 0.22);
  box-shadow: none;
}

.rd-subtle-link{
  color: inherit;
  text-decoration: none;
}
.rd-subtle-link:hover{
  color: inherit;
  text-decoration: none;
}

.rd-sidebar-heading{
  font-size: var(--rd-font-meta);
  color: var(--rd-muted);
  letter-spacing: .14em;
}

.rd-nav-icon{
  color: var(--rd-green);
}

.rd-nav-text{
  font-size: var(--rd-font-ui);
}

/* Fix: when Phoenix collapses the vertical navbar, hide our custom section headings and count badges. */
html.navbar-vertical-collapsed .rd-app .navbar-vertical .rd-sidebar-heading{
  display: none !important;
}
html.navbar-vertical-collapsed .rd-app .navbar-vertical .rd-nav-text{
  display: none !important;
}
html.navbar-vertical-collapsed .rd-app .navbar-vertical .rd-nav-count{
  display: none !important;
}
html.navbar-vertical-collapsed .rd-app .navbar-vertical .nav-link .nav-link-icon{
  margin-right: 0 !important;
}

/* Fix: ensure content shifts left when sidebar is collapsed (Phoenix keeps margin-left at the expanded width). */
@media (min-width: 992px){
  /* Phoenix collapses the vertical nav with position:absolute but doesn't pin it; keep it flush to the left. */
  html.navbar-vertical-collapsed .rd-app .navbar-vertical.navbar-expand-lg{
    left: 0 !important;
  }

  html.navbar-vertical-collapsed .rd-app .navbar-vertical.navbar-expand-lg ~ .navbar-top ~ .content{
    margin-left: 4rem !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Backup selector (in case the sibling chain changes). */
  html.navbar-vertical-collapsed .rd-app .content{
    margin-left: 4rem !important;
  }

  /* Tighten our custom sidebar spacing for the collapsed icon-only rail. */
  html.navbar-vertical-collapsed .rd-app .navbar-vertical .nav-item-wrapper{
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  html.navbar-vertical-collapsed .rd-app .navbar-vertical .navbar-nav .nav-link{
    padding-left: 0 !important;
    padding-right: 0 !important;
    justify-content: center !important;
  }
  html.navbar-vertical-collapsed .rd-app .navbar-vertical .navbar-nav .nav-link.active::before{
    display: none !important;
  }
}

.rd-filter-card{
  border-radius: var(--rd-radius);
  border: 1px solid var(--rd-border);
  background: var(--rd-card);
  box-shadow: none;
}

.rd-filter-card .form-label{
  font-weight: 700;
  color: var(--rd-muted);
}

.rd-filter-card .card-body{
  padding: 1rem 1.125rem !important;
}

.rd-pill-nav{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.rd-pill-btn{
  border-radius: 999px;
  padding: 10px 16px;
  border: 1px solid rgba(15, 36, 55, 0.16);
  background: rgba(255, 255, 255, 0.94);
  color: var(--rd-ink);
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.rd-pill-btn:hover{
  border-color: rgba(15, 36, 55, 0.26);
  background: #fff;
  color: var(--rd-ink);
  text-decoration: none;
}

.rd-pill-btn.is-active{
  background: var(--rd-green);
  border-color: var(--rd-green);
  color: #fff;
  box-shadow: none;
}

.rd-month-nav{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.rd-month-btn{
  min-width: 72px;
  justify-content: center;
  padding: 10px 0;
}

.rd-table-card{
  border-radius: var(--rd-radius);
  overflow: hidden;
}

.rd-table{
  margin-bottom: 0;
}

.rd-table thead th{
  background: rgb(var(--rd-primary-rgb) / 0.06);
  color: var(--rd-muted);
  font-size: var(--rd-font-table);
  font-weight: 600;
  letter-spacing: .03em;
  text-transform: none;
  border-bottom-color: var(--rd-border);
  white-space: nowrap;
  position: sticky;
  top: 0;
  z-index: 2;
  padding-top: 10px;
  padding-bottom: 10px;
}

.rd-table tbody td{
  border-top-color: var(--rd-border);
  color: var(--rd-ink);
  padding-top: 9px;
  padding-bottom: 9px;
}

.rd-table tbody tr.rd-clickable{
  cursor: pointer;
}

.rd-table tbody tr.rd-clickable:hover{
  background: var(--rd-row-hover);
}

.rd-table-card .table-responsive{
  overflow: auto;
}

.rd-app .table-hover > tbody > tr:hover > *{
  background-color: var(--rd-row-hover);
}

.rd-zone-row{
  background-image: linear-gradient(90deg, var(--zone-bg, transparent) 0, transparent 220px);
  background-repeat: no-repeat;
}

.rd-zone-row td:first-child{
  position: relative;
}

.rd-zone-row td:first-child::before{
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 6px;
  background: var(--zone-accent, transparent);
}

.rd-zone-pill{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .02em;
  border: 1px solid rgba(15, 36, 55, 0.10);
  white-space: nowrap;
  text-decoration: none;
  background: var(--zone-bg, rgb(var(--rd-primary-rgb) / 0.06));
  color: var(--zone-text, var(--rd-ink));
}

.rd-zone-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  display: inline-block;
  background: var(--zone-accent, rgb(var(--rd-primary-rgb) / 0.55));
}

.rd-min-w-0{ min-width: 0; }

/* Legacy tenant page helpers (kept for compatibility; scoped to admin shell). */
.rd-app .section-card{
  background: var(--rd-card);
  border-radius: calc(var(--rd-radius) + 4px);
  padding: 16px;
  border: 1px solid var(--rd-border);
  box-shadow: var(--rd-shadow);
  margin-top: 24px;
}
.rd-app .section-header{
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 14px;
}
.rd-app .section-header h3{ margin: 0; }
.rd-app .table-wrapper{
  overflow-x: auto;
  border-radius: 12px;
}

.rd-icon-bubble.is-featured{
  background: rgb(var(--rd-primary-rgb) / 0.14);
}

.rd-icon-bubble.is-disabled{
  background: rgba(15, 36, 55, 0.06);
  color: rgba(15, 36, 55, 0.45);
}

.rd-brand-logo{ object-fit: contain; }
.rd-brand-fallback{
  width: 27px;
  height: 27px;
  background: rgb(var(--rd-primary-rgb) / 0.12);
  color: var(--rd-green);
  font-weight: 800;
}
.rd-brand-text{ color: var(--rd-green); }
.rd-user-role{ font-size: 12px; }
.rd-topnav-user{
  gap: 10px;
  padding: 6px 10px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid rgba(15, 36, 55, 0.10);
  box-shadow: none;
  transition: background .15s ease, border-color .15s ease;
}

.rd-topnav-user:hover{
  background: #f8fafc;
  border-color: rgb(var(--rd-primary-rgb) / 0.18);
}

/* Centered overlays used in tenant actions */
#vacate-tenant-modal,
#activate-tenant-modal,
#add-utility-modal,
#add-opening-balance-modal,
#add-payment-modal,
#edit-tenant-payment-modal,
#add-unit-modal,
#edit-tenant-unit-modal,
#assign-unit-modal,
#manage-deposit-modal,
#move-payments-modal {
  align-items: center;
  justify-content: center;
  padding: 16px;
}
#vacate-tenant-modal.show,
#activate-tenant-modal.show,
#add-utility-modal.show,
#add-opening-balance-modal.show,
#add-payment-modal.show,
#edit-tenant-payment-modal.show,
#add-unit-modal.show,
#edit-tenant-unit-modal.show,
#assign-unit-modal.show,
#manage-deposit-modal.show,
#move-payments-modal.show {
  display: flex !important;
}

/* Bootstrap 5.2-compatible "subtle" badges (Phoenix theme doesn't ship 5.3 utility classes). */
.text-bg-primary-subtle{ background: rgba(13,110,253,0.12) !important; color: rgba(13,110,253,0.92) !important; }
.text-bg-success-subtle{ background: rgb(var(--rd-primary-rgb) / 0.14) !important; color: var(--rd-primary-700) !important; }
.text-bg-info-subtle{ background: rgba(13,202,240,0.14) !important; color: rgba(8,126,156,0.95) !important; }
.text-bg-warning-subtle{ background: rgba(255,193,7,0.18) !important; color: rgba(154,93,0,0.95) !important; }
.text-bg-danger-subtle{ background: rgba(220,53,69,0.14) !important; color: rgba(176,42,55,0.95) !important; }
.text-bg-secondary-subtle{ background: rgba(108,117,125,0.14) !important; color: rgba(63,73,83,0.95) !important; }

.rd-print-hide{}

/* Legacy forms in older pages (no .form-control/.form-select classes). */
.rd-app .muted{
  color: var(--rd-muted);
}

.rd-app .field label{
  display: block;
  margin-bottom: 6px;
  font-weight: 700;
  color: var(--rd-muted);
}

.rd-app .field input:not([type="checkbox"]):not([type="radio"]),
.rd-app .field select,
.rd-app .field textarea{
  width: 100%;
  border: 1px solid rgba(15, 36, 55, 0.18);
  border-radius: 10px;
  padding: 8px 10px;
  min-height: 38px;
  background: var(--rd-card);
  color: var(--rd-ink);
  outline: none;
}

.rd-app .form-control,
.rd-app .form-select,
.rd-app input,
.rd-app select,
.rd-app textarea{
  min-height: 38px;
  border-radius: 10px;
}

.rd-app .btn{
  min-height: 36px;
  padding-top: 6px;
  padding-bottom: 6px;
  border-radius: 10px;
}

.rd-app .rd-top-search .form-control[data-rd-global-search]{
  min-width: 260px;
}

.rd-app .rd-top-search .form-control[data-rd-global-search]:focus{
  border-color: rgb(var(--rd-primary-rgb) / 0.5);
  box-shadow: 0 0 0 0.2rem rgb(var(--rd-primary-rgb) / 0.16);
}

.rd-app.rd-density-compact{
  --rd-font-page-title: 1.35rem;
  --rd-font-section-title: 1rem;
  --rd-font-card-title: 0.9375rem;
  --rd-font-body: 0.8125rem;
  --rd-font-ui: 0.8125rem;
  --rd-font-table: 0.75rem;
  --rd-font-meta: 0.6875rem;
}

.rd-app.rd-density-compact .card-body,
.rd-app.rd-density-compact .card-header,
.rd-app.rd-density-compact .card-footer{
  padding: 0.75rem !important;
}

.rd-app.rd-density-compact .rd-page-hero{
  padding: 0.75rem 0.9rem !important;
}

.rd-app.rd-density-compact .rd-filter-card .card-body{
  padding: 0.75rem 0.9rem !important;
}

.rd-app.rd-density-compact .rd-table thead th{
  padding-top: 7px;
  padding-bottom: 7px;
}

.rd-app.rd-density-compact .rd-table tbody td{
  padding-top: 7px;
  padding-bottom: 7px;
}

.rd-app.rd-density-compact .form-control,
.rd-app.rd-density-compact .form-select,
.rd-app.rd-density-compact input,
.rd-app.rd-density-compact select,
.rd-app.rd-density-compact textarea{
  min-height: 34px;
}

.rd-app.rd-density-compact .btn{
  min-height: 32px;
  padding-top: 4px;
  padding-bottom: 4px;
}

#rd-toast-stack .toast{
  min-width: 320px;
  max-width: 420px;
}

#rd-toast-stack .rd-toast{
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.12);
}

#rd-toast-stack .rd-toast .toast-body{
  font-size: 0.84rem;
  line-height: 1.45;
}

#rd-toast-stack .rd-toast-success{
  background: #ecfdf3;
  color: #166534;
}

#rd-toast-stack .rd-toast-danger{
  background: #fef2f2;
  color: #991b1b;
}

#rd-toast-stack .rd-toast-warning{
  background: #fffbeb;
  color: #92400e;
}

#rd-toast-stack .rd-toast-info{
  background: #eff6ff;
  color: #1e3a8a;
}

.rd-app .field input:not([type="checkbox"]):not([type="radio"]):focus,
.rd-app .field select:focus,
.rd-app .field textarea:focus{
  border-color: rgb(var(--rd-primary-rgb) / 0.55);
  box-shadow: 0 0 0 .2rem rgb(var(--rd-primary-rgb) / 0.18);
}

.rd-app .field input[readonly],
.rd-app .field select:disabled,
.rd-app .field input:disabled,
.rd-app .field textarea:disabled{
  background: rgba(15, 36, 55, 0.04);
  color: rgba(15, 36, 55, 0.55);
}

@media print{
  .rd-print-hide,
  .navbar-top,
  .navbar-vertical,
  .navbar-vertical-footer,
  header,
  footer,
  nav,
  aside{
    display: none !important;
  }

  body.rd-app,
  .rd-app{
    background: #fff !important;
  }

  .rd-app .content{
    padding-top: 0 !important;
    background: #fff !important;
  }

  .rd-app .container-xxl{
    max-width: 100% !important;
  }

  .rd-app .card{
    box-shadow: none !important;
  }
}
/* Modal stacking fixes */
.modal { z-index: 1080; }
.modal-backdrop { z-index: 1075; }
.modal.show {
  display: flex !important;
  align-items: center;
  justify-content: center;
}
