/* ==========================================================================
   v83 — Unified layout system (authoritative overrides)
   Fixes safe-area double-padding, header alignment, gutters, and mobile chrome.
   ========================================================================== */

:root {
  --page-gutter: 14px;
  /* Expense page banner is the universal standard */
  --universal-banner-height: 78px;
  --universal-banner-row-height: 42px;
  --banner-btn-size: 42px;
  --banner-title-size: 1.35rem;
  --status-bar-top: max(var(--android-inset-top, 0px), env(safe-area-inset-top, 0px));
  --banner-total-height: calc(var(--universal-banner-height) + var(--status-bar-top));
  --app-header-height: var(--banner-total-height);
  --bottom-chrome: calc(var(--android-inset-bottom, 0px) + 72px);
}

/* Android APK: ensure menu/title row clears status bar even when native inset is 0 */
html.capacitor-android {
  --status-bar-top: max(var(--android-inset-top, 0px), env(safe-area-inset-top, 0px), 28px);
  --banner-total-height: calc(var(--universal-banner-height) + var(--status-bar-top));
  --app-header-height: var(--banner-total-height);
}

/* ── Shell & safe area ── */
html.capacitor-android .app-container {
  padding-top: 0 !important;
  padding-left: max(var(--page-gutter), calc(var(--page-gutter) + var(--android-inset-left, 0px))) !important;
  padding-right: max(var(--page-gutter), calc(var(--page-gutter) + var(--android-inset-right, 0px))) !important;
  padding-bottom: var(--bottom-chrome) !important;
}

html.capacitor-android header {
  padding-top: var(--status-bar-top) !important;
  margin-top: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-bottom: 16px !important;
  height: var(--banner-total-height) !important;
  min-height: var(--banner-total-height) !important;
  max-height: none !important;
  box-sizing: border-box !important;
}

html.capacitor-android .boot-splash,
html.capacitor-android .login-overlay {
  padding-top: var(--status-bar-top) !important;
  box-sizing: border-box !important;
}

html.capacitor-android .modal {
  padding-top: 0 !important;
  padding-bottom: var(--android-inset-bottom, 0px) !important;
  padding-left: var(--android-inset-left, 0px) !important;
  padding-right: var(--android-inset-right, 0px) !important;
}

html.capacitor-android .route-page > .modal-content > .modal-header {
  padding-top: 12px !important;
  padding-left: max(var(--page-gutter), calc(var(--page-gutter) + var(--android-inset-left, 0px))) !important;
  padding-right: max(var(--page-gutter), calc(var(--page-gutter) + var(--android-inset-right, 0px))) !important;
}

@media (max-width: 640px) {
  body {
    padding-bottom: 0 !important;
  }
}

.app-container {
  padding-left: var(--page-gutter) !important;
  padding-right: var(--page-gutter) !important;
  padding-bottom: var(--bottom-chrome) !important;
}

/* ── Header grid: menu | title | actions ── */
#mobile-menu-btn,
html.capacitor-android #mobile-menu-btn,
.route-menu-btn {
  position: static !important;
  inset: auto !important;
  top: auto !important;
  left: auto !important;
  z-index: auto !important;
  order: 0 !important;
  flex: 0 0 var(--banner-btn-size) !important;
  width: var(--banner-btn-size) !important;
  height: var(--banner-btn-size) !important;
  min-width: var(--banner-btn-size) !important;
  min-height: var(--banner-btn-size) !important;
}

.header-top {
  padding-left: 0 !important;
  display: grid !important;
  grid-template-columns: var(--banner-btn-size) minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 10px !important;
  height: var(--universal-banner-row-height) !important;
  min-height: var(--universal-banner-row-height) !important;
  max-height: var(--universal-banner-row-height) !important;
  width: 100% !important;
}

html.capacitor-android .header-top {
  padding-left: 0 !important;
  padding-top: 0 !important;
}

.common-banner-title {
  margin: 0 !important;
  min-width: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  font-size: var(--banner-title-size) !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  grid-column: 2 !important;
}

.header-right-panel {
  grid-column: 3 !important;
  justify-self: end !important;
  margin-left: 0 !important;
}

header {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
  align-items: stretch !important;
  gap: 0 !important;
  height: auto !important;
  min-height: var(--banner-total-height) !important;
  max-height: none !important;
  padding: var(--status-bar-top) var(--page-gutter) 0 var(--page-gutter) !important;
  margin-top: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-bottom: 16px !important;
  top: 0 !important;
  box-sizing: border-box !important;
  background: #ffffff !important;
  border-bottom: 1px solid var(--border) !important;
  box-shadow: 0 2px 10px rgba(15, 23, 42, .05) !important;
}

.header-right-panel,
#header-refresh-btn,
#global-drafts-btn,
#mobile-menu-btn {
  height: var(--banner-btn-size) !important;
  min-height: var(--banner-btn-size) !important;
}

@media (max-width: 640px) {
  :root {
    --universal-banner-height: 72px;
    --universal-banner-row-height: 38px;
    --banner-btn-size: 38px;
    --banner-title-size: 1.2rem;
  }

  html.capacitor-android {
    --status-bar-top: max(
      var(--android-inset-top, 0px),
      env(safe-area-inset-top, 0px),
      24px
    );
    --banner-total-height: calc(var(--universal-banner-height) + var(--status-bar-top));
    --app-header-height: var(--banner-total-height);
  }
}

/* ── Universal banner: all route surfaces match Expense header ── */
.app-universal-banner,
.route-page-actions-bar,
.health-route-title-container,
.habit-route-header-content,
.health-route-header,
.habit-route-header,
.reports-route-header,
.uniform-route-header,
.route-page > .modal-content > .modal-header {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  flex-wrap: nowrap !important;
  height: var(--universal-banner-height) !important;
  min-height: var(--universal-banner-height) !important;
  max-height: var(--universal-banner-height) !important;
  padding: 0 var(--page-gutter) !important;
  margin: 0 !important;
  box-sizing: border-box !important;
  background: #ffffff !important;
  border-bottom: 1px solid var(--border) !important;
  box-shadow: 0 2px 10px rgba(15, 23, 42, .05) !important;
  overflow: hidden !important;
}

.health-route-title-container {
  justify-content: center !important;
}

.health-route-title,
.habit-route-title {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  height: var(--universal-banner-row-height) !important;
  max-height: var(--universal-banner-row-height) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  padding: 0 !important;
}

.health-route-title .calorie-route-banner,
.health-route-title .calorie-route-bar {
  width: 100% !important;
  max-width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.health-route-title .calorie-route-bar {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 6px !important;
  align-items: stretch !important;
}

.health-route-title .calorie-route-stat {
  min-width: 0 !important;
  height: 100% !important;
  min-height: 0 !important;
  padding: 4px 6px !important;
  border-radius: 10px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
}

/* ── Mobile sub-route positioning ── */
@media (max-width: 899px) {
  .layout-right > .route-page {
    top: var(--banner-total-height) !important;
    height: calc(100dvh - var(--banner-total-height)) !important;
  }
}

/* ── Unified page gutters (Settings reference) ── */
#expensePage .expense-controls,
#expensePage .layout-left,
#expensePage .layout-right > .transaction-toolbar-row,
#expensePage .layout-right > .filters-container,
#expensePage .layout-right > .transactions-list,
#workoutPage .health-route-title-container,
#foodPage .health-route-title-container,
#habitsPage .route-daily-nav-host,
#reportsModal .reports-page,
#reportsModal .route-page-actions-bar,
#settingsModal .modal-content > .settings-card,
.settlement-search-shell,
.settlement-filter-chips {
  box-sizing: border-box !important;
}

#expensePage .expense-controls {
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding: 12px var(--page-gutter) !important;
}

.settlement-search-shell {
  flex: 1 1 200px !important;
  min-width: 0 !important;
}

#settle-search {
  padding: 10px 12px 10px 36px !important;
  border-radius: 12px !important;
  border: 1px solid #e2e8f0 !important;
  width: 100% !important;
  font-size: 0.95rem !important;
  box-sizing: border-box !important;
}

.settlement-actions-shell {
  display: flex !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

.settlement-filter-chips {
  display: flex !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
  margin-top: 8px !important;
  width: 100% !important;
}

.settlement-controls-row {
  display: flex !important;
  gap: 8px !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  width: 100% !important;
}

.settlement-search-shell {
  position: relative !important;
}

.settlement-search-icon {
  position: absolute !important;
  left: 12px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  font-size: 18px !important;
  color: #94a3b8 !important;
  pointer-events: none !important;
}

/* ── Accounts horizontal scroll (restore) ── */
#accounts-dashboard-list.accounts-scroller,
#expensePage #accounts-dashboard-list.accounts-scroller {
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  scroll-snap-type: x proximity !important;
  width: 100% !important;
  max-width: 100% !important;
  padding-bottom: 6px !important;
}

#accounts-dashboard-list .account-card {
  scroll-snap-align: start !important;
  flex-shrink: 0 !important;
}

@media (min-width: 900px) {
  body[data-active-route="home"] #accounts-dashboard-list.accounts-scroller {
    overflow-x: visible !important;
    scroll-snap-type: none !important;
  }
}

/* Calorie stats scaled to fit universal banner row */
.health-route-title .calorie-route-stat span {
  font-size: 0.62rem !important;
  line-height: 1.05 !important;
}

.health-route-title .calorie-route-stat strong {
  font-size: 0.82rem !important;
  line-height: 1.05 !important;
}

@media (max-width: 640px) {
  .health-route-title .calorie-route-stat span {
    font-size: 0.56rem !important;
  }
  .health-route-title .calorie-route-stat strong {
    font-size: 0.76rem !important;
  }
}

/* ── FAB & bottom nav ── */
#main-add-transaction-btn,
.module-fab {
  right: max(var(--page-gutter), calc(var(--android-inset-right, 0px) + var(--page-gutter))) !important;
  bottom: max(20px, var(--bottom-chrome)) !important;
  z-index: 2600 !important;
}

@media (max-width: 640px) {
  .app-nav,
  .route-daily-nav-host .app-nav,
  html.capacitor-android .app-nav,
  html.capacitor-android .route-daily-nav-host .app-nav {
    left: max(12px, calc(var(--android-inset-left, 0px) + 12px)) !important;
    bottom: max(12px, calc(var(--android-inset-bottom, 0px) + 12px)) !important;
  }
}

/* ── Health page shell padding ── */
html.capacitor-android .health-page-shell {
  padding-bottom: calc(var(--bottom-chrome) + 12px) !important;
}

.health-page-shell {
  padding-left: var(--page-gutter) !important;
  padding-right: var(--page-gutter) !important;
}

.reports-page {
  padding-left: var(--page-gutter) !important;
  padding-right: var(--page-gutter) !important;
}

/* ── Offline banner ── */
html.capacitor-android .offline-banner {
  top: calc(var(--status-bar-top) + 8px) !important;
}

/* ── Modal overlays (true dialogs, not route pages) ── */
.modal:not(.route-page) .modal-content {
  max-height: calc(100dvh - var(--android-inset-top, 0px) - var(--android-inset-bottom, 0px) - 32px) !important;
}

/* ── v82 override: keep edge-to-edge routes without clipping accounts ── */
body[data-active-route="home"] #expensePage.route-page > .main-layout {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Cancel legacy edge-to-edge negative header margins from older CSS layers */
html.capacitor-android header,
header {
  margin-top: 0 !important;
}

/* ======================================================================
   v86: Settings banner visibility + Expense toggle lift
   - Keeps the common banner content clear of Android/status-bar clipping.
   - Pulls the Expense Personal/Household control directly below the banner.
   ====================================================================== */
:root {
  --settings-banner-extra-clearance: 8px;
  --expense-toggle-banner-gap: 2px;
}

/* The Settings route uses the shared common header. Older layout layers can
   leave the header row too close to the top clip/status area on Android, so
   give only Settings a little more top clearance and explicit visible overflow. */
body[data-active-route="settings"] header {
  padding-top: calc(var(--status-bar-top) + var(--settings-banner-extra-clearance)) !important;
  min-height: calc(var(--universal-banner-height) + var(--status-bar-top) + var(--settings-banner-extra-clearance)) !important;
  height: auto !important;
  overflow: visible !important;
}

body[data-active-route="settings"] .header-top,
body[data-active-route="settings"] #mobile-menu-btn,
body[data-active-route="settings"] .common-banner-title,
body[data-active-route="settings"] .header-right-panel {
  overflow: visible !important;
  align-self: center !important;
}

body[data-active-route="settings"] .common-banner-title {
  line-height: 1.25 !important;
  padding-top: 1px !important;
  padding-bottom: 1px !important;
}

/* When the Settings header grows for safe-area clearance, move the Settings
   route content down by the same computed banner height so it never slides
   underneath the banner. */
@media (max-width: 899px) {
  body[data-active-route="settings"] .layout-right > #settingsModal.route-page {
    top: calc(var(--universal-banner-height) + var(--status-bar-top) + var(--settings-banner-extra-clearance)) !important;
    height: calc(100dvh - var(--universal-banner-height) - var(--status-bar-top) - var(--settings-banner-extra-clearance)) !important;
  }
}

/* Expense page: remove the legacy large top spacer so the Personal/Household
   toggle is visually attached to the bottom of the common banner. */
body[data-active-route="home"] header {
  margin-bottom: var(--expense-toggle-banner-gap) !important;
}

body[data-active-route="home"] #expensePage.route-page > .main-layout {
  padding-top: 0 !important;
  gap: 12px !important;
}

body[data-active-route="home"] #expensePage .expense-controls {
  margin-top: 0 !important;
  margin-bottom: 12px !important;
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
}
