/**
 * DistHub responsive layer — Bootstrap 5 grid + mobile/tablet/desktop (320px–1920px).
 * Load after disthub.css and Bootstrap grid/utilities.
 */

/* ——— No horizontal scroll ——— */
html.disthub-root {
  overflow-x: hidden;
}

.disthub-body,
.app-shell,
.main,
.content,
.assign-page,
.login-page {
  max-width: 100%;
  overflow-x: hidden;
}

img,
video,
svg,
canvas {
  max-width: 100%;
  height: auto;
}

/* ——— Bootstrap table-responsive for all data tables ——— */
.table-responsive,
.dh-table-wrap,
.dh-table-wrap--manage,
.bill-table-wrap,
.bill-view-table-scroll,
.party-table-wrap,
.pm-classic-table-wrap,
.pm-table-wrap,
.perm-table-wrap,
.dh-expense-list-table-wrap,
.mismatch-table-scroll,
.dh-ui-v2 .dh-table-wrap {
  display: block;
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
}

.dh-table-wrap table,
.bill-table-wrap table,
.pm-classic-table-wrap table,
.perm-table-wrap table,
.bill-view-table-scroll table {
  margin-bottom: 0;
}

/* ——— Touch-friendly controls (min 44×44 tap targets) ——— */
@media (max-width: 991.98px) {
  .btn,
  .fab-btn,
  .fab-bar .btn,
  .assign-chip,
  .home-dash-hero-btn,
  .home-dash-module,
  .main-topbar-toggle,
  .sidebar-nav a,
  .login-submit,
  .dh-modal-close,
  button[type="submit"],
  button[type="button"]:not(.dh-sr-only) {
    min-height: 44px;
  }

  .main-topbar-toggle {
    min-width: 44px;
    width: 44px;
  }

  .assign-chip,
  .home-dash-hero-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
  }

  .sidebar-nav a {
    min-height: 44px;
    display: flex;
    align-items: center;
  }
}

/* ——— Forms: full width on mobile ——— */
@media (max-width: 767.98px) {
  .assign-field,
  .assign-field input,
  .assign-field select,
  .assign-field textarea,
  .assign-field-input,
  .bill-toolbar-form input,
  .bill-toolbar-form select,
  .login-form input,
  .login-form select,
  .dh-form-control,
  .pm-toolbar input,
  .pm-toolbar select,
  form input[type="text"],
  form input[type="password"],
  form input[type="date"],
  form input[type="number"],
  form input[type="search"],
  form input[type="email"],
  form select,
  form textarea {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
  }

  .assign-toolbar-fields,
  .assign-toolbar-fields--one-row {
    flex-direction: column;
    align-items: stretch;
    min-width: 0 !important;
    width: 100%;
  }

  .assign-field {
    flex: 1 1 100% !important;
    min-width: 0 !important;
    max-width: 100%;
  }

  .assign-field--search-inline {
    min-width: 0 !important;
  }

  .assign-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .assign-toolbar-actions {
    width: 100%;
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  .assign-toolbar-actions .btn {
    flex: 1 1 auto;
  }
}

/* ——— Cards stack on small screens ——— */
@media (max-width: 767.98px) {
  .assign-row-card,
  .assign-row-shell,
  .bill-card .assign-row-shell {
    grid-template-columns: 1fr !important;
  }

  .assign-row--inline .assign-row-card {
    gap: 0.65rem;
  }

  .home-dash-attention-grid,
  .home-dash-module-grid,
  .home-dash-team-grid,
  .stats-grid {
    grid-template-columns: 1fr !important;
  }

  .home-dash-status-bar {
    flex-direction: column;
    align-items: stretch;
  }

  .home-dash-status-bar--5 {
    grid-template-columns: 1fr !important;
  }

  .home-dash-pill {
    width: 100%;
  }

  .assign-hero-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
  }

  .assign-hero-links {
    flex-wrap: wrap;
    width: 100%;
  }

  .assign-hero-pills {
    flex-wrap: wrap;
  }
}

/* ——— Sales Bills FAB bar: fixed bottom (reference layout) ——— */
@media (max-width: 767.98px) {
  .bill-details-page,
  .assign-page--unpaid {
    padding-bottom: calc(6rem + env(safe-area-inset-bottom, 0px));
  }

  .bill-details-page:has(.fab-bar--has-totals),
  .assign-page--unpaid:has(.fab-bar--has-totals) {
    padding-bottom: calc(7.5rem + env(safe-area-inset-bottom, 0px));
  }

  .fab-bar--sales-bills.fab-bar--sales-bills-fixed {
    bottom: 0;
    padding: 0.25rem 0.45rem calc(0.45rem + env(safe-area-inset-bottom, 0px));
    background: linear-gradient(to top, rgba(248, 250, 252, 0.98) 72%, rgba(248, 250, 252, 0));
  }

  .fab-bar--sales-bills.fab-bar--sales-bills-fixed .fab-bar-inner {
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 12px !important;
  }

  .fab-bar--sales-bills:not(.fab-bar--sales-bills-fixed) {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding: 0.25rem 0.45rem calc(0.45rem + env(safe-area-inset-bottom, 0px));
    box-sizing: border-box;
    justify-content: stretch;
    align-items: stretch;
    background: linear-gradient(to top, rgba(248, 250, 252, 0.98) 70%, rgba(248, 250, 252, 0));
    pointer-events: none;
    z-index: 45;
  }

  .fab-bar--sales-bills [hidden] {
    display: none !important;
  }

  .fab-bar--sales-bills .fab-bar-inner {
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 10px !important;
    display: grid !important;
    grid-template-columns: auto 1fr 1fr;
    grid-template-rows: auto auto;
    gap: 0.28rem 0.35rem !important;
    padding: 0.4rem 0.45rem !important;
    box-sizing: border-box;
    overflow: hidden;
    align-items: stretch !important;
    flex-wrap: nowrap !important;
  }

  .fab-bar--sales-bills.fab-bar--has-totals .fab-bar-inner {
    grid-template-rows: auto auto auto;
  }

  .fab-bar--sales-bills .fab-bar-inner > * {
    flex: none !important;
    min-width: 0 !important;
    max-width: none !important;
  }

  .fab-bar--sales-bills .fab-bar-select {
    grid-column: 1;
    grid-row: 1;
    display: inline-flex !important;
    align-items: center !important;
    gap: 0.3rem !important;
    font-size: 0.72rem !important;
    font-weight: 600 !important;
    white-space: nowrap;
    padding: 0 !important;
  }

  .fab-bar--sales-bills .fab-bar-select input {
    width: 15px;
    height: 15px;
    margin: 0;
  }

  .fab-bar--sales-bills #fab-assign-selected {
    grid-column: 2 / -1;
    grid-row: 1;
    min-height: 34px !important;
    padding: 0.3rem 0.45rem !important;
    font-size: 0.78rem !important;
    white-space: nowrap;
  }

  .fab-bar--sales-bills #fab-edit-bill {
    grid-column: 2;
    grid-row: 2;
    min-height: 32px !important;
    padding: 0.28rem 0.4rem !important;
    font-size: 0.76rem !important;
  }

  .fab-bar--sales-bills:not(:has(#fab-edit-bill)) .fab-bill-list-wrap {
    grid-column: 2 / -1;
  }

  .fab-bar--sales-bills:not(:has(#fab-assign-selected)) #fab-edit-bill,
  .fab-bar--sales-bills:not(:has(#fab-assign-selected)) .fab-bill-list-wrap {
    grid-row: 1;
  }

  .fab-bar--sales-bills .fab-bill-list-wrap {
    grid-column: 3;
    grid-row: 2;
    margin-left: 0 !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: stretch !important;
    gap: 0 !important;
    width: auto !important;
  }

  .fab-bar--sales-bills .fab-selected-totals {
    grid-column: 1 / -1;
    grid-row: 2;
    width: 100% !important;
    justify-content: stretch !important;
    flex-wrap: nowrap !important;
    gap: 0.28rem !important;
  }

  .fab-bar--sales-bills.fab-bar--has-totals #fab-edit-bill,
  .fab-bar--sales-bills.fab-bar--has-totals .fab-bill-list-wrap {
    grid-row: 3;
  }

  .fab-bar--sales-bills .fab-selected-total {
    flex: 1 1 0;
    justify-content: center;
    min-width: 0;
    padding: 0.22rem 0.4rem !important;
    font-size: 0.68rem !important;
    border-radius: 8px !important;
  }

  .fab-bar--sales-bills .fab-selected-total-meta {
    display: none;
  }

  .fab-bar--sales-bills .fab-btn-bill-list,
  .fab-bar--sales-bills .fab-btn-delete-bill {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 32px !important;
    padding: 0.28rem 0.4rem !important;
    font-size: 0.76rem !important;
  }

  .fab-bar--sales-bills .btn {
    line-height: 1.15;
  }
}

/* ——— Other FAB bars: wrap on mobile ——— */
@media (max-width: 767.98px) {
  .fab-bar,
  .fab-bar--hisab {
    left: 0;
    right: 0;
    padding-left: max(0.5rem, env(safe-area-inset-left));
    padding-right: max(0.5rem, env(safe-area-inset-right));
  }

  .fab-bar--hisab .fab-bar-inner,
  .fab-bar--assign-reassign .fab-bar-inner {
    flex-wrap: wrap !important;
    justify-content: center;
    gap: 0.5rem;
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 14px !important;
  }

  .fab-bar--assign-reassign .fab-bar-inner .btn,
  .fab-bar--assign-reassign .fab-bar-inner label {
    flex: 1 1 calc(50% - 0.35rem);
  }
}

/* ——— Tablet: stack bill toolbars (768–991px) ——— */
@media (min-width: 768px) and (max-width: 991.98px) {
  .bill-details-page .assign-toolbar-fields--one-row,
  .assign-page--unpaid .assign-toolbar-fields--one-row {
    flex-wrap: wrap !important;
  }

  .bill-details-page .assign-toolbar-fields--one-row .assign-field--search-inline {
    flex: 1 1 100% !important;
    min-width: 0 !important;
  }
}

/* ——— Daily hisab + excel import toolbars ——— */
@media (max-width: 767.98px) {
  .dh-daily-toolbar,
  .dh-daily-toolbar .assign-toolbar-fields {
    flex-direction: column;
    align-items: stretch;
  }

  .dh-daily-toolbar input[type="date"],
  .dh-daily-toolbar select,
  .dh-daily-toolbar .assign-btn {
    width: 100% !important;
    min-width: 0 !important;
    white-space: normal;
  }

  .bill-excel-panel--wide {
    width: calc(100vw - 1rem) !important;
    max-width: calc(100vw - 1rem) !important;
    margin: 0.5rem;
  }

  .bill-list-resolve-wrap {
    margin: 0 -0.25rem;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
  }

  .bill-list-resolve {
    min-width: 640px;
  }

  .dh-modal-panel,
  .bill-assign-panel,
  .bill-assign-multi {
    width: calc(100vw - 1rem) !important;
    max-width: calc(100vw - 1rem) !important;
  }

  .bill-assign-foot .btn {
    flex: 1 1 100%;
    width: 100%;
  }

  .assign-hero-links .assign-chip {
    flex: 1 1 auto;
  }

  .main:has(.assign-hero) .main-topbar {
    position: sticky;
    left: auto;
    top: 0;
    margin-bottom: 0.35rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0;
    background: var(--dh-surface, #fff);
    z-index: 30;
  }

  .main:has(.assign-hero) .main-topbar-title {
    position: static;
    width: auto;
    height: auto;
    margin: 0;
    padding: 0;
    overflow: visible;
    clip: auto;
    white-space: nowrap;
    border: 0;
    font-size: 1rem;
    font-weight: 800;
    color: #0f172a;
  }

  .main:has(.assign-hero) .main-topbar-toggle {
    position: relative;
    z-index: 30;
  }

  .assign-page {
    padding-left: 0;
    padding-right: 0;
  }

  .assign-hero-inner {
    padding-top: 0;
  }
}

/* ——— Bill list pages: tablet layout (desktop single row in assign.css @992px) ——— */
@media (min-width: 768px) and (max-width: 991.98px) {
  .bill-list-head {
    display: none;
  }

  .bill-search-count {
    display: none !important;
  }

  .bill-details-page .bill-toolbar-form,
  .assign-page--unpaid .unpaid-toolbar-form,
  .assign-page--assign-bills .assign-toolbar-form {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    row-gap: 0.55rem;
    column-gap: 0.85rem;
  }

  .bill-details-page .assign-toolbar-fields--one-row,
  .assign-page--unpaid .assign-toolbar-fields--one-row,
  .assign-page--assign-bills .assign-toolbar-fields--assign-bills {
    flex: 1 1 100%;
    min-width: 0;
  }
}

@media (min-width: 992px) {
  .bill-list-head {
    display: none;
  }

  .bill-search-count {
    display: none !important;
  }
}

@media (max-width: 767.98px) {
  .bill-details-page .bill-toolbar-form,
  .assign-page--unpaid .unpaid-toolbar-form,
  .assign-page--assign-bills .assign-toolbar-form {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    padding: 0.4rem 0.5rem !important;
    margin-bottom: 0.35rem !important;
  }

  .bill-details-page .assign-field--search-inline,
  .assign-page--unpaid .assign-field--search-inline,
  .assign-page--assign-bills .assign-field--search-inline {
    flex: 1 1 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    order: -1;
  }

  .bill-details-page .assign-field--search-inline .assign-field-label,
  .assign-page--unpaid .assign-field--search-inline .assign-field-label {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  .bill-details-page .assign-field--search-inline .assign-search-wrap .assign-field-input,
  .assign-page--unpaid .assign-field--search-inline .assign-search-wrap .assign-field-input {
    min-height: 36px;
    padding: 0.35rem 0.55rem;
    font-size: 0.86rem;
    border-radius: 9px;
  }

  .bill-details-page .bill-search-count,
  .assign-page--unpaid .bill-search-count {
    display: block;
    font-size: 0.68rem;
    margin-top: 0.15rem;
    padding-left: 0.1rem;
  }

  .bill-details-page .assign-toolbar-fields--one-row > .btn {
    min-height: 34px;
    font-size: 0.8rem;
  }

  .bill-details-page .assign-toolbar-fields--one-row > .bill-add-bill-btn {
    grid-column: 1 / -1;
  }

  .bill-details-page .assign-toolbar-fields--one-row > .btn-secondary {
    flex: 1 1 calc(50% - 0.2rem);
  }

  .bill-details-page .assign-toolbar-fields--one-row > .bill-import-excel-btn:last-child {
    grid-column: 1 / -1;
  }

  /* Hide magnifying-glass circle in search bars on mobile */
  .assign-search-ico {
    display: none !important;
  }

  .assign-search-wrap .assign-field-input,
  .assign-search-wrap .assign-search-input {
    padding-left: 0.55rem !important;
  }

  .assign-page .assign-field-label {
    font-size: 0.6rem;
    margin-bottom: 0.12rem;
  }

  .assign-page--assign-bills .assign-toolbar-fields--assign-bills,
  .bill-details-page .assign-toolbar-fields--one-row,
  .assign-page--unpaid .assign-toolbar-fields--one-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 0.3rem 0.35rem !important;
    align-items: end !important;
    padding-top: 0.35rem;
  }

  .bill-details-page .assign-toolbar-fields--one-row > .assign-field--search-inline,
  .assign-page--unpaid .assign-toolbar-fields--one-row > .assign-field--search-inline,
  .assign-page--assign-bills .assign-toolbar-fields--assign-bills > .assign-field--search-inline {
    grid-column: 1 / -1;
    order: 0;
  }

  .assign-page--assign-bills .assign-toolbar-fields--assign-bills .assign-field--date,
  .assign-page--assign-bills .assign-toolbar-fields--assign-bills .assign-field--area {
    grid-column: 1 / -1;
  }

  .bill-details-page .assign-toolbar-fields--one-row > .btn,
  .assign-page--unpaid .assign-toolbar-fields--one-row > .btn {
    grid-column: 1 / -1;
    min-height: 34px;
    font-size: 0.8rem;
  }

  .bill-details-page .assign-field-label,
  .assign-page--unpaid .assign-field-label {
    font-size: 0.6rem;
    margin-bottom: 0.12rem;
  }

  .bill-details-page .assign-field-input,
  .assign-page--unpaid .assign-field-input {
    min-height: 34px;
    padding: 0.3rem 0.45rem;
    font-size: 0.82rem;
  }

  .assign-page .assign-toolbar {
    padding: 0.4rem 0.5rem !important;
    margin-bottom: 0.35rem !important;
  }

  .bill-list-head {
    display: grid;
    grid-template-columns: 1.35rem minmax(0, 1.1fr) minmax(0, 1.4fr) auto;
    gap: 0.35rem;
    align-items: center;
    padding: 0.28rem 0.45rem;
    margin-bottom: 0.2rem;
    border-radius: 8px;
    background: #f1f5f9;
    font-size: 0.62rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #64748b;
  }

  .bill-list-head__amt {
    text-align: right;
  }
}

@media (max-width: 991.98px) {
  .dh-modal:not([hidden]) {
    padding: 0.5rem;
    align-items: flex-end;
  }

  .bill-photo-entry-modal .dh-modal-panel {
    max-height: 92vh;
    overflow-y: auto;
  }
}

/* ——— Sidebar hamburger (align with Bootstrap lg = 992px) ——— */
@media (max-width: 991.98px) {
  .main-topbar {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    position: sticky;
    top: 0;
    z-index: 20;
    background: var(--dh-surface, #fff);
    padding: 0.65rem 0;
    margin-bottom: 0.5rem;
  }

  .main-topbar-title {
    font-size: 1.05rem;
    line-height: 1.3;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .content.container-fluid {
    padding-left: max(0.75rem, env(safe-area-inset-left));
    padding-right: max(0.75rem, env(safe-area-inset-right));
  }
}

/* ——— Content padding by breakpoint ——— */
@media (min-width: 576px) and (max-width: 991.98px) {
  .content.container-fluid {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

@media (min-width: 1200px) {
  .content.container-fluid {
    max-width: 1920px;
    margin-left: auto;
    margin-right: auto;
  }
}

/* ——— Modals ——— */
@media (max-width: 575.98px) {
  .dh-modal-panel,
  .dh-modal-dialog {
    width: calc(100vw - 1rem) !important;
    max-width: calc(100vw - 1rem) !important;
    margin: 0.5rem;
  }
}

/* ——— Login ——— */
@media (max-width: 575.98px) {
  .login-layout {
    padding: 1rem;
  }

  .login-card {
    width: 100%;
    max-width: 100%;
  }

  .login-form .btn,
  .login-submit {
    width: 100%;
  }
}

/* ——— Bootstrap grid helpers for DistHub cards ——— */
.dh-bs-card-grid .home-dash-action-card,
.dh-bs-card-grid .home-dash-module,
.dh-bs-card-grid .home-dash-team-card {
  height: 100%;
}

.dh-bs-card-grid .home-dash-module {
  min-height: 5.5rem;
}

/* ——— Tablet tweaks ——— */
@media (min-width: 768px) and (max-width: 991.98px) {
  .home-dash-attention-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-dash-module-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .home-dash-team-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ——— Compact bill list: Sales Bills + Unpaid Bills (mobile) ——— */
@media (max-width: 767.98px) {
  .bill-details-page,
  .assign-page--unpaid {
    padding-left: 0;
    padding-right: 0;
  }

  /* Smaller hero — title already in top bar */
  .bill-details-page .assign-hero,
  .assign-page--unpaid .assign-hero {
    margin-left: 0;
    margin-right: 0;
    padding: 0.45rem 0.6rem 0.55rem;
    border-radius: 12px;
  }

  .bill-details-page .assign-hero-inner,
  .assign-page--unpaid .assign-hero-inner {
    gap: 0.4rem;
    padding-top: 0;
  }

  .bill-details-page .assign-hero-title,
  .assign-page--unpaid .assign-hero-title {
    display: none;
  }

  /* Summary stats duplicate hero — hide on mobile */
  .bill-details-page .assign-stats--bills,
  .assign-page--unpaid .assign-stats.dh-unpaid-summary {
    display: none;
  }

  .bill-details-page .assign-hero-pills,
  .assign-page--unpaid .assign-hero-pills {
    gap: 0.25rem;
  }

  .bill-details-page .assign-hero-pill,
  .assign-page--unpaid .assign-hero-pill {
    font-size: 0.62rem;
    padding: 0.15rem 0.4rem;
  }

  .bill-details-page .assign-hero-links,
  .assign-page--unpaid .assign-hero-links {
    width: 100%;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .bill-details-page .assign-hero-links .assign-chip,
  .assign-page--unpaid .assign-hero-links .assign-chip {
    min-height: 32px;
    padding: 0.28rem 0.55rem;
    font-size: 0.72rem;
    flex: 1 1 auto;
  }

  .bill-details-page .assign-hero-links .assign-chip--icon {
    flex: 0 0 32px;
    min-width: 32px;
    padding: 0;
  }

  /* Tighter list */
  .bill-details-page .assign-list.bill-card-list,
  .assign-page--unpaid .assign-list.bill-card-list,
  .assign-page--unpaid .unpaid-bill-list {
    gap: 0.35rem;
  }

  /* Compact bill card — 2-col grid (not full stack) */
  .assign-row.assign-row--inline.bill-card {
    padding: 0.4rem 0.45rem !important;
    border-radius: 10px;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-shell {
    align-items: flex-start;
    gap: 0.3rem;
    margin-left: 0;
  }

  .bill-details-page .bill-details-check,
  .assign-page--unpaid .bill-details-check {
    padding: 0.1rem 0.2rem 0 0;
    align-self: center;
  }

  .bill-details-page .bill-details-check input,
  .assign-page--unpaid .bill-details-check input {
    width: 17px;
    height: 17px;
    margin: 0;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-card,
  .assign-row.assign-row--inline.bill-card .assign-row-shell .assign-row-card,
  .assign-row.assign-row--inline.bill-card a.assign-row-card--link {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    grid-template-rows: auto auto auto !important;
    gap: 0.2rem 0.45rem !important;
    align-items: start !important;
    padding: 0 !important;
    margin: 0 !important;
    width: 100%;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-card-left--stacked {
    grid-column: 1;
    grid-row: 1;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.25rem 0.35rem;
    min-width: 0;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-card-right,
  .assign-row.assign-row--inline.bill-card .assign-row-card-right--unpaid {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-items: flex-end;
    text-align: right;
    gap: 0.2rem;
    min-width: 0;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-card-mid {
    grid-column: 1 / -1;
    grid-row: 2;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.12rem;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-vcn {
    height: 22px;
    padding: 0 0.4rem;
    font-size: 0.64rem;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-bill-date {
    min-height: 18px;
    padding: 0 0.35rem;
    font-size: 0.56rem;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-party {
    font-size: 0.8rem !important;
    font-weight: 800;
    line-height: 1.25;
    margin-bottom: 0 !important;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
  }

  /* Hide long address on mobile — keep area + salesman only */
  .assign-row.assign-row--inline.bill-card .assign-row-address {
    display: none;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-sub {
    margin-top: 0.1rem;
    font-size: 0.65rem;
    line-height: 1.3;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.2rem 0.35rem;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-sub--loc .assign-row-area,
  .assign-row.assign-row--inline.bill-card .assign-row-sub--loc .assign-row-salesman {
    font-size: 0.64rem;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-meta--kg {
    font-size: 0.62rem;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-driver {
    margin-top: 0;
    font-size: 0.62rem;
    gap: 0.18rem;
    line-height: 1.2;
    opacity: 0.92;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-driver .dh-etype-badge {
    transform: scale(0.85);
    transform-origin: left center;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-amt {
    font-size: 0.92rem !important;
    font-weight: 900;
    line-height: 1.15;
    white-space: nowrap;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-tags {
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.18rem;
    max-width: 7.5rem;
  }

  .assign-row.assign-row--inline.bill-card .assign-tag {
    height: 18px;
    padding: 0 0.35rem;
    font-size: 0.54rem;
    letter-spacing: 0.02em;
  }

  .assign-row.assign-row--inline.bill-card .assign-row-corner-tag {
    font-size: 0.52rem;
    height: 16px;
    padding: 0 0.3rem;
  }

  /* Hide duplicate kind tag when VCN badge already shows cash/debit color */
  .assign-row.assign-row--inline.bill-card .assign-tag--kind {
    display: none;
  }

  /* Unpaid: show only status tag on mobile (save space) */
  .assign-page--unpaid .assign-row.assign-row--inline.bill-card .assign-tag--edited {
    display: none;
  }

  .assign-page--unpaid .assign-row.assign-row--inline.bill-card .assign-row-corner-tag {
    position: static;
    margin-bottom: 0.1rem;
  }

  .bill-details-page .bill-toolbar-hint,
  .assign-page--unpaid .bill-toolbar-hint {
    font-size: 0.72rem;
    margin-top: 0.35rem;
  }
}

/* ——— Assign bills: compact mobile ——— */
@media (max-width: 767.98px) {
  .assign-page--assign-bills .assign-hero {
    padding: 0.45rem 0.6rem 0.55rem;
    margin-bottom: 0.35rem;
  }

  .assign-page--assign-bills .assign-hero-inner {
    gap: 0.4rem;
    padding-top: 0;
  }

  .assign-page--assign-bills .assign-hero-title {
    display: none;
  }

  .assign-page--assign-bills .assign-hero-pill {
    font-size: 0.62rem;
    padding: 0.15rem 0.4rem;
  }

  .assign-page--assign-bills .assign-hero-links .assign-chip {
    min-height: 32px;
    padding: 0.28rem 0.55rem;
    font-size: 0.72rem;
    flex: 1 1 auto;
  }

  .assign-page--assign-bills .assign-toolbar-form {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    padding: 0.4rem 0.5rem !important;
    margin-bottom: 0.35rem !important;
  }

  .assign-page--assign-bills .assign-toolbar-fields--assign-bills {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 0.3rem 0.35rem !important;
    padding-top: 0.35rem;
  }

  .assign-page--assign-bills .assign-toolbar-fields--assign-bills .assign-field--date,
  .assign-page--assign-bills .assign-toolbar-fields--assign-bills .assign-field--area {
    grid-column: 1 / -1;
  }

  .assign-page--assign-bills .assign-stats {
    display: flex !important;
    flex-wrap: nowrap !important;
    grid-template-columns: unset !important;
    grid-auto-flow: unset !important;
    grid-auto-columns: unset !important;
    gap: 0.32rem !important;
    overflow-x: auto !important;
    margin-bottom: 0.4rem !important;
    padding: 0 0 0.12rem !important;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
  }

  .assign-page--assign-bills .assign-stat {
    flex: 0 0 auto;
    min-width: 4.75rem;
    max-width: 6.5rem;
    padding: 0.32rem 0.42rem !important;
    border-radius: 8px !important;
    border-width: 1px !important;
    gap: 0.1rem !important;
    scroll-snap-align: start;
  }

  .assign-page--assign-bills .assign-stat.is-active {
    box-shadow: 0 0 0 2px rgba(20, 184, 166, 0.28) !important;
  }

  .assign-page--assign-bills .assign-stat-top {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }

  .assign-page--assign-bills .assign-stat-num {
    font-size: 0.9rem !important;
  }

  .assign-page--assign-bills .assign-stat-label {
    font-size: 0.5rem !important;
    text-align: left !important;
    line-height: 1.15;
  }

  .assign-page--assign-bills .assign-stat-amt {
    font-size: 0.64rem !important;
    font-weight: 700 !important;
  }

  .assign-page--assign-bills .assign-bottom-strip {
    width: 100%;
    max-width: 100%;
    font-size: 0.66rem;
    padding: 0.22rem 0.45rem;
    gap: 0.2rem 0.35rem;
    margin-top: 0.35rem;
    justify-content: center;
  }

  .assign-page--assign-bills .assign-empty {
    padding: 0.85rem 0.5rem;
  }

  .assign-page--assign-bills .assign-roster-section-title {
    font-size: 0.82rem;
    margin: 0.35rem 0 0.25rem;
  }

  .assign-page--assign-bills.assign-page--has-reassign {
    padding-bottom: calc(4.75rem + env(safe-area-inset-bottom, 0px));
  }
}

/* ——— Very small phones (320px) ——— */
@media (max-width: 359.98px) {
  .home-dash-title {
    font-size: 1.25rem;
  }

  .fab-bar--sales-bills .fab-bar-select {
    font-size: 0.68rem !important;
  }

  .fab-bar--sales-bills #fab-assign-selected,
  .fab-bar--sales-bills #fab-edit-bill,
  .fab-bar--sales-bills .fab-btn-bill-list,
  .fab-bar--sales-bills .fab-btn-route-list {
    font-size: 0.72rem !important;
  }
}
