/* Mobile layer: отдельная адаптация интерфейса для телефонов.
   Desktop-стили не трогаем: этот файл включается только через media query. */

.mobile-only {
  display: none;
}

@media (max-width: 768px) {
  :root {
    --mobile-page-padding: 14px;
    --mobile-radius: 22px;
  }

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

  body {
    display: block !important;
    background: #f4f7fb !important;
  }

  .mobile-only {
    display: initial;
  }

  .app {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 100vh !important;
    display: block !important;
    overflow: visible !important;
  }

  .sidebar {
    position: sticky !important;
    top: 0 !important;
    z-index: 30 !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    padding: 12px var(--mobile-page-padding) 10px !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(128, 143, 166, 0.18) !important;
    background: rgba(248, 250, 253, 0.94) !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    box-shadow: 0 16px 34px rgba(38, 54, 77, 0.08) !important;
  }

  .logo-area {
    padding: 0 !important;
    margin: 0 0 10px !important;
  }

  .logo {
    min-width: 0 !important;
    gap: 10px !important;
  }

  .logo-icon {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    border-radius: 14px !important;
    font-size: 13px !important;
  }

  .logo-title {
    font-size: 18px !important;
    line-height: 1.1 !important;
  }

  .logo-subtitle {
    max-width: 250px !important;
    font-size: 11px !important;
    line-height: 1.25 !important;
  }

  .mode-switcher {
    margin: 0 !important;
  }

  .mode-toggle {
    display: flex !important;
    gap: 8px !important;
    overflow-x: auto !important;
    padding: 2px 0 4px !important;
    scroll-snap-type: x proximity !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .mode-toggle::-webkit-scrollbar {
    display: none !important;
  }

  .mode-btn {
    flex: 0 0 auto !important;
    min-width: 126px !important;
    min-height: 44px !important;
    padding: 9px 12px !important;
    border-radius: 16px !important;
    scroll-snap-align: start !important;
  }

  .mode-btn-icon {
    width: 24px !important;
    height: 24px !important;
    min-width: 24px !important;
  }

  .mode-btn-label {
    font-size: 12px !important;
    line-height: 1.15 !important;
    white-space: normal !important;
  }

  .sidebar-actions,
  .sidebar-section {
    display: none !important;
  }

  #account-box.account-box {
    margin: 10px 0 0 !important;
    padding: 10px 12px !important;
    border-radius: 16px !important;
  }

  #account-box .account-title,
  #account-box .account-subtitle,
  #account-box .account-access {
    font-size: 12px !important;
  }

  #account-box .account-actions {
    gap: 8px !important;
  }

  #account-box .account-btn {
    min-height: 38px !important;
    border-radius: 13px !important;
    padding: 0 12px !important;
    font-size: 13px !important;
  }

  .main {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
    display: block !important;
  }

  .main-header {
    position: relative !important;
    display: block !important;
    padding: 16px var(--mobile-page-padding) 12px !important;
    border-radius: 0 !important;
  }

  .main-title {
    font-size: 21px !important;
    line-height: 1.18 !important;
    letter-spacing: -0.03em !important;
  }

  .main-subtitle {
    margin-top: 8px !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
  }

  .dataset-meta-line {
    margin-top: 12px !important;
    width: 100% !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    justify-content: flex-start !important;
  }

  .dataset-meta-item {
    min-height: 32px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
  }

  .dataset-meta-line[hidden] {
    display: none !important;
  }

  .mode-panel {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    display: none !important;
  }

  .mode-panel.active {
    display: block !important;
  }

  #mode-search,
  #mode-protocol,
  #mode-oa_check,
  #mode-account {
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
  }

  .identity-area,
  .conditions-area,
  .results-area,
  .protocol-check-shell,
  .oa-check-shell,
  .oa-compare-shell,
  .oa-sort-shell,
  .account-shell {
    width: calc(100% - var(--mobile-page-padding) * 2) !important;
    max-width: calc(100% - var(--mobile-page-padding) * 2) !important;
    margin: 12px var(--mobile-page-padding) !important;
    padding: 14px !important;
    border-radius: var(--mobile-radius) !important;
    overflow: visible !important;
  }

  .identity-header,
  .conditions-header,
  .results-header,
  .section-header,
  .compact-head,
  .oa-mode-header,
  .protocol-check-header {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
  }

  .identity-actions,
  .condition-actions,
  .results-actions,
  .results-toolbar,
  .search-export-actions,
  .protocol-check-actions,
  .oa-actions,
  .oa-sort-actions,
  .cabinet-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    justify-content: flex-start !important;
  }

  .identity-row,
  .condition-row,
  .condition-table,
  .identity-table,
  .protocol-table-wrapper,
  .oa-table-wrapper,
  .results-table-shell {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .identity-table table,
  .condition-table table {
    min-width: 720px !important;
  }

  .condition-row input,
  .identity-row input,
  .condition-row select,
  .identity-row select,
  textarea {
    min-height: 44px !important;
    font-size: 15px !important;
  }

  .action-bar {
    width: calc(100% - var(--mobile-page-padding) * 2) !important;
    max-width: calc(100% - var(--mobile-page-padding) * 2) !important;
    margin: 12px var(--mobile-page-padding) !important;
    padding: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
  }

  .action-bar button,
  .btn-search,
  .btn-secondary,
  .btn-outline,
  .search-export-btn,
  .results-view-btn {
    min-height: 46px !important;
    border-radius: 16px !important;
    font-size: 14px !important;
  }

  .btn-search {
    grid-column: 1 / -1 !important;
  }

  .results-summary {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .summary-card,
  .mini-stat-card {
    min-width: 0 !important;
    padding: 12px !important;
    border-radius: 18px !important;
  }

  #results-count,
  #search-stats {
    font-size: 13px !important;
  }

  .results-view-toggle {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 6px !important;
    padding: 5px !important;
    border-radius: 18px !important;
  }

  .results-view-btn {
    width: 100% !important;
  }

  .search-export-actions {
    width: 100% !important;
  }

  .search-export-btn {
    flex: 1 1 calc(50% - 4px) !important;
  }

  #results-grid.results-grid,
  .results-grid,
  .results-grid.results-grid-table-mode {
    width: 100% !important;
    max-width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    overflow: visible !important;
  }

  .lab-card {
    width: 100% !important;
    min-width: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    padding: 15px !important;
    border-radius: 22px !important;
  }

  .lab-card-top,
  .lab-card-top.compact-top {
    display: flex !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }

  .lab-name {
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    white-space: normal !important;
    font-size: 15px !important;
    line-height: 1.32 !important;
    letter-spacing: -0.01em !important;
  }


  .lab-name.fsa-lab-link {
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    white-space: normal !important;
  }

  .selected-lab-name.fsa-lab-link {
    display: inline-block !important;
    max-width: 100% !important;
  }

  .lab-status {
    flex: 0 0 auto !important;
    border-radius: 999px !important;
    font-size: 11px !important;
  }

  .lab-meta-line,
  .lab-location,
  .reasons-preview,
  .lab-tags {
    font-size: 12.5px !important;
    line-height: 1.45 !important;
  }

  .lab-tags {
    display: flex !important;
    gap: 6px !important;
    overflow-x: auto !important;
    padding-bottom: 2px !important;
  }

  .lab-tag {
    flex: 0 0 auto !important;
  }

  .lab-card-side,
  .lab-card-side.compact-side {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    align-items: stretch !important;
  }

  .lab-match,
  .lab-rows-count {
    width: 100% !important;
    margin: 0 !important;
    padding: 10px !important;
    border-radius: 16px !important;
    background: rgba(247, 249, 252, 0.9) !important;
  }

  .lab-card-actions {
    grid-column: 1 / -1 !important;
  }

  .btn-open {
    width: 100% !important;
    min-height: 44px !important;
    border-radius: 16px !important;
  }

  .results-table-shell {
    border-radius: 20px !important;
    border: 1px solid rgba(128, 143, 166, 0.18) !important;
  }

  .results-table {
    min-width: 1040px !important;
  }

  .results-table th,
  .results-table td {
    padding: 10px 12px !important;
    font-size: 12px !important;
  }

  .right-panel,
  .details-panel,
  #details-panel {
    display: none !important;
  }

  .suggest-list,
  .account-suggest-list {
    max-width: calc(100vw - 32px) !important;
    left: 0 !important;
    right: 0 !important;
    font-size: 14px !important;
  }

  .auth-card,
  .verify-email-card,
  .reset-card,
  .account-modal-card {
    width: calc(100vw - 28px) !important;
    max-width: calc(100vw - 28px) !important;
    border-radius: 26px !important;
    padding: 22px !important;
  }

  .auth-actions,
  .verify-email-actions,
  .reset-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .account-modal-panel,
  .account-modal-card {
    max-height: calc(100vh - 24px) !important;
    overflow-y: auto !important;
  }

  .account-modal-grid,
  .cabinet-grid,
  .account-lab-grid,
  .oa-grid,
  .oa-compare-grid,
  .oa-sort-grid,
  .protocol-check-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  .empty-card {
    padding: 18px !important;
    border-radius: 22px !important;
    font-size: 14px !important;
  }

  .source-note-page {
    margin: 16px var(--mobile-page-padding) 28px !important;
    font-size: 11px !important;
    line-height: 1.45 !important;
  }

  .mobile-back-to-search {
    position: fixed !important;
    right: 14px !important;
    bottom: 14px !important;
    z-index: 40 !important;
    min-height: 44px !important;
    padding: 0 14px !important;
    border: 1px solid rgba(128, 143, 166, 0.22) !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.94) !important;
    color: #26354d !important;
    box-shadow: 0 16px 36px rgba(38, 54, 77, 0.18) !important;
    backdrop-filter: blur(14px) !important;
    -webkit-backdrop-filter: blur(14px) !important;
    font-weight: 700 !important;
  }

  body:not(.mobile-has-results) .mobile-back-to-search {
    display: none !important;
  }
}

/* --------------------------------------------------------------------------
   Mobile fix v2: условия поиска на телефоне показываем карточками, не таблицей.
   На desktop ничего не меняется, потому что правила живут внутри max-width: 768px.
---------------------------------------------------------------------------- */
@media (max-width: 768px) {
  .conditions-area {
    overflow: visible !important;
  }

  .conditions-table-wrap,
  .conditions-table-wrap.compact-table-wrap {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: visible !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
  }

  .conditions-table,
  .conditions-table.compact-table,
  .conditions-table tbody,
  .conditions-table tr,
  .conditions-table td {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  .conditions-table {
    border-collapse: separate !important;
    border-spacing: 0 !important;
    table-layout: fixed !important;
  }

  .conditions-table thead {
    display: none !important;
  }

  .conditions-table tbody {
    display: grid !important;
    gap: 12px !important;
  }

  .conditions-table tbody tr {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: 10px !important;
    padding: 12px !important;
    border: 1px solid rgba(128, 143, 166, 0.18) !important;
    border-radius: 20px !important;
    background: rgba(255, 255, 255, 0.94) !important;
    box-shadow: 0 14px 28px rgba(38, 54, 77, 0.06) !important;
  }

  .conditions-table tbody tr:hover {
    background: rgba(255, 255, 255, 0.94) !important;
  }

  .conditions-table td {
    padding: 0 !important;
    border: 0 !important;
    vertical-align: top !important;
  }

  .conditions-table td::before {
    display: block !important;
    margin: 0 0 5px !important;
    font-size: 11px !important;
    line-height: 1.2 !important;
    font-weight: 700 !important;
    color: #718096 !important;
    letter-spacing: 0.01em !important;
  }

  .conditions-table td:nth-child(1) {
    grid-column: 1 / -1 !important;
    width: auto !important;
    text-align: left !important;
    color: #3b6fe0 !important;
    font-weight: 800 !important;
    font-size: 12px !important;
    padding: 0 0 2px !important;
  }

  .conditions-table td:nth-child(1)::before {
    display: inline !important;
    content: "Условие " !important;
    margin: 0 !important;
    color: #3b6fe0 !important;
    font-size: 12px !important;
  }

  .conditions-table td:nth-child(2),
  .conditions-table td:nth-child(3),
  .conditions-table td:nth-child(7) {
    grid-column: 1 / -1 !important;
  }

  .conditions-table td:nth-child(2)::before { content: "Методика / документ" !important; }
  .conditions-table td:nth-child(3)::before { content: "Показатель" !important; }
  .conditions-table td:nth-child(4)::before { content: "Ед. измерения" !important; }
  .conditions-table td:nth-child(5)::before { content: "От" !important; }
  .conditions-table td:nth-child(6)::before { content: "До" !important; }
  .conditions-table td:nth-child(7)::before { content: "Объект / продукция" !important; }
  .conditions-table td:nth-child(8)::before { content: "ОКПД2" !important; }
  .conditions-table td:nth-child(9)::before { content: "ТН ВЭД" !important; }
  .conditions-table td:nth-child(10)::before { content: "Важность" !important; }
  .conditions-table td:nth-child(11)::before { content: "Режим" !important; }

  .conditions-table td:nth-child(12) {
    grid-column: 1 / -1 !important;
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center !important;
    min-height: 0 !important;
  }

  .conditions-table td:nth-child(12)::before {
    content: "" !important;
    display: none !important;
  }

  .conditions-table td input,
  .conditions-table td select,
  .conditions-table.compact-table td input,
  .conditions-table.compact-table td select {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: 44px !important;
    min-height: 44px !important;
    padding: 0 12px !important;
    border: 1px solid rgba(128, 143, 166, 0.26) !important;
    border-radius: 14px !important;
    background-color: #ffffff !important;
    font-size: 15px !important;
    line-height: 44px !important;
    box-sizing: border-box !important;
  }

  .conditions-table td select {
    padding-right: 32px !important;
    line-height: normal !important;
  }

  .conditions-table td input:focus,
  .conditions-table td select:focus {
    border-color: rgba(59, 111, 224, 0.7) !important;
    box-shadow: 0 0 0 3px rgba(59, 111, 224, 0.10) !important;
    background-color: #ffffff !important;
  }

  .conditions-table td .input-wrap {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    position: relative !important;
  }

  .conditions-table .row-del {
    width: auto !important;
    min-width: 120px !important;
    height: 40px !important;
    padding: 0 14px !important;
    border-radius: 14px !important;
    opacity: 1 !important;
    background: rgba(231, 76, 60, 0.08) !important;
    color: #b42318 !important;
    font-size: 20px !important;
  }

  .floating-suggest-box {
    max-width: calc(100vw - 28px) !important;
  }
}

@media (max-width: 420px) {
  .conditions-table tbody tr {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .conditions-table td:nth-child(2),
  .conditions-table td:nth-child(3),
  .conditions-table td:nth-child(4),
  .conditions-table td:nth-child(5),
  .conditions-table td:nth-child(6),
  .conditions-table td:nth-child(7),
  .conditions-table td:nth-child(8),
  .conditions-table td:nth-child(9),
  .conditions-table td:nth-child(10) {
    grid-column: 1 / -1 !important;
  }
}


/* Priority conditions: mobile-friendly mandatory/optional selector */
@media (max-width: 768px) {
  .conditions-table td:nth-child(10),
  .conditions-table td:nth-child(11) {
    grid-column: 1 / -1 !important;
  }

  .conditions-table td:nth-child(12) {
    grid-column: 1 / -1 !important;
    display: flex !important;
    justify-content: flex-start !important;
  }
}

@media (max-width: 768px) {
  .selected-fsa-link {
    width: 100%;
    margin-top: 12px;
    padding: 11px 14px;
  }
}


/* --------------------------------------------------------------------------
   Desktop guard: кнопка «К поиску» нужна только на телефоне.
   На ПК она полностью скрыта, чтобы не занимать правую часть экрана.
---------------------------------------------------------------------------- */
.mobile-back-to-search {
  display: none !important;
}

@media (max-width: 768px) {
  body.mobile-has-results .mobile-back-to-search {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
  }

  body:not(.mobile-has-results) .mobile-back-to-search {
    display: none !important;
  }
}

@media (min-width: 769px) {
  .mobile-back-to-search,
  #mobile-back-to-search {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
}
