/* ============================================================================
   mobile.css — мобільна оптимізація (телефони). ІЗОЛЬОВАНО.
   Усе всередині @media (max-width:768px) → на десктопі НЕ застосовується взагалі.
   Завантажується ПІСЛЯ style.css, тож на конфліктах перемагають ці правила.
   Безпека: тільки візуальні правки + перетворення таблиць у картки (через data-label,
   що проставляє js/mobile.js). Жодної логіки/даних не чіпає.
   ============================================================================ */

@media (max-width: 768px) {

  /* ---- Бокова панель = висувна шухляда + затемнення ---- */
  .sidebar {
    width: 82vw !important;
    min-width: 0 !important;
    max-width: 320px;
    transform: translateX(-100%);
    box-shadow: 2px 0 24px rgba(0,0,0,.28);
    padding-top: env(safe-area-inset-top, 0);
  }
  .sidebar.mobile-open { transform: translateX(0); }
  .main-content { margin-left: 0 !important; }

  .m-sidebar-backdrop {
    position: fixed; inset: 0; z-index: 99;
    background: rgba(0,0,0,.45);
    opacity: 0; pointer-events: none; transition: opacity .2s ease;
  }
  .m-sidebar-backdrop.show { opacity: 1; pointer-events: auto; }
  body.m-noscroll { overflow: hidden; }

  /* приховуємо кнопку «згорнути» сайдбар (на телефоні не потрібна) */
  .sidebar-toggle { display: none !important; }

  /* ---- Топбар ---- */
  .topbar {
    gap: 10px;
    padding: 10px 12px;
    padding-top: calc(10px + env(safe-area-inset-top, 0));
  }
  .mobile-menu-btn { display: flex !important; font-size: 22px; padding: 6px 8px; }
  .topbar-search { max-width: none; }
  .topbar-search .search-input { font-size: 16px; } /* 16px = iOS не зумить при фокусі */
  /* дублюючі кнопки модулів у топбарі ховаємо — є гамбургер-меню */
  .topbar-actions .topbar-nav-btn { display: none !important; }
  .topbar-actions { gap: 4px; }

  /* ---- Контент сторінки ---- */
  .page-container { padding: 12px; }
  .page-content { padding: 12px !important; }
  .page-header { padding: 8px 12px !important; }
  .page-header h1, .page-title { font-size: 19px !important; }

  /* широкі сітки → 1 колонка */
  .mdash-grid, .dashboard-grid, .stats-grid, .report-grid,
  .dashboard-charts-grid, .cards-grid, .grid-2, .grid-3, .grid-4 {
    grid-template-columns: 1fr !important;
  }
  .mdash-card.mdash-w2 { width: auto !important; }

  /* фільтри в стовпчик, поля на всю ширину */
  .filters-bar, .filter-bar, .toolbar, .filters { flex-direction: column; align-items: stretch; }
  .filter-select, .filter-search, .filters-bar select, .filters-bar input { min-width: 100% !important; width: 100% !important; }

  /* ---- Широкі таблиці БЕЗ карток → горизонтальна прокрутка (нічого не губимо) ---- */
  .mv-wrap, .table-scroll, .table-responsive { overflow-x: auto !important; -webkit-overflow-scrolling: touch; }

  /* ---- Таблиці → картки (data-table, mdash-table) ---- */
  table.data-table, table.mdash-table { border: 0 !important; width: 100% !important; }
  table.data-table thead, table.mdash-table thead { position: absolute; left: -9999px; top: -9999px; } /* шапку ховаємо — підписи в кожній комірці */
  table.data-table tbody, table.mdash-table tbody,
  table.data-table tfoot, table.mdash-table tfoot,
  table.data-table tr, table.mdash-table tr,
  table.data-table td, table.mdash-table td { display: block; width: auto !important; }

  table.data-table tr, table.mdash-table tr {
    border: 1px solid var(--border-color);
    border-radius: 12px;
    margin: 0 0 10px;
    padding: 8px 12px;
    background: var(--bg-secondary);
    box-shadow: var(--shadow-xs, 0 1px 2px rgba(0,0,0,.04));
  }
  table.data-table td, table.mdash-table td {
    display: flex; justify-content: space-between; align-items: baseline; gap: 14px;
    border: 0 !important;
    padding: 5px 0 !important;
    text-align: right !important;
    white-space: normal !important;
    min-height: 0 !important;
  }
  table.data-table td::before, table.mdash-table td::before {
    content: attr(data-label);
    font-weight: 600; color: var(--text-muted);
    text-align: left; flex: 0 0 auto; max-width: 45%;
  }
  /* перша комірка рядка = «заголовок» картки */
  table.data-table td:first-child, table.mdash-table td:first-child {
    font-weight: 700; font-size: 15px; padding-top: 0 !important;
  }
  table.data-table td:first-child::before, table.mdash-table td:first-child::before { content: ""; }
  /* порожні комірки в картці не показуємо */
  table.data-table td:empty, table.mdash-table td:empty { display: none; }
  /* рядки-«немає даних» / colspan — на всю ширину без підпису */
  table.data-table td[colspan]::before, table.mdash-table td[colspan]::before { content: ""; }
  table.data-table td[colspan], table.mdash-table td[colspan] { justify-content: flex-start; }
  /* підсумковий рядок «Разом» — виділяємо */
  table.mdash-table tfoot tr, table.data-table tfoot tr { background: var(--accent-light); }

  /* ---- Модалки = нижній лист майже на весь екран ---- */
  .modal-overlay { padding: 0; align-items: flex-end; }
  .modal-content {
    max-width: 100% !important;
    width: 100% !important;
    max-height: 92vh !important;
    border-radius: 18px 18px 0 0 !important;
    margin: 0 !important;
    padding-bottom: env(safe-area-inset-bottom, 0);
  }
  .modal-header { padding: 16px; position: sticky; top: 0; background: var(--bg-secondary); z-index: 1; }
  .modal-body { padding: 16px; }
  .modal-footer { flex-wrap: wrap; gap: 8px; }
  .modal-footer .btn { flex: 1 1 auto; }

  /* форма: один стовпчик, поля 16px (без зуму iOS) */
  .form-row, .form-grid, .form-grid-2 { grid-template-columns: 1fr !important; }
  input, select, textarea { font-size: 16px !important; }

  /* кнопки — зручні тап-зони */
  .btn { padding: 11px 16px; }
  .btn-sm { padding: 8px 12px; }

  /* панелі сповіщень / AI на всю ширину */
  .notif-panel, .ai-panel { width: 100% !important; right: 0 !important; left: 0 !important; }

  /* вкладки картки компанії — горизонтальний скрол замість переносу в стовпчик */
  .comp-tabs, .tabs, .tab-bar { overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap !important; }
  .comp-tabs::-webkit-scrollbar, .tabs::-webkit-scrollbar { display: none; }

  /* логін — відступи */
  .login-screen .login-card, .login-card { width: 100%; max-width: 380px; }
}

/* дрібніший тир для вузьких телефонів */
@media (max-width: 400px) {
  .topbar-search { display: none; } /* на дуже вузьких — звільняємо місце; пошук доступний на сторінках */
  .page-header h1, .page-title { font-size: 18px !important; }
}
