/* Core layout and base configurations */

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
  height: 100%;
  overflow: hidden;
}

body {
  font-family: var(--font-sans);
  background-color: var(--bg-app);
  color: var(--text-primary);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transition: background-color var(--transition-normal), color var(--transition-normal);
  overflow: hidden;
  height: 100%;
}

/* Scrollbar Customization */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--scrollbar-track);
}

::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--border-hover);
}

/* Typography styles */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.25;
  color: var(--text-primary);
  letter-spacing: 0;
}

h1 { font-size: clamp(1.75rem, 4vw, 2.5rem); }
h2 { font-size: clamp(1.35rem, 3vw, 1.85rem); }
h3 { font-size: clamp(1.15rem, 2vw, 1.45rem); }

#page-title,
.login-title,
.modal-title,
.drawer-title {
  font-family: var(--font-display);
  font-weight: 800;
  letter-spacing: 0;
}

#page-subtitle,
.text-stone-500,
.text-muted {
  color: #334155;
  line-height: 1.55;
}

[data-theme="dark"] #page-subtitle,
[data-theme="dark"] .text-stone-500,
[data-theme="dark"] .text-muted {
  color: #d7dfcf;
}

a {
  color: var(--color-brand);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-brand-hover);
}

/* Layout Architecture */
.app-shell {
  display: grid;
  grid-template-rows: auto 1fr;
  grid-template-columns: 280px 1fr;
  height: 100vh;
  position: relative;
  overflow: hidden;
}

/* Sidebar Styling (Static Desktop) */
.sidebar {
  grid-column: 1;
  grid-row: 2;
  background-color: var(--bg-sidebar);
  border-right: 1px solid var(--border-color);
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  transition: background-color var(--transition-normal), border-color var(--transition-normal);
}

/* Main Content Area */
.main-wrapper {
  grid-column: 2;
  grid-row: 2;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

.main-header {
  grid-column: 1 / -1;
  grid-row: 1;
  position: relative;
  z-index: 90;
  background: linear-gradient(180deg, #07180d 0%, #0b1f10 100%) !important;
  border-bottom: 1px solid rgba(154, 190, 112, 0.18) !important;
  padding: 2.25rem 2rem !important;
  height: 16rem !important;
  min-height: 16rem !important;
  max-height: 16rem !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  transition: all var(--transition-normal);
  flex-shrink: 0;
  overflow: hidden;
}

.main-header h1 {
  font-family: Georgia, "Times New Roman", serif !important;
  font-size: clamp(1.45rem, 3vw, 2.4rem) !important;
  font-weight: 800 !important;
  color: #ffffff !important;
  margin: 0.5rem auto 0 !important;
  max-width: 920px !important;
  line-height: 1.25 !important;
}

.main-header h1 em {
  color: #b88318 !important;
  font-style: italic !important;
  font-weight: 500 !important;
}

.main-header p {
  margin: 0.45rem auto 0 !important;
  max-width: 640px !important;
  color: rgba(255, 255, 255, 0.72) !important;
  font-size: 0.76rem !important;
  line-height: 1.45 !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}

.main-header .btn-outline {
  border: 1px solid rgba(154, 190, 112, 0.3) !important;
  background: rgba(96, 143, 61, 0.1) !important;
  color: #9abe70 !important;
}

.main-header .btn-outline:hover {
  border-color: #9abe70 !important;
  background: rgba(96, 143, 61, 0.2) !important;
  color: #ffffff !important;
}

.content-pane {
  padding: 2rem;
  flex-grow: 1;
  max-width: 1600px;
  width: 100%;
  margin: 0 auto;
  overflow-y: auto;
}

body.dashboard-route-active .main-header {
  display: none !important;
}

body.dashboard-route-active .sidebar {
  display: none !important;
}

body.dashboard-route-active .main-wrapper {
  grid-column: 1 / -1 !important;
  grid-row: 1 / -1 !important;
  height: 100vh !important;
}

body.dashboard-route-active .content-pane {
  padding-top: 0;
  max-width: none;
}

body:has(#tab-dashboard.active) .main-header,
body:has(#tab-dashboard.active) .mobile-top-bar {
  display: none !important;
}

body:has(#tab-dashboard.active) .content-pane {
  padding-top: 0 !important;
}

body.payments-route-active .main-wrapper,
body.payments-route-active .content-pane,
body.payments-route-active #tab-payments,
body:has(#tab-payments.active) .main-wrapper,
body:has(#tab-payments.active) .content-pane,
body:has(#tab-payments.active) #tab-payments {
  min-height: 0;
}

body.payments-route-active .content-pane,
body:has(#tab-payments.active) .content-pane {
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch;
  padding-bottom: max(4rem, env(safe-area-inset-bottom, 0px));
}

body.payments-route-active #tab-payments,
body:has(#tab-payments.active) #tab-payments {
  overflow: visible !important;
  padding-bottom: 4rem;
}

@media (max-width: 768px) {
  body.dashboard-route-active .mobile-nav-menu {
    display: flex;
  }

  body.dashboard-route-active .mobile-top-bar {
    display: none !important;
  }
}

/* Mobile Layout Overrides */
.mobile-top-bar {
  display: none;
  background-color: var(--bg-sidebar);
  border-bottom: 1px solid var(--border-color);
  padding: 0.65rem 1rem;
  position: sticky;
  top: 0;
  z-index: 95;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.mobile-brand-lockup {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  min-width: 0;
}

.mobile-brand-lockup span {
  color: var(--text-primary);
  font-size: 0.9rem;
  line-height: 1.15;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mobile-header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-shrink: 0;
}

.mobile-theme-button {
  width: 2.25rem;
  height: 2.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 0;
  border: 1px solid var(--border-color);
  border-radius: var(--radius-full);
  background-color: var(--bg-card);
  color: var(--color-brand);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  transition: background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);
}

.mobile-theme-button:hover {
  border-color: var(--color-brand);
  background-color: var(--color-brand-light);
  transform: translateY(-1px);
}

.mobile-theme-button svg {
  width: 1rem;
  height: 1rem;
}

.mobile-nav-menu {
  display: none;
  position: fixed;
  bottom: max(env(safe-area-inset-bottom, 0px), var(--mobile-browser-bottom));
  left: 0;
  right: 0;
  z-index: 1000;
  background-color: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border-top: 1px solid var(--border-color);
  min-height: var(--mobile-nav-height);
  padding: 0.45rem 0.65rem;
  justify-content: space-between;
  gap: 0.25rem;
  overflow-x: visible;
  overflow-y: hidden;
  overscroll-behavior-x: contain;
  scrollbar-width: none;
  box-shadow: 0 -4px 12px rgba(0,0,0,0.05);
}

.mobile-more-menu {
  position: fixed;
  left: 0.75rem;
  right: 0.75rem;
  bottom: calc(var(--mobile-nav-height) + max(env(safe-area-inset-bottom, 0px), var(--mobile-browser-bottom)) + 2.1rem);
  z-index: 1001;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.55rem;
  padding: 0.8rem;
  border: 1.5px solid #1f2d3d;
  border-radius: 0.9rem;
  background: #ffffff;
  box-shadow: 0 18px 38px rgba(17, 24, 39, 0.18);
  opacity: 0;
  pointer-events: none;
  transform: translateY(0.65rem) scale(0.98);
  transition: opacity var(--transition-fast), transform var(--transition-fast);
  max-height: min(24rem, calc(100dvh - var(--mobile-nav-height) - max(env(safe-area-inset-bottom, 0px), var(--mobile-browser-bottom)) - 2rem));
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.mobile-nav-item#mobile-more-toggle[aria-expanded="true"],
body.mobile-more-open .mobile-nav-item#mobile-more-toggle {
  color: #111827;
  background: rgba(154, 190, 112, 0.35);
}

.mobile-more-menu.open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

body.mobile-more-open .mobile-more-menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.mobile-more-item {
  min-height: 4rem;
  padding: 0.7rem;
  border: 1px solid #d9dfd2;
  border-radius: 0.65rem;
  background: #fbfcf8;
  color: #111827;
  text-align: left;
  cursor: pointer;
}

.mobile-more-item span {
  display: block;
  color: #111827;
  font-family: var(--font-display);
  font-size: 0.94rem;
  font-weight: 800;
  line-height: 1.1;
}

.mobile-more-item small {
  display: block;
  margin-top: 0.22rem;
  color: #5b8f3a;
  font-size: 0.62rem;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.mobile-more-item.active {
  border-color: #5b8f3a;
  background: #eef5ea;
}

.mobile-nav-menu::-webkit-scrollbar {
  display: none;
}

/* Micro Animations & Keyframes */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes slideUp {
  from { transform: translateY(20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

@keyframes slideInRight {
  from { transform: translateX(100%); }
  to { transform: translateX(0); }
}

@keyframes tabEnter {
  from { opacity: 0; transform: translateX(15px); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes cardReveal {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

.animate-fade-in {
  animation: fadeIn var(--transition-normal) forwards;
}

.animate-slide-up {
  animation: slideUp var(--transition-slow) forwards;
}

.animate-tab-enter {
  animation: tabEnter var(--transition-normal) cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.animate-card-reveal {
  opacity: 0;
  animation: cardReveal 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay: calc(var(--i, 0) * 0.05s);
}

/* Media Queries */
@media (max-width: 1024px) {
  html,
  body {
    height: 100%;
    overflow: hidden;
  }

  .app-shell {
    display: grid !important;
    grid-template-columns: 1fr;
    grid-template-rows: auto minmax(0, 1fr);
    height: 100vh;
    min-height: 100vh;
    height: 100dvh;
    min-height: 100dvh;
    overflow: hidden;
  }
  
  .sidebar {
    display: none; /* hidden desktop sidebar */
  }
  
  .main-wrapper {
    grid-column: 1;
    grid-row: 2;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    position: relative !important;
    top: auto !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    height: 100% !important;
    min-height: 0;
    padding-bottom: 0 !important;
  }
  
  .main-header {
    display: flex !important;
    grid-column: 1;
    grid-row: 1;
    height: calc(7.25rem + env(safe-area-inset-top, 0px)) !important;
    min-height: calc(7.25rem + env(safe-area-inset-top, 0px)) !important;
    max-height: calc(7.25rem + env(safe-area-inset-top, 0px)) !important;
    padding: calc(0.68rem + env(safe-area-inset-top, 0px)) 3rem 0.72rem 4.35rem !important;
    align-items: flex-start !important;
    justify-content: center !important;
    text-align: left !important;
    gap: 0.2rem;
    overflow: hidden !important;
  }

  .main-header > a {
    position: absolute !important;
    top: calc(0.85rem + env(safe-area-inset-top, 0px)) !important;
    left: 0.95rem !important;
  }

  .main-header .dashboard-hero-logo {
    width: 2.55rem !important;
    margin: 0 !important;
  }

  .main-header .dashboard-kicker {
    margin: 0 0 0.28rem 0 !important;
    padding: 0.16rem 0.5rem !important;
    font-size: 0.54rem !important;
    letter-spacing: 0.08em !important;
    line-height: 1.1 !important;
  }

  .main-header h1 {
    margin: 0 !important;
    font-size: clamp(1.18rem, 5.5vw, 1.45rem) !important;
    line-height: 1.05 !important;
    max-width: 17rem !important;
  }

  .main-header p {
    margin: 0.28rem 0 0 !important;
    max-width: 17rem !important;
    font-size: 0.6rem !important;
    line-height: 1.25 !important;
  }

  .main-header > div[style*="position: absolute"] {
    top: calc(0.75rem + env(safe-area-inset-top, 0px)) !important;
    right: 0.85rem !important;
  }

  .main-header #notif-btn {
    width: 2.15rem !important;
    height: 2.15rem !important;
  }

  body.dashboard-route-active .main-header {
    display: none !important;
  }

  body.dashboard-route-active .mobile-top-bar {
    display: none !important;
  }
  
  .mobile-top-bar {
    display: none !important;
    grid-column: 1;
    grid-row: 1;
    position: relative;
    flex-shrink: 0;
  }
  
  .mobile-nav-menu {
    display: flex;
    position: fixed !important;
  }
  
  .content-pane {
    padding: 0.85rem 1rem calc(var(--mobile-nav-height) + max(env(safe-area-inset-bottom, 0px), var(--mobile-browser-bottom)) + 1.5rem) 1rem !important;
    flex: 1;
    min-height: 0;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    height: auto !important;
    scroll-padding-bottom: calc(var(--mobile-nav-height) + max(env(safe-area-inset-bottom, 0px), var(--mobile-browser-bottom)) + 1.5rem);
    overscroll-behavior-y: contain;
  }

  .tab-view.active {
    min-height: 100%;
    padding-bottom: 0.5rem;
  }

  /* Force inline grids to stack into 1 column on tablet and mobile */
  .grid[style*="grid-template-columns: 2fr 1fr"],
  .grid[style*="grid-template-columns: 2.2fr 1fr"],
  .grid[style*="grid-template-columns: 1fr 380px"],
  .grid[style*="grid-template-columns: 1.25fr 1fr"],
  .grid[style*="grid-template-columns: repeat(3, 1fr)"],
  .grid[style*="grid-template-columns: 1fr 1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }

  /* Referral pipeline summary stats columns layout wrap */
  .grid[style*="grid-template-columns: repeat(4, 1fr)"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* Handle flex wrapping safely */
  .flex-wrap {
    flex-wrap: wrap !important;
  }

  /* Force search bars and selectors to stretch on mobile/tablet */
  .search-wrapper {
    width: 100% !important;
    max-width: none !important;
  }

  .glass-card .flex.gap-3.align-center.flex-wrap {
    width: 100%;
  }

  .glass-card .flex.gap-3.align-center.flex-wrap > .form-group,
  .glass-card .flex.gap-3.align-center.flex-wrap > .btn,
  .glass-card .flex.gap-3.align-center.flex-wrap select {
    width: 100% !important;
  }

  /* Responsive styling for the details profile drawer modal */
  #details-drawer {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    margin: 0 !important;
    transform: none !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100vh !important;
    max-height: 100vh !important;
    border-radius: 0 !important;
    border: none !important;
    display: flex !important;
    flex-direction: column !important;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-normal) !important;
  }

  #details-drawer.open {
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  #details-drawer .drawer-header {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    padding: 1rem !important;
    padding-top: calc(1rem + env(safe-area-inset-top, 0px)) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    border-bottom: 1px solid var(--border-color) !important;
    background: transparent !important;
    z-index: 200 !important;
  }

  #details-drawer .drawer-header h3 {
    display: block !important;
    font-size: 1.25rem !important;
    margin: 0 !important;
    font-weight: 600 !important;
    color: var(--text-primary) !important;
  }

  #details-drawer .drawer-header #details-drawer-close-btn {
    color: var(--text-primary) !important;
    background-color: var(--bg-card) !important;
    border: 1px solid var(--border-color) !important;
    box-shadow: var(--shadow-md) !important;
    border-radius: var(--radius-full) !important;
    width: 2.25rem !important;
    height: 2.25rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 1.5rem !important;
    line-height: 1 !important;
    opacity: 1 !important;
    position: relative !important;
    top: auto !important;
    right: auto !important;
    cursor: pointer !important;
  }

  #details-drawer .drawer-body {
    padding: 1rem !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    flex: 1 !important;
  }

  /* Force inner container to grow past 100% height to enable outer scrolling */
  #details-drawer .drawer-body > div {
    height: auto !important;
    min-height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
  }

  /* Make profile drawer tab navigation scroll horizontally */
  .profile-tabs-nav {
    overflow-x: auto !important;
    white-space: nowrap !important;
    flex-wrap: nowrap !important;
    padding-bottom: 0.5rem !important;
    -webkit-overflow-scrolling: touch;
  }

  .profile-tabs-nav button {
    flex-shrink: 0 !important;
  }

  /* Adjust spacing in the drawer info headers */
  #details-drawer .drawer-body [style*="min-width: 320px"] {
    min-width: 0 !important;
    width: 100% !important;
  }

  #details-drawer .drawer-body [style*="margin-right: 2.25rem"] {
    margin-right: 0 !important;
    width: 100% !important;
  }

  /* Stacking the 480px fixed height cards */
  #details-drawer .drawer-body .glass-card[style*="height: 480px"] {
    height: auto !important;
    max-height: none !important;
    min-height: auto !important;
  }

  #details-drawer .drawer-body .glass-card [style*="flex-grow: 1"] {
    max-height: none !important;
    overflow-y: visible !important;
  }

  #details-drawer,
  #details-drawer *,
  #details-drawer *::before,
  #details-drawer *::after {
    box-sizing: border-box !important;
  }

  #details-drawer .drawer-body,
  #details-drawer .drawer-body > div,
  #details-drawer .glass-card,
  #details-drawer .grid,
  #details-drawer .flex {
    max-width: 100% !important;
    min-width: 0 !important;
  }

  #details-drawer table {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    white-space: nowrap !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .payment-roster-pane {
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    display: flex !important;
    flex-direction: column !important;
  }

  .payment-roster-pane .payment-roster-list {
    flex: 0 1 auto !important;
    max-height: none !important;
    overflow-y: visible !important;
    -webkit-overflow-scrolling: touch !important;
  }

  /* Mobile Dashboard Welcome Hero Card & Alert Layout overrides (Stitch Mobile Designs) */
  .tab-view#tab-dashboard > div > .glass-card:first-child {
    background: linear-gradient(135deg, #1b3820, #0f2214) !important; /* Premium dark forest green */
    border: 1px solid #234d2c !important;
    padding: 1.75rem 1.5rem !important;
    text-align: left !important;
    align-items: flex-start !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-lg), 0 10px 25px rgba(27,56,32,0.15) !important;
  }

  .tab-view#tab-dashboard > div > .glass-card:first-child h2 {
    color: #ffffff !important;
    text-align: left !important;
    font-size: 1.5rem !important;
    line-height: 1.3 !important;
    max-width: 100% !important;
  }

  .tab-view#tab-dashboard > div > .glass-card:first-child h2 span {
    color: #5ea35d !important;
  }

  .tab-view#tab-dashboard > div > .glass-card:first-child p {
    color: rgba(255, 255, 255, 0.75) !important;
    text-align: left !important;
    font-size: 0.85rem !important;
    margin-top: 0.75rem !important;
  }

  /* Action buttons container in Hero */
  .tab-view#tab-dashboard > div > .glass-card:first-child .flex.justify-center.gap-3.mt-6 {
    flex-direction: column !important;
    width: 100% !important;
    gap: 0.75rem !important;
    margin-top: 1.5rem !important;
  }

  /* Button 1: Manage Residents */
  .tab-view#tab-dashboard > div > .glass-card:first-child .flex.justify-center.gap-3.mt-6 button:first-child {
    background-color: #5ea35d !important;
    color: #0d120a !important;
    border: none !important;
    width: 100% !important;
    border-radius: var(--radius-full) !important;
    padding: 0.75rem 1.25rem !important;
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    justify-content: center !important;
    box-shadow: 0 4px 12px rgba(94,163,93,0.2) !important;
  }

  /* Button 2: View Housing Map */
  .tab-view#tab-dashboard > div > .glass-card:first-child .flex.justify-center.gap-3.mt-6 button:last-child {
    background-color: transparent !important;
    color: #5ea35d !important;
    border: 1.5px solid #5ea35d !important;
    width: 100% !important;
    border-radius: var(--radius-full) !important;
    padding: 0.75rem 1.25rem !important;
    font-weight: 700 !important;
    font-size: 0.9rem !important;
    justify-content: center !important;
  }

  /* Operations Action Required Alert Banner (Stitch Mobile Designs) */
  .tab-view#tab-dashboard > div > .glass-card[style*="background-color: var(--color-warning-bg)"] {
    flex-direction: column !important;
    align-items: stretch !important;
    background-color: #1a1916 !important;
    border: 1px solid var(--color-warning) !important;
    padding: 1.25rem !important;
  }

  .tab-view#tab-dashboard > div > .glass-card[style*="background-color: var(--color-warning-bg)"] .flex.align-center.gap-2 {
    align-items: flex-start !important;
  }

  .tab-view#tab-dashboard > div > .glass-card[style*="background-color: var(--color-warning-bg)"] .btn {
    width: 100% !important;
    margin-top: 1rem !important;
    background-color: #5ea35d !important;
    color: #0d120a !important;
    border: none !important;
    border-radius: var(--radius-md) !important;
    padding: 0.65rem !important;
    font-weight: 700 !important;
  }

  .payment-mobile-toggle {
    display: flex !important;
    position: sticky;
    top: 0;
    z-index: 10;
  }

  #tab-payments,
  #tab-payments > *,
  #tab-payments .payment-roster-layout,
  #tab-payments .payment-roster-pane,
  #tab-payments .payment-statement-card,
  #tab-payments .payment-statement-card > *,
  #tab-payments .payment-statement-card-printable,
  #tab-payments .payment-statement-card-printable > *,
  #tab-payments .statement-doc-header,
  #tab-payments .statement-recipient-grid,
  #tab-payments .statement-recipient-box,
  #tab-payments .statement-metrics-panel,
  #tab-payments .ledger-balance-box {
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  #tab-payments {
    overflow-x: hidden !important;
  }

  #tab-payments .payment-roster-layout {
    width: 100% !important;
    overflow-x: hidden !important;
  }

  #tab-payments .payment-statement-card {
    overflow-x: hidden !important;
  }

  #tab-payments .payment-mobile-toggle {
    max-width: 100% !important;
    min-width: 0 !important;
  }

  #tab-payments .payment-mobile-toggle .btn {
    min-width: 0 !important;
    width: auto !important;
    flex: 1 1 0 !important;
    white-space: normal !important;
  }

  #tab-payments .statement-doc-header .no-print,
  #tab-payments .payment-actions-bar {
    width: 100% !important;
    min-width: 0 !important;
    flex-wrap: wrap !important;
    justify-content: stretch !important;
  }

  #tab-payments .statement-doc-header .no-print .btn,
  #tab-payments .payment-actions-bar .btn {
    flex: 1 1 100% !important;
    min-width: 0 !important;
  }

  #tab-payments [style*="overflow-x: auto"],
  #tab-payments [style*="grid-template-columns"] {
    max-width: 100% !important;
    min-width: 0 !important;
  }

  #tab-payments .premium-ledger-table {
    max-width: 100% !important;
  }
}

@media (max-width: 480px) {
  /* On small mobile phones, let 2 column grids stack */
  .grid[style*="grid-template-columns: 1fr 1fr; gap: 0.75rem;"],
  .grid[style*="grid-template-columns: repeat(2, 1fr)"],
  .grid[style*="grid-template-columns: repeat(4, 1fr)"] {
    grid-template-columns: 1fr !important;
  }

  .flex.justify-center.gap-3.mt-6 {
    flex-direction: column !important;
  }

  .flex.justify-center.gap-3.mt-6 button {
    width: 100% !important;
  }
}


/* Utility Helpers */
.flex { display: flex; }
.flex-col { flex-direction: column; }
.align-center { align-items: center; }
.justify-between { justify-content: space-between; }
.grid { display: grid; }
.gap-1 { gap: 0.25rem; }
.gap-2 { gap: 0.5rem; }
.gap-3 { gap: 0.75rem; }
.gap-4 { gap: 1rem; }
.gap-6 { gap: 1.5rem; }
.gap-8 { gap: 2rem; }

.mt-1 { margin-top: 0.25rem; }
.mt-2 { margin-top: 0.5rem; }
.mt-3 { margin-top: 0.75rem; }
.mt-4 { margin-top: 1rem; }
.mt-6 { margin-top: 1.5rem; }

.w-full { width: 100%; }
.text-center { text-align: center; }
.text-right { text-align: right; }

.text-stone-500 { color: var(--text-secondary); }
.text-xs { font-size: 0.75rem; }
.text-sm { font-size: 0.875rem; }
.text-lg { font-size: 1.125rem; }
.text-xl { font-size: 1.25rem; }
.font-bold { font-weight: 700; }
.font-semibold { font-weight: 600; }
.font-medium { font-weight: 500; }

/* Mobile Phone Viewport Optimization (max-width: 768px) */
@media (max-width: 768px) {
  /* Stack grid layouts that are styled inline or use grid classes */
  div[style*="grid-template-columns"]:not([style*="repeat(7"]):not([style*="7,"]),
  .grid[style*="grid-template-columns"]:not([style*="repeat(7"]):not([style*="7,"]) {
    grid-template-columns: 1fr !important;
  }

  /* Make flex components wrap dynamically */
  .flex:not(.no-wrap-mobile) {
    flex-wrap: wrap !important;
  }

  /* Optimize modal dialog layouts for mobile screens */
  dialog {
    width: calc(100% - 1.25rem) !important;
    max-width: 100% !important;
    padding: 1.25rem !important;
    margin: auto !important;
  }
  
  dialog form .grid {
    grid-template-columns: 1fr !important;
    gap: 0.75rem !important;
  }

  /* Ensure tables scroll smoothly horizontally and don't push the viewport */
  .premium-ledger-table,
  .invoice-table,
  table:not(.calendar-table) {
    display: block !important;
    width: 100% !important;
    overflow-x: auto !important;
    white-space: nowrap !important;
    -webkit-overflow-scrolling: touch;
  }

  /* Ensure detail sections and tabs fit on mobile screens */
  .profile-tabs-nav {
    overflow-x: auto !important;
    white-space: nowrap !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    padding-bottom: 0.25rem;
    -webkit-overflow-scrolling: touch;
  }

  .profile-tabs-nav button {
    flex-shrink: 0 !important;
  }

  /* Form control full-width scaling */
  .form-group,
  .form-control,
  .form-select,
  .form-input,
  .search-wrapper,
  .btn {
    width: 100% !important;
    max-width: none !important;
  }

  /* Adjustment to details drawer to make it scroll correctly on small heights */
  #details-drawer {
    height: 100% !important;
    max-height: 100vh !important;
  }

  /* Optimize ledger page card formatting on mobile */
  .payment-statement-card {
    padding: 1rem !important;
    min-height: auto !important;
    border-radius: var(--radius-md) !important;
  }

  .payment-actions-bar {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.5rem !important;
    width: 100% !important;
  }

  .payment-actions-bar .btn {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .statement-doc-header {
    flex-direction: column !important;
    align-items: flex-start !important;
    border-bottom: 1px solid var(--border-color) !important;
    padding-bottom: 1rem !important;
    gap: 0.75rem !important;
  }

  .statement-doc-header .text-right,
  .statement-doc-header div[style*="text-align: right"],
  .statement-doc-header div[style*="text-align:right"] {
    text-align: left !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
  }

  .statement-recipient-grid {
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
  }

  .statement-metrics-panel {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    gap: 1rem !important;
  }

  .payment-roster-layout {
    gap: 1rem !important;
  }

  .payment-roster-pane {
    height: auto !important;
    max-height: none !important;
  }

  .payment-statement-card {
    width: 100% !important;
    overflow: visible !important;
  }

  .payment-statement-card-printable {
    gap: 1rem !important;
  }

  .statement-recipient-box {
    padding: 1rem !important;
  }

  .ledger-balance-box {
    align-items: flex-start !important;
    flex-direction: column !important;
    gap: 0.75rem !important;
    margin-top: 1rem !important;
  }

  .ledger-balance-box .text-right {
    text-align: left !important;
  }

  .premium-ledger-table {
    display: block !important;
    width: 100% !important;
    border-collapse: separate !important;
    border-spacing: 0 0.75rem !important;
    overflow: visible !important;
    white-space: normal !important;
    margin-top: 0.5rem !important;
  }

  .premium-ledger-table thead {
    display: none !important;
  }

  .premium-ledger-table tbody,
  .premium-ledger-table tr,
  .premium-ledger-table td {
    display: block !important;
    width: 100% !important;
  }

  .premium-ledger-table tr {
    background-color: var(--bg-app);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-md);
    padding: 0.75rem;
    box-shadow: var(--shadow-sm);
  }

  .premium-ledger-table td {
    border-bottom: 1px dashed var(--border-color) !important;
    padding: 0.55rem 0 !important;
    text-align: left !important;
    white-space: normal !important;
    overflow-wrap: anywhere;
  }

  .premium-ledger-table td:last-child {
    border-bottom: 0 !important;
  }

  .premium-ledger-table td::before {
    content: attr(data-label);
    display: block;
    margin-bottom: 0.15rem;
    color: var(--text-secondary);
    font-size: 0.65rem;
    font-weight: 800;
    text-transform: uppercase;
  }

  .premium-ledger-table td[colspan]::before {
    content: none;
  }
}

@media (max-width: 1024px) {
  body:not(.dashboard-route-active) .main-wrapper {
    grid-row: 1 / 3 !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
  }

  body:not(.dashboard-route-active) .main-header {
    display: flex !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    flex-shrink: 0 !important;
    height: calc(7.25rem + env(safe-area-inset-top, 0px)) !important;
    min-height: calc(7.25rem + env(safe-area-inset-top, 0px)) !important;
    max-height: calc(7.25rem + env(safe-area-inset-top, 0px)) !important;
    padding: calc(0.68rem + env(safe-area-inset-top, 0px)) 3rem 0.72rem 4.35rem !important;
    background: linear-gradient(180deg, #07180d 0%, #0b1f10 100%) !important;
    border-bottom: 1px solid rgba(154, 190, 112, 0.18) !important;
  }

  body:not(.dashboard-route-active) .mobile-top-bar {
    display: none !important;
  }

  body:not(.dashboard-route-active) .content-pane {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    padding-top: calc(7.25rem + 0.85rem + env(safe-area-inset-top, 0px)) !important;
  }

  body.dashboard-route-active .main-wrapper {
    grid-row: 1 / 3 !important;
  }

  body:has(#tab-dashboard.active) .main-wrapper {
    grid-row: 1 / 3 !important;
  }

  body.dashboard-route-active .content-pane {
    padding: 0 0 calc(var(--mobile-nav-height) + max(env(safe-area-inset-bottom, 0px), var(--mobile-browser-bottom)) + 1.5rem) !important;
    padding-bottom: calc(var(--mobile-nav-height) + max(env(safe-area-inset-bottom, 0px), var(--mobile-browser-bottom)) + 1.5rem) !important;
  }
}

/* Print Media Overrides */
@media print {
  body {
    background: #ffffff !important;
    background-color: #ffffff !important;
    color: #000000 !important;
    font-size: 11pt !important;
  }

  .sidebar,
  .mobile-top-bar,
  .mobile-nav-menu,
  .main-header,
  .payment-roster-pane,
  .payment-roster-header,
  .no-print,
  .btn,
  button,
  .theme-switch-wrapper,
  .modal-close-btn {
    display: none !important;
  }

  .app-shell {
    display: block !important;
    min-height: auto !important;
    grid-template-columns: 1fr !important;
  }

  .main-wrapper {
    grid-column: 1 !important;
    padding-bottom: 0 !important;
    min-height: auto !important;
    margin: 0 !important;
  }

  .content-pane {
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
  }

  .tab-view {
    display: none !important;
  }
  
  .tab-view.active {
    display: block !important;
  }

  .payment-statement-card {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 100% !important;
  }

  /* Make table look like a traditional high-quality statement */
  .premium-ledger-table {
    border-collapse: collapse !important;
    width: 100% !important;
    margin-top: 1rem !important;
    border: 1px solid #000000 !important;
  }

  .premium-ledger-table th {
    background-color: #f0f0f0 !important;
    border: 1px solid #000000 !important;
    color: #000000 !important;
    font-weight: bold !important;
  }

  .premium-ledger-table td {
    border: 1px solid #000000 !important;
    color: #000000 !important;
    padding: 6px 10px !important;
  }

  .badge {
    border: 1px solid #000000 !important;
    color: #000000 !important;
    background: transparent !important;
    padding: 2px 6px !important;
    border-radius: 4px !important;
    text-transform: uppercase !important;
    font-size: 8pt !important;
  }

  /* Balance box layout on print */
  .ledger-balance-box {
    border: 1px solid #000000 !important;
    background-color: #fcfcfc !important;
    padding: 10px !important;
    margin-top: 1.5rem !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
  }
}
