/* === RESPONSIVE / MOBILE RULES === */

/* Desktop defaults for mobile-only elements */
.mobile-search-toggle-btn,
.mobile-filter-bar,
.mobile-status-chips,
.mobile-bulk-status-btn,
.filter-panel-close-btn {
  display: none !important;
}

/* Keep global command actions available on tablet/mobile */
@media (max-width: 1023px) {
  .header-actions {
    display: flex !important;
    align-items: center;
    gap: 8px !important;
    flex: 0 0 auto;
  }
}

/* Mobile sidebar behavior */
@media (max-width: 1023px) {
  .sidebar {
    display: flex !important;
    position: fixed;
    top: 0;
    left: 0;
    width: 270px;
    max-width: 80%;
    height: 100vh;
    z-index: 200;
    box-shadow: 5px 0 30px rgba(0, 0, 0, .5);
    overflow: hidden;
    background: var(--sidebar-bg, var(--bg));
    transform: translateX(-100%);
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  }

  .sidebar.show {
    transform: translateX(0);
  }

  .sidebar-close {
    display: flex !important;
    position: absolute;
    top: 8px;
    right: 8px;
    background: var(--card2);
    border: 1px solid var(--line);
    color: var(--text);
    width: 32px;
    height: 32px;
    border-radius: 8px;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 16px;
    z-index: 10;
  }

  .sidebar-overlay {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .5);
    z-index: 199;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
  }

  .sidebar-overlay.show {
    opacity: 1;
    pointer-events: auto;
  }

  .mobile-menu-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    background: var(--card2);
    border: 1px solid var(--line);
    color: var(--text);
    padding: 8px 12px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 18px;
  }

  .content-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .content-actions {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
  }

  .content-actions .btn {
    flex: 1;
    min-width: 70px;
    justify-content: center;
    font-size: 11px;
    padding: 8px 6px;
  }

  .acc-card {
    flex-wrap: wrap;
    padding: 12px;
    gap: 8px;
  }

  .acc-status-group {
    gap: 2px;
    width: 52px;
  }

  .acc-info {
    width: calc(100% - 50px);
  }

  .acc-actions {
    width: 100%;
    justify-content: flex-end;
    margin-top: 6px;
    padding-top: 6px;
    border-top: 1px solid var(--line);
  }

  .selection-bar {
    flex-direction: column;
    align-items: stretch;
    padding: 10px;
    gap: 8px;
  }

  .modal-box {
    width: 95%;
    max-width: 95%;
    margin: 10px;
    max-height: 90vh;
  }

  .modal-body {
    padding: 12px;
  }

  .form-row {
    flex-direction: column;
    gap: 10px;
  }
}

@media (max-width: 480px) {
  #statsGrid.stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .content-actions .btn {
    min-width: 60px;
    font-size: 10px;
    padding: 6px 4px;
  }

  .acc-card {
    flex-direction: column;
    gap: 6px;
    padding: 12px;
  }

  .acc-status-group {
    width: 100%;
    display: flex;
    flex-direction: row;
    gap: 4px;
  }

  .acc-status-btn {
    flex: 1;
    width: auto;
    height: 32px;
  }

  .acc-info {
    width: 100% !important;
  }

  .acc-actions {
    border-top: none;
    margin-top: 0;
    padding-top: 0;
  }

  .modal-box {
    width: 98%;
    max-width: 98%;
    margin: 4px;
  }

  .modal-footer {
    flex-wrap: wrap;
    gap: 6px;
  }

  .modal-footer .btn {
    flex: 1;
    min-width: 80px;
    justify-content: center;
  }

  .notes-panel {
    width: 100% !important;
    max-width: 100% !important;
  }
}

@media (max-width: 360px) {
  .sidebar {
    width: 260px !important;
    max-width: 85% !important;
  }
}

/* UI REDESIGN V2 - mobile safety overrides */
@media (max-width: 1023px) {

  html,
  body {
    max-width: 100%;
    overflow-x: hidden !important;
  }

  .app-shell,
  .content-shell {
    width: 100%;
    min-width: 0;
  }

  .sidebar {
    width: 270px !important;
    max-width: 88vw !important;
    flex-direction: column;
    overflow: hidden !important;
  }

  .sidebar-header,
  .sidebar-footer,
  #mobileSettingsSection {
    flex: 0 0 auto;
  }

  .sidebar-scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
  }

  .app-topbar {
    height: 64px !important;
    padding: 0 14px !important;
  }

  .app-topbar-inner {
    min-width: 0;
  }

  .topbar-left {
    max-width: none !important;
    min-width: 0;
    flex: 1 1 auto;
    gap: 10px !important;
  }

  .topbar-search-box {
    max-width: none !important;
    min-width: 0;
    flex: 1 1 auto !important;
  }

  .main-content {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
    padding: 16px !important;
  }

  .dashboard-table-card,
  .acc-list,
  .table-responsive {
    max-width: 100%;
    min-width: 0;
  }

  .table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .acc-table {
    min-width: 1078px;
  }

  .account-toolbar {
    flex-direction: column;
    align-items: stretch !important;
  }

  .toolbar-left,
  .toolbar-right {
    width: 100%;
    flex-wrap: wrap;
  }

  .selection-bar .actions {
    width: 100%;
  }
}

@media (max-width: 760px) {
  .app-topbar-inner {
    gap: 8px !important;
  }

  .topbar-left {
    gap: 8px !important;
  }

  .header-left-brand a span,
  #btnTheme {
    display: none !important;
  }

  .topbar-search-box {
    max-width: 260px !important;
  }

  .sync-status-container {
    display: none !important;
  }

  #btnAddAcc {
    min-width: 44px !important;
    padding: 0 10px !important;
  }

  #btnTools,
  .avatar-btn,
  #topbarSidebarToggleBtn {
    width: 38px !important;
    min-width: 38px !important;
    padding: 0 !important;
    justify-content: center;
  }

  #btnTools span:not(#toolsBadgeDot),
  .avatar-arrow {
    display: none !important;
  }

  .accounts-hero {
    padding: 22px 0 20px !important;
  }

  .accounts-period-control,
  .accounts-hero-action-row {
    overflow-x: auto;
    flex-wrap: nowrap !important;
    padding-bottom: 4px;
    -webkit-overflow-scrolling: touch;
  }

  .accounts-period-buttons {
    display: flex !important;
    grid-template-columns: none !important;
    flex-wrap: nowrap !important;
  }

  .accounts-hero-action-row .btn,
  .period-btn {
    white-space: nowrap;
  }
}

@media (max-width: 520px) {
  .topbar-search-box {
    max-width: 170px !important;
    min-width: 0 !important;
  }

  .topbar-search-box input::placeholder {
    color: transparent;
  }

  .topbar-search-box kbd {
    display: none !important;
  }

  #btnAddAcc span {
    display: none !important;
  }
}

@media (max-width: 480px) {
  .content-actions .btn {
    min-width: 0;
  }

  #viewTitle {
    font-size: 22px;
  }

  .bulk-divider {
    display: none;
  }
}

/* === MOBILE APP SHELL REDESIGN === */
.mobile-bottom-nav {
  display: none;
}

@media (max-width: 767px) {
  :root {
    --mobile-bottom-nav-h: 68px;
  }

  html,
  body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden !important;
  }

  body.mobile-menu-open {
    overflow: hidden;
  }

  .mobile-bottom-nav {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 180;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    height: calc(var(--mobile-bottom-nav-h) + env(safe-area-inset-bottom));
    padding: 7px 8px calc(7px + env(safe-area-inset-bottom));
    background: color-mix(in srgb, var(--surface-1) 94%, transparent);
    border-top: 1px solid var(--border-strong);
    box-shadow: 0 -10px 30px rgba(0, 0, 0, .28);
    backdrop-filter: blur(16px);
  }

  .mobile-bottom-nav-item {
    appearance: none;
    min-width: 0;
    min-height: 52px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    border: 1px solid transparent;
    border-radius: 10px;
    background: transparent;
    color: var(--text-secondary);
    font: inherit;
    font-size: 10px;
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: 0;
    cursor: pointer;
    transition: background .18s ease, border-color .18s ease, color .18s ease;
  }

  .mobile-bottom-nav-item.active {
    color: var(--text-primary);
    background: var(--accent-soft);
    border-color: var(--accent-border);
  }

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

  .mobile-nav-icon svg {
    width: 21px;
    height: 21px;
    stroke-width: 2.15;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .app-shell,
  .content-shell,
  .main-content,
  .dashboard-view,
  .settings-view,
  .orders-page,
  .data-management-view,
  #liveLogView {
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .content-shell,
  .main-content,
  .dashboard-view,
  .settings-view,
  .orders-page,
  .data-management-view,
  #liveLogView,
  #ordersView,
  #detailView,
  #settingsView,
  #dataManagementView {
    padding-bottom: calc(var(--mobile-bottom-nav-h) + 30px + env(safe-area-inset-bottom)) !important;
  }

  .main-content {
    padding: 12px !important;
  }

  .app-topbar {
    height: 56px !important;
    padding: 0 10px !important;
  }

  .app-topbar-inner,
  .topbar-left,
  .topbar-right {
    min-width: 0;
  }

  .topbar-left {
    gap: 8px !important;
    flex: 1 1 auto;
  }

  .topbar-right {
    flex: 0 0 auto;
    gap: 6px !important;
  }

  .topbar-search-box {
    height: 40px;
    max-width: 180px !important;
    min-width: 0 !important;
  }

  .topbar-search-box input {
    min-width: 0;
    font-size: 13px;
  }

  .topbar-search-box kbd,
  .header-left-brand a span,
  #btnTheme,
  .sync-status-container,
  .avatar-arrow {
    display: none !important;
  }

  #btnTools,
  .avatar-btn,
  #topbarSidebarToggleBtn,
  #btnAddAcc {
    min-width: 40px !important;
    width: 40px !important;
    height: 40px !important;
    padding: 0 !important;
    justify-content: center;
  }

  #btnTools span:not(#toolsBadgeDot),
  #btnAddAcc span,
  .avatar-email,
  .avatar-btn span:not(.avatar-icon) {
    display: none !important;
  }

  .content-header,
  .account-toolbar,
  .toolbar-left,
  .toolbar-right,
  .dashboard-toolbar,
  .dashboard-tabbar,
  .orders-toolbar,
  .dm-toolbar,
  .settings-toolbar {
    min-width: 0;
  }

  .content-header,
  .account-toolbar,
  .orders-toolbar,
  .dm-toolbar {
    align-items: stretch !important;
  }

  .toolbar-left,
  .toolbar-right,
  .content-actions,
  .orders-toolbar,
  .dm-toolbar {
    gap: 8px !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .toolbar-left::-webkit-scrollbar,
  .toolbar-right::-webkit-scrollbar,
  .content-actions::-webkit-scrollbar,
  .orders-toolbar::-webkit-scrollbar,
  .dm-toolbar::-webkit-scrollbar {
    display: none;
  }

  button,
  .btn,
  input,
  select,
  textarea,
  .period-btn,
  .pg-btn,
  .status-pill,
  .row-action-btn {
    min-height: 44px;
  }

  input,
  select,
  textarea {
    font-size: 16px;
  }

  .modal {
    align-items: flex-end !important;
    padding: 0 !important;
  }

  .modal-box {
    width: 100vw !important;
    max-width: 100vw !important;
    max-height: 100dvh !important;
    margin: 0 !important;
    border-radius: 16px 16px 0 0 !important;
    border-left: 0;
    border-right: 0;
    border-bottom: 0;
  }

  .modal-header {
    position: sticky;
    top: 0;
    z-index: 2;
    background: var(--card);
    border-bottom: 1px solid var(--line);
  }

  .modal-body {
    max-height: calc(100dvh - 148px);
    overflow-y: auto;
    padding: 14px !important;
    -webkit-overflow-scrolling: touch;
  }

  .modal-footer {
    position: sticky;
    bottom: 0;
    z-index: 2;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    padding: 12px 14px calc(12px + env(safe-area-inset-bottom)) !important;
    background: var(--card);
    border-top: 1px solid var(--line);
  }

  .modal-footer .btn {
    width: 100%;
    justify-content: center;
  }

  .drawer,
  .orders-detail-drawer,
  .notes-panel {
    width: 100vw !important;
    max-width: 100vw !important;
  }

  .drawer-panel {
    width: 100vw !important;
    max-width: 100vw !important;
  }

  .table-responsive,
  .dash-v-table-wrap,
  .tx-table-scroll,
  .dm-table-wrap {
    width: 100%;
    overflow: visible !important;
  }

  .acc-table,
  .dash-v-table,
  .tx-table,
  .dm-table {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    table-layout: auto !important;
    border-collapse: separate;
    border-spacing: 0;
  }

  .acc-table colgroup,
  .dash-v-table colgroup,
  .tx-table colgroup,
  .dm-table colgroup,
  .acc-table thead,
  .dash-v-table thead,
  .tx-table thead,
  .dm-table thead {
    display: none !important;
  }

  .acc-table tbody,
  .dash-v-table tbody,
  .tx-table tbody,
  .dm-table tbody {
    display: grid;
    gap: 10px;
    width: 100%;
  }

  .acc-table tr,
  .dash-v-table tr,
  .tx-table tr,
  .dm-table tr {
    display: grid;
    width: 100%;
    min-width: 0;
    padding: 12px;
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 12px;
  }

  .acc-table td,
  .dash-v-table td,
  .tx-table td,
  .dm-table td {
    display: flex !important;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    min-width: 0;
    width: 100% !important;
    padding: 8px 0 !important;
    border: 0 !important;
    border-bottom: 1px solid var(--border-soft) !important;
    text-align: right !important;
    white-space: normal !important;
    word-break: break-word;
  }

  .acc-table td:last-child,
  .dash-v-table td:last-child,
  .tx-table td:last-child,
  .dm-table td:last-child {
    border-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  .acc-table td::before,
  .dash-v-table td::before,
  .tx-table td::before,
  .dm-table td::before {
    content: attr(data-label);
    flex: 0 0 34%;
    max-width: 42%;
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    line-height: 1.35;
    text-align: left;
    text-transform: uppercase;
  }

  .acc-table .td-check {
    justify-content: flex-start !important;
    padding-bottom: 10px !important;
  }

  .acc-table .td-check::before {
    display: none;
  }

  .acc-table .td-account,
  .acc-table .td-category,
  .acc-table .td-status-quick,
  .acc-table .td-note,
  .acc-table .td-actions {
    align-items: flex-start;
  }

  .acc-table .account-cell,
  .acc-table .category-tags,
  .acc-table .quick-status-pills,
  .acc-table .row-actions,
  .acc-table .action-buttons,
  .acc-table .note-cell,
  .acc-table .date-cell {
    min-width: 0;
    max-width: 62%;
    justify-content: flex-end;
  }

  .acc-table .account-cell,
  .acc-table .category-tags,
  .acc-table .quick-status-pills,
  .acc-table .row-actions,
  .acc-table .action-buttons {
    flex-wrap: wrap;
  }

  .acc-table .account-main,
  .acc-table .account-sub,
  .acc-table .note-cell {
    text-align: right;
  }

  .acc-table .status-pill {
    min-height: 36px;
    padding: 7px 9px;
  }

  .acc-table .td-actions,
  .dm-table td:last-child {
    justify-content: space-between !important;
  }

  .acc-table .row-action-btn,
  .dm-table .icon-btn {
    min-width: 40px;
    min-height: 40px;
  }

  .selection-bar {
    position: fixed !important;
    left: 10px !important;
    right: 10px !important;
    bottom: calc(var(--mobile-bottom-nav-h) + 10px + env(safe-area-inset-bottom)) !important;
    z-index: 181 !important;
    width: auto !important;
    max-width: none !important;
    padding: 10px !important;
    background: var(--surface-2) !important;
    border: 1px solid var(--border-strong) !important;
    border-radius: 12px !important;
    box-shadow: 0 12px 35px rgba(0, 0, 0, .35);
  }

  .selection-bar .actions {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    width: 100%;
  }

  .selection-bar .btn {
    width: 100%;
    justify-content: center;
  }

  #statsGrid.stats-grid,
  .dash-v-metrics,
  .dashboard-kpi-grid,
  .orders-kpi-grid,
  .dm-kpi-grid,
  .settings-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  .dash-v-grid,
  .dash-v-panels,
  .dashboard-grid,
  .orders-grid,
  .settings-layout,
  .dm-layout {
    grid-template-columns: 1fr !important;
  }

  .dash-tabs,
  .dashboard-tabs,
  .orders-tabs,
  .dm-tabs,
  .notes-filter-tabs,
  .accounts-period-control,
  .accounts-hero-action-row {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .dash-tabs::-webkit-scrollbar,
  .dashboard-tabs::-webkit-scrollbar,
  .orders-tabs::-webkit-scrollbar,
  .dm-tabs::-webkit-scrollbar,
  .notes-filter-tabs::-webkit-scrollbar,
  .accounts-period-control::-webkit-scrollbar,
  .accounts-hero-action-row::-webkit-scrollbar {
    display: none;
  }

  .dash-tabs .btn,
  .dashboard-tabs .btn,
  .orders-tabs .btn,
  .dm-tabs .btn,
  .notes-filter-tabs .notes-tab,
  .accounts-hero-action-row .btn,
  .period-btn {
    flex: 0 0 auto;
    white-space: nowrap;
  }

  .orders-page {
    padding: 12px !important;
  }

  .orders-header,
  .orders-toolbar,
  .orders-filter-grid,
  .orders-summary-grid,
  .orders-list-header {
    grid-template-columns: 1fr !important;
    align-items: stretch !important;
  }

  .orders-list,
  .orders-cards,
  .orders-card-list {
    gap: 10px !important;
  }

  .live-log-shell,
  .live-log-layout,
  .activity-layout {
    grid-template-columns: 1fr !important;
  }

  .live-log-terminal,
  .activity-log,
  pre,
  code {
    max-width: 100%;
    white-space: pre-wrap;
    word-break: break-word;
  }

  .dm-table .dm-dot,
  .category-tag,
  .tag,
  .badge {
    flex: 0 0 auto;
  }

  .pg-wrap,
  .pagination,
  .dm-pagination,
  .orders-pagination {
    flex-wrap: wrap;
    justify-content: center !important;
    gap: 8px;
  }

  .pg-nav,
  .pg-size {
    width: 100%;
    justify-content: center;
  }

  /* Mobile-first Account Card Layout */
  .acc-mobile-cards {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 4px 0;
  }

  .acc-mobile-cards .acc-card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    transition: transform 0.2s ease, border-color 0.2s ease;
  }

  .acc-mobile-cards .acc-card.selected,
  .acc-mobile-cards .acc-card.is-selected {
    border-color: var(--accent) !important;
    background: color-mix(in srgb, var(--accent) 5%, var(--card)) !important;
  }

  .acc-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
  }

  .acc-card-header-left {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    min-width: 0;
  }

  .acc-card-username {
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 140px;
  }

  .acc-card-header-right {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
  }

  .acc-card-body {
    display: flex;
    flex-direction: column;
    gap: 6px;
  }

  .acc-card-categories {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
  }

  .acc-card-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 11px;
    color: var(--muted);
  }

  .acc-card-note {
    background: rgba(0, 0, 0, 0.2);
    border-left: 3px solid var(--accent);
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 11px;
    color: var(--text-secondary);
    margin-top: 2px;
    word-break: break-word;
  }

  .acc-card-footer {
    display: flex;
    flex-direction: column;
    gap: 8px;
    border-top: 1px solid var(--line);
    padding-top: 8px;
    margin-top: 2px;
  }

  .acc-card-financials {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 12px;
    color: var(--text-secondary);
  }

  .acc-card-financials .fin-item strong {
    color: var(--text);
  }

  .acc-card-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
    flex-wrap: wrap;
  }

  .acc-card-actions .btn {
    min-height: 32px !important;
    height: 32px !important;
    padding: 0 10px !important;
    font-size: 12px !important;
  }

  .acc-card-actions .quick-status-pills {
    display: flex;
    gap: 2px;
  }

  .acc-card-actions .quick-status-pills .status-pill {
    min-height: 28px !important;
    height: 28px !important;
    min-width: 38px !important;
    padding: 0 4px !important;
    font-size: 11px !important;
    border-radius: 4px !important;
  }

  /* Order Step Wizard styling */
  .order-form-steps {
    display: flex;
    justify-content: space-between;
    background: var(--card2);
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 8px 10px;
    margin-bottom: 14px;
    gap: 4px;
  }

  .order-form-steps .step-dot {
    font-size: 11px;
    font-weight: 600;
    color: var(--muted);
    padding: 4px 6px;
    border-radius: 4px;
    transition: background 0.2s, color 0.2s;
  }

  .order-form-steps .step-dot.active {
    background: var(--accent-soft);
    color: var(--text-primary);
    border: 1px solid var(--accent-border);
  }

  .order-form-mobile-nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: 14px;
  }

  .orders-modal .modal-footer {
    display: none !important;
  }

  /* Dashboard Overview & Transactions Mobile Cards */
  .overview-mobile-list,
  .tx-mobile-list,
  .dm-mobile-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
    margin-top: 10px;
  }

  .overview-mobile-card,
  .tx-mobile-card,
  .dm-mobile-card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 14px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
    transition: transform 0.2s ease, border-color 0.2s ease;
  }

  .overview-mobile-card:hover,
  .tx-mobile-card:hover,
  .dm-mobile-card:hover {
    border-color: var(--accent-border);
  }

  .om-card-header,
  .tx-mobile-card-header,
  .dm-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    border-bottom: 1px solid var(--border-soft);
    padding-bottom: 8px;
  }

  .om-username,
  .tx-mobile-username {
    font-size: 14px;
    font-weight: 600;
    color: var(--text);
  }

  .tx-mobile-user-section {
    display: flex;
    flex-direction: column;
    min-width: 0;
  }

  .tx-mobile-domain {
    font-size: 11px;
    color: var(--muted);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .om-card-body,
  .tx-mobile-card-meta,
  .dm-card-body {
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-size: 12px;
  }

  .om-meta,
  .om-financials,
  .tx-mobile-meta-item,
  .dm-meta-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: var(--text-secondary);
  }

  .tx-mobile-meta-item.source-seller {
    flex-wrap: wrap;
    gap: 4px;
  }

  .tx-mobile-card-finance {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    background: var(--card2);
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 8px 10px;
    margin-top: 4px;
  }

  .tx-mobile-card-finance .fin-box {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: 11px;
    color: var(--muted);
  }

  .tx-mobile-card-finance .fin-box strong {
    font-size: 12px;
    color: var(--text);
  }

  .tx-mobile-card-finance .fin-box.profit.is-good strong {
    color: var(--good);
  }

  .tx-mobile-card-finance .fin-box.profit.is-bad strong {
    color: var(--danger);
  }

  .tx-mobile-note,
  .dm-card-note {
    background: rgba(0, 0, 0, 0.2);
    border-left: 3px solid var(--accent);
    padding: 6px 10px;
    border-radius: 4px;
    font-size: 11px;
    color: var(--text-secondary);
    margin-top: 4px;
    word-break: break-word;
  }

  .tx-mobile-card-actions,
  .dm-card-actions {
    margin-top: 6px;
    display: flex;
    gap: 8px;
  }

  .dm-card-actions.two-btns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .tx-mobile-card-actions .btn,
  .dm-card-actions .btn {
    min-height: 40px !important;
    justify-content: center;
    width: 100%;
  }

  /* Data Management specific styles */
  .dm-game-title,
  .dm-seller-title,
  .dm-cat-title-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
  }

  .dm-meta-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin: 4px 0;
  }

  .dm-meta-grid div {
    display: flex;
    flex-direction: column;
    gap: 2px;
    background: var(--card2);
    border: 1px solid var(--line);
    border-radius: 6px;
    padding: 6px;
    font-size: 11px;
    color: var(--muted);
  }

  .dm-meta-grid div strong {
    font-size: 12px;
    color: var(--text);
  }

  .dm-card-time {
    font-size: 10px;
    color: var(--muted);
    text-align: right;
    margin-top: 2px;
  }

  .dm-chip {
    display: inline-flex;
    align-items: center;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 600;
  }

  .dm-chip.group-chip {
    background: rgba(139, 92, 246, 0.15);
    color: #a78bfa;
    border: 1px solid rgba(139, 92, 246, 0.3);
  }

  .dm-chip.child-chip {
    background: rgba(16, 185, 129, 0.15);
    color: #34d399;
    border: 1px solid rgba(16, 185, 129, 0.3);
  }

  .dm-mobile-card.kind-child {
    border-left: 4px solid var(--good);
    padding-left: 10px;
  }

  .dm-mobile-card.kind-group {
    border-left: 4px solid #8b5cf6;
    padding-left: 10px;
  }

  /* === MOBILE ACCOUNTS VIEW STYLING & COMPACT CARD OVERRIDES === */

  /* Show mobile-specific elements */
  .mobile-search-toggle-btn {
    display: flex !important;
    align-items: center;
    justify-content: center;
  }

  /* Hide desktop topbar buttons on mobile */
  #btnTools,
  .tools-dropdown,
  .avatar-dropdown,
  .avatar-btn,
  #avatarBtn,
  #btnManualSave,
  #btnUndo,
  #btnUndoHistory {
    display: none !important;
  }

  /* Hide desktop bulk status buttons and show compact toggle button */
  #bulkStatusAvailable,
  #bulkStatusSold,
  #bulkStatusDie,
  #bulkStatusBanned,
  #bulkStatusFaceid {
    display: none !important;
  }

  .mobile-bulk-status-btn,
  #bulkStatusToggleBtn {
    display: block !important;
  }

  .selection-bar .actions {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    width: 100% !important;
  }

  /* Mobile Search Box Toggled Styling */
  .topbar-search-box {
    display: none !important;
    position: absolute !important;
    top: 56px !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-width: none !important;
    height: 48px !important;
    background: var(--card2) !important;
    border: none !important;
    border-bottom: 1px solid var(--line) !important;
    padding: 0 16px !important;
    z-index: 100 !important;
  }

  .topbar-search-box.show-mobile {
    display: flex !important;
    align-items: center !important;
  }

  .topbar-search-box input {
    width: 100% !important;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    font-size: 14px !important;
  }

  /* Mobile Filter Bar & Status Chips */
  .mobile-filter-bar {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin: 8px 0 !important;
    width: 100% !important;
  }

  .mobile-search-wrap {
    position: relative !important;
    flex: 1 !important;
    display: flex !important;
    align-items: center !important;
  }

  .mobile-search-icon {
    position: absolute !important;
    left: 10px !important;
    width: 16px !important;
    height: 16px !important;
    color: var(--muted) !important;
    pointer-events: none !important;
  }

  #mobileAccFilterSearch {
    width: 100% !important;
    height: 38px !important;
    padding: 0 10px 0 32px !important;
    background: var(--card) !important;
    border: 1px solid var(--line) !important;
    border-radius: 8px !important;
    color: var(--text) !important;
    font-size: 14px !important;
    outline: none !important;
    transition: border-color 0.2s !important;
  }

  #mobileAccFilterSearch:focus {
    border-color: var(--accent) !important;
  }

  #mobileFilterToggleBtn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    height: 38px !important;
    padding: 0 14px !important;
    background: var(--card) !important;
    border: 1px solid var(--line) !important;
    border-radius: 8px !important;
    color: var(--text) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
  }

  .mobile-status-chips {
    display: flex !important;
    gap: 8px !important;
    overflow-x: auto !important;
    padding: 4px 0 10px 0 !important;
    margin-bottom: 8px !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
  }

  .mobile-status-chips::-webkit-scrollbar {
    display: none !important;
  }

  .status-chip {
    flex: 0 0 auto !important;
    height: 32px !important;
    padding: 0 14px !important;
    background: var(--card) !important;
    border: 1px solid var(--line) !important;
    border-radius: 20px !important;
    color: var(--muted) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
  }

  .status-chip.active {
    background: var(--accent) !important;
    color: #fff !important;
    border-color: var(--accent) !important;
    box-shadow: 0 2px 8px rgba(139, 92, 246, 0.3) !important;
  }

  /* Filter Panel Bottom Sheet Layout */
  .accounts-filter-panel {
    display: none !important;
    position: fixed !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: var(--card) !important;
    border: none !important;
    border-top: 1px solid var(--line) !important;
    border-radius: 16px 16px 0 0 !important;
    padding: 28px 16px 16px 16px !important;
    z-index: 210 !important;
    box-shadow: 0 -10px 30px rgba(0, 0, 0, 0.4) !important;
    flex-direction: column !important;
    gap: 14px !important;
    margin-top: 0 !important;
  }

  .accounts-filter-panel.show-mobile-sheet {
    display: flex !important;
  }

  .filter-panel-close-btn {
    display: flex !important;
    position: absolute !important;
    top: 10px !important;
    right: 12px !important;
    width: 24px !important;
    height: 24px !important;
    border: none !important;
    background: transparent !important;
    color: var(--text-secondary) !important;
    font-size: 16px !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    z-index: 10 !important;
  }

  .filter-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  .filter-field-search {
    grid-column: span 2 !important;
  }

  /* Compact Account Cards UI */
  .acc-mobile-cards .acc-card.is-mobile-card {
    padding: 12px !important;
    gap: 6px !important;
    border-radius: 12px !important;
    border: 1px solid var(--line) !important;
    background: var(--card) !important;
  }

  .acc-card.is-mobile-card.available {
    border-left: 4px solid var(--good) !important;
  }
  .acc-card.is-mobile-card.sold {
    border-left: 4px solid var(--warn) !important;
  }
  .acc-card.is-mobile-card.die {
    border-left: 4px solid var(--danger) !important;
  }
  .acc-card.is-mobile-card.banned {
    border-left: 4px solid #f97316 !important;
  }
  .acc-card.is-mobile-card.faceid {
    border-left: 4px solid #3b82f6 !important;
  }

  .acc-card-username {
    font-size: 15px !important;
    font-weight: 600 !important;
    max-width: 160px !important;
  }

  .mobile-dots-btn {
    width: 32px !important;
    height: 32px !important;
    border: 1px solid var(--line) !important;
    background: var(--card2) !important;
    color: var(--text) !important;
    border-radius: 6px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 16px !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
  }

  .mobile-dots-btn:hover {
    background: var(--line) !important;
  }

  .status-pill {
    padding: 2px 6px !important;
    border-radius: 4px !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    line-height: 1.2 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: auto !important;
  }

  .status-pill.status-available {
    background: rgba(16, 185, 129, 0.15) !important;
    color: var(--good) !important;
    border: 1px solid rgba(16, 185, 129, 0.3) !important;
  }

  .status-pill.status-sold {
    background: rgba(245, 158, 11, 0.15) !important;
    color: var(--warn) !important;
    border: 1px solid rgba(245, 158, 11, 0.3) !important;
  }

  .status-pill.status-die {
    background: rgba(239, 68, 68, 0.15) !important;
    color: var(--danger) !important;
    border: 1px solid rgba(239, 68, 68, 0.3) !important;
  }

  .status-pill.status-banned {
    background: rgba(249, 115, 22, 0.15) !important;
    color: #f97316 !important;
    border: 1px solid rgba(249, 115, 22, 0.3) !important;
  }

  .status-pill.status-faceid {
    background: rgba(59, 130, 246, 0.15) !important;
    color: #3b82f6 !important;
    border: 1px solid rgba(59, 130, 246, 0.3) !important;
  }

  .category-tag {
    display: inline-flex !important;
    align-items: center !important;
    padding: 3px 8px !important;
    border-radius: 6px !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    border: 1px solid var(--tag-border, var(--line)) !important;
    color: var(--tag-color, var(--text-secondary)) !important;
    background: var(--tag-bg, var(--card2)) !important;
  }

  .acc-card-financials {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    font-size: 12px !important;
    color: var(--text-secondary) !important;
    gap: 6px !important;
    flex-wrap: wrap !important;
  }

  .acc-card-financials .fin-item {
    flex: 1 1 0px !important;
    background: var(--card2) !important;
    border: 1px solid var(--line) !important;
    padding: 5px !important;
    border-radius: 6px !important;
    text-align: center !important;
    font-size: 11px !important;
  }

  .profit-value.is-positive {
    color: var(--good) !important;
  }
  .profit-value.is-negative {
    color: var(--danger) !important;
  }

  .acc-card-actions {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 6px !important;
    width: 100% !important;
  }

  .acc-card-actions .btn {
    width: 100% !important;
    justify-content: center !important;
    font-size: 12px !important;
    height: 34px !important;
    min-height: 34px !important;
  }

  /* Bottom Sheet Action Menus styling */
  .mobile-action-menu .btn,
  .status-options-list .btn,
  .bulk-status-options-list .btn {
    min-height: 48px !important;
    height: 48px !important;
    padding: 0 16px !important;
    font-size: 14px !important;
    border: 1px solid var(--line) !important;
    background: var(--card) !important;
    color: var(--text) !important;
    border-radius: 8px !important;
    justify-content: flex-start !important;
  }

  .mobile-action-menu .btn:hover,
  .status-options-list .btn:hover,
  .bulk-status-options-list .btn:hover {
    background: var(--line) !important;
  }
}

@media (max-width: 430px) {
  .topbar-search-box {
    max-width: 136px !important;
  }

  .mobile-bottom-nav {
    padding-left: 5px;
    padding-right: 5px;
  }

  .mobile-bottom-nav-item {
    font-size: 9px;
  }

  #statsGrid.stats-grid,
  .dash-v-metrics,
  .dashboard-kpi-grid,
  .orders-kpi-grid,
  .dm-kpi-grid,
  .settings-grid {
    grid-template-columns: 1fr 1fr !important;
  }

  .modal-footer {
    grid-template-columns: 1fr;
  }

  .selection-bar .actions {
    grid-template-columns: 1fr;
  }
}
