/* Mobile-only presentation layer.
   Loads after app.css and only applies at phone/tablet breakpoints.
   Desktop remains untouched. */

@media (max-width: 980px){
  html, body {
    max-width: 100%;
    overflow-x: hidden;
  }

  .app-shell,
  .main,
  .content,
  .dashboard-page,
  .card,
  .kpi-card,
  .scorecard-card,
  .list-item,
  .mini-kpi,
  .card-head,
  .page-tools,
  .profile-head,
  .profile-actions,
  .dashboard-layout-toolbar,
  .dashboard-layout-actions,
  .scorecard-actions,
  .partner-health-actions,
  .partners-page-tools,
  .partners-mobile-actions,
  .print-actions,
  .inline-actions,
  .inline-form,
  .actions-row,
  .topbar,
  .top-actions,
  .table-wrap,
  .table,
  .table th,
  .table td,
  .scorecard-table,
  .scorecard-table th,
  .scorecard-table td,
  .form-stack,
  .form-grid,
  .compact-form,
  .grid,
  .grid > *,
  .grid.two > *,
  .grid.three > *,
  .grid.four > *,
  .kpi-grid > *,
  .mini-kpis > *,
  .scorecard-grid-2 > *,
  .scorecard-grid-4 > *,
  .dashboard-target-stack > * {
    min-width: 0;
    max-width: 100%;
  }

  .content {
    padding-left: 16px;
    padding-right: 16px;
  }

  .dashboard-page,
  .scorecard-shell,
  .scorecard-report {
    width: 100%;
    overflow-x: hidden;
  }

  .card,
  .scorecard-card,
  .kpi-card,
  .mini-kpi,
  .list-item {
    overflow: hidden;
  }

  .card,
  .scorecard-card {
    padding: 18px;
  }

  .page-tools,
  .profile-head,
  .card-head,
  .dashboard-layout-toolbar,
  .search-hero-top,
  .search-results-toolbar,
  .scorecard-top,
  .partners-page-tools {
    flex-wrap: wrap;
    align-items: flex-start;
  }

  .profile-actions,
  .dashboard-layout-actions,
  .scorecard-actions,
  .partner-health-actions,
  .partners-mobile-actions,
  .print-actions,
  .inline-actions,
  .actions-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: flex-start;
  }

  .profile-actions > .btn,
  .profile-actions > a,
  .dashboard-layout-actions > .btn,
  .dashboard-layout-actions > a,
  .scorecard-actions > .btn,
  .scorecard-actions > a,
  .partner-health-actions > .btn,
  .partner-health-actions > a,
  .partners-mobile-actions > .btn,
  .partners-mobile-actions > a,
  .print-actions > .btn,
  .print-actions > a,
  .actions-row > .btn,
  .actions-row > a,
  .inline-actions > .btn,
  .inline-actions > a {
    min-height: 42px;
  }

  .grid.two,
  .grid.three,
  .grid.four,
  .scorecard-grid-2,
  .scorecard-grid-4,
  .accounts-mobile-grid,
  .form-grid,
  .grid2,
  .grid4 {
    grid-template-columns: 1fr;
  }

  .kpi-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    overflow: visible;
    margin-bottom: 18px;
  }

  .mini-kpis {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    overflow: visible;
    padding-bottom: 0;
  }

  .kpi-card,
  .mini-kpi {
    width: 100%;
    min-height: 0;
  }

  .list-item {
    align-items: flex-start;
    gap: 12px;
  }

  .item-title,
  .item-meta,
  .item-copy,
  .tag,
  .badge,
  .scorecard-name,
  .scorecard-meta,
  .scorecard-title,
  .scorecard-pill,
  .search-result-title,
  .search-result-meta,
  .profile-title,
  .profile-meta {
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .table-wrap {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }

  .table,
  .scorecard-table {
    width: 100%;
    min-width: 640px;
    table-layout: auto;
  }

  .table th,
  .table td,
  .scorecard-table th,
  .scorecard-table td {
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .form-stack,
  .compact-form,
  .inline-form {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
    align-items: stretch;
  }

  .input,
  .textarea,
  select.input,
  .input-sm,
  button.btn,
  a.btn {
    max-width: 100%;
  }

  .input,
  .textarea,
  select.input {
    min-height: 44px;
    font-size: 16px;
  }

  .textarea {
    width: 100%;
  }

  .dashboard-forecast-row,
  .dashboard-target-stack,
  .search-summary-grid,
  .search-shortcuts-grid,
  .search-best-match-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-page .dashboard-forecast-row .mini-kpis,
  .dashboard-page .dashboard-forecast-row .kpi-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px){
  .content {
    padding-left: 14px;
    padding-right: 14px;
  }

  .card,
  .scorecard-card,
  .kpi-card,
  .mini-kpi {
    border-radius: 16px;
  }

  .card,
  .scorecard-card {
    padding: 16px;
  }

  .kpi-grid,
  .mini-kpis,
  .oem-stat-grid,
  .search-summary-grid {
    grid-template-columns: 1fr;
  }

  .profile-actions,
  .dashboard-layout-actions,
  .scorecard-actions,
  .partner-health-actions,
  .partners-mobile-actions,
  .print-actions,
  .inline-actions,
  .actions-row {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .profile-actions > .btn,
  .profile-actions > a,
  .dashboard-layout-actions > .btn,
  .dashboard-layout-actions > a,
  .scorecard-actions > .btn,
  .scorecard-actions > a,
  .partner-health-actions > .btn,
  .partner-health-actions > a,
  .partners-mobile-actions > .btn,
  .partners-mobile-actions > a,
  .print-actions > .btn,
  .print-actions > a,
  .inline-actions > .btn,
  .inline-actions > a,
  .actions-row > .btn,
  .actions-row > a,
  .inline-form > .btn,
  .inline-form > a,
  .inline-form > button {
    width: 100%;
  }

  .table,
  .scorecard-table {
    min-width: 560px;
  }

  .table th,
  .table td,
  .scorecard-table th,
  .scorecard-table td {
    padding: 12px 10px;
    font-size: 13px;
  }

  .profile-title,
  .search-hero-title {
    font-size: 24px;
    line-height: 1.15;
  }

  .scorecard-list-item,
  .list-item {
    padding: 12px;
  }
}


/* =========================================================
   Dashboard mobile hardening restore + Reports page mobile cleanup.
   Presentation-only and mobile-only.
   ========================================================= */
@media (max-width: 980px){
  .dashboard-page{
    overflow-x:hidden;
  }

  .dashboard-page > *,
  .reports-page,
  .reports-page > *{
    min-width:0;
    max-width:100%;
  }

  .dashboard-page .dashboard-layout-board,
  .dashboard-page [data-dashboard-card]{
    display:block;
    width:100%;
    min-width:0;
    max-width:100%;
  }

  .dashboard-page [data-dashboard-card]{
    margin-bottom:16px !important;
  }

  .dashboard-page .dashboard-layout-toolbar,
  .dashboard-page .dashboard-layout-actions,
  .dashboard-page .dashboard-layout-note,
  .reports-page .dashboard-layout-toolbar,
  .reports-page .dashboard-layout-actions,
  .reports-page .dashboard-layout-note,
  .reports-page .actions-row{
    width:100%;
    min-width:0;
  }

  .dashboard-page .dashboard-layout-toolbar,
  .reports-page .dashboard-layout-toolbar{
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
  }

  .dashboard-page .dashboard-layout-actions,
  .reports-page .dashboard-layout-actions,
  .reports-page .actions-row{
    display:flex;
    flex-wrap:wrap;
    justify-content:flex-start;
    gap:10px;
  }

  .dashboard-page .dashboard-layout-actions > *,
  .reports-page .dashboard-layout-actions > *,
  .reports-page .actions-row > *{
    flex:0 1 auto;
    max-width:100%;
  }

  .dashboard-page .dashboard-layout-actions .btn,
  .dashboard-page .dashboard-layout-actions a,
  .reports-page .dashboard-layout-actions .btn,
  .reports-page .dashboard-layout-actions a,
  .reports-page .actions-row .btn,
  .reports-page .actions-row a{
    min-height:44px;
  }

  .dashboard-page .kpi-grid,
  .dashboard-page .mini-kpis{
    display:grid !important;
    grid-auto-flow:row !important;
    grid-auto-columns:auto !important;
    overflow:visible !important;
    width:100%;
    min-width:0;
    max-width:100%;
    padding-bottom:0;
    margin-left:0;
    margin-right:0;
  }

  .dashboard-page .kpi-grid,
  .reports-page .kpi-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
    gap:12px !important;
  }

  .dashboard-page .mini-kpis{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
    gap:12px !important;
  }

  .dashboard-page .kpi-card,
  .dashboard-page .mini-kpi,
  .reports-page .kpi-card{
    width:100%;
    min-width:0;
    max-width:100%;
    min-height:0;
    overflow:hidden;
    scroll-snap-align:none;
  }

  .dashboard-page .kpi-card strong,
  .reports-page .kpi-card strong{
    font-size:24px;
    line-height:1.15;
  }

  .dashboard-page .card,
  .dashboard-page .scorecard-card,
  .reports-page .card{
    width:100%;
    min-width:0;
    max-width:100%;
    overflow:hidden;
  }

  .dashboard-page .card-head,
  .reports-page .card-head{
    display:flex;
    flex-wrap:wrap;
    align-items:flex-start;
    justify-content:space-between;
    gap:8px 12px;
    width:100%;
    min-width:0;
  }

  .dashboard-page .card-head > h3,
  .dashboard-page .card-head > div,
  .dashboard-page .card-head > a,
  .dashboard-page .card-head > span,
  .reports-page .card-head > h3,
  .reports-page .card-head > div,
  .reports-page .card-head > a,
  .reports-page .card-head > span{
    min-width:0;
    max-width:100%;
  }

  .dashboard-page .card-head > h3,
  .reports-page .card-head > h3{
    flex:1 1 220px;
    overflow-wrap:anywhere;
    word-break:break-word;
    line-height:1.2;
  }

  .dashboard-page .card-head > div,
  .dashboard-page .card-head > a,
  .dashboard-page .card-head > span,
  .reports-page .card-head > div,
  .reports-page .card-head > a,
  .reports-page .card-head > span{
    flex:1 1 100%;
    overflow-wrap:anywhere;
    word-break:break-word;
  }

  .dashboard-page .list-stack,
  .dashboard-page .list-item,
  .dashboard-page .list-item > div,
  .reports-page .list-stack,
  .reports-page .list-item,
  .reports-page .list-item > div{
    min-width:0;
    max-width:100%;
  }

  .dashboard-page .list-item,
  .reports-page .list-item{
    display:flex;
    align-items:flex-start;
    gap:10px;
  }

  .dashboard-page .item-title,
  .dashboard-page .item-meta,
  .dashboard-page .tag,
  .dashboard-page .badge,
  .reports-page .item-title,
  .reports-page .item-meta,
  .reports-page .tag,
  .reports-page .badge{
    overflow-wrap:anywhere;
    word-break:break-word;
  }

  .dashboard-page .simple-bars,
  .dashboard-page .bar-row,
  .reports-page .simple-bars,
  .reports-page .bar-row{
    min-width:0;
    max-width:100%;
  }

  .dashboard-page .bar-row,
  .reports-page .bar-row{
    grid-template-columns:44px minmax(0,1fr) auto;
    gap:10px;
    align-items:center;
  }

  .dashboard-page .bar-row > span,
  .reports-page .bar-row > span,
  .dashboard-page .bar-row > strong,
  .reports-page .bar-row > strong{
    white-space:nowrap;
  }

  .dashboard-page .bar-row .bar-track,
  .reports-page .bar-row .bar-track{
    min-width:0;
    width:100%;
  }

  .dashboard-page .table-wrap,
  .reports-page .table-wrap{
    width:100%;
    max-width:100%;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
  }

  .dashboard-page .table,
  .reports-page .table{
    width:100%;
    min-width:560px;
    table-layout:auto;
  }

  .dashboard-page .table th,
  .dashboard-page .table td,
  .reports-page .table th,
  .reports-page .table td{
    white-space:normal;
    overflow-wrap:anywhere;
    word-break:break-word;
    vertical-align:top;
  }

  .dashboard-page .dashboard-target-stack{
    display:grid;
    grid-template-columns:1fr;
    gap:16px;
  }

  .dashboard-page .dashboard-target-stack .card{
    margin:0;
  }

  .dashboard-page .dashboard-forecast-row{
    grid-template-columns:1fr !important;
    gap:16px !important;
  }

  .dashboard-page .dashboard-forecast-row > .card{
    width:100%;
    min-width:0;
    max-width:100%;
  }

  .reports-page .dashboard-layout-board{
    display:block;
    width:100%;
    min-width:0;
    max-width:100%;
    overflow-x:hidden;
  }

  .reports-page [data-dashboard-card]{
    display:block;
    width:100%;
    min-width:0;
    max-width:100%;
    margin-bottom:16px !important;
  }

  .reports-page .grid.two{
    grid-template-columns:1fr !important;
    gap:16px !important;
  }
}

@media (max-width: 720px){
  .dashboard-page .kpi-grid,
  .dashboard-page .mini-kpis,
  .reports-page .kpi-grid{
    grid-template-columns:1fr !important;
  }

  .dashboard-page .kpi-card strong,
  .reports-page .kpi-card strong{
    font-size:22px;
  }

  .dashboard-page .dashboard-layout-actions,
  .reports-page .dashboard-layout-actions,
  .reports-page .actions-row{
    display:grid;
    grid-template-columns:1fr;
  }

  .dashboard-page .dashboard-layout-actions > *,
  .reports-page .dashboard-layout-actions > *,
  .reports-page .actions-row > *{
    width:100%;
  }

  .dashboard-page .card,
  .dashboard-page .scorecard-card,
  .reports-page .card{
    padding:16px;
  }

  .dashboard-page .table,
  .reports-page .table{
    min-width:520px;
  }

  .reports-page .bar-row{
    grid-template-columns:40px minmax(0,1fr);
    align-items:flex-start;
  }

  .reports-page .bar-row > strong{
    grid-column:2;
    white-space:normal;
  }
}
/* =========================================================
   ACCOUNTS PAGE MOBILE FIX
   Fix top summary + quick access layout
   ========================================================= */
.accounts-page .page-tools,
.accounts-page .accounts-top-row,
.accounts-page .accounts-summary-row{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:12px;
  align-items:stretch;
}

/* Stop horizontal squeeze / swipe behavior ONLY here */
.accounts-page .mini-kpis{
  display:grid !important;
  grid-template-columns:1fr !important;
  grid-auto-flow:row !important;
  grid-auto-columns:auto !important;
  overflow:visible !important;
  gap:12px;
  margin-bottom:0;
  padding-bottom:0;
}

.accounts-page .mini-kpi{
  width:100%;
  min-height:0;
  padding:16px;
}

/* Ensure cards take full width */
.accounts-page .page-tools > .card{
  width:100%;
  min-width:0;
  max-width:100%;
}

