/* ── Общие правила для мобильных ─────────────────────────────────── */
/* Предотвращаем zoom на iOS при фокусе на input */
@media (max-width: 900px) {
  input, select, textarea {
    font-size: 16px !important;
  }
  body {
    overflow-x: hidden !important;
  }
  /* Минимальный touch target */
  button, .btn-primary, .btn-ghost, .btn-danger, .nav-item, .mobile-nav-item {
    min-height: 44px !important;
  }
  .modal {
    max-width: 95vw !important;
    width: 95vw !important;
  }
  /* Модалки — не выходить за viewport */
  .modal-overlay {
    padding: 8px !important;
  }
}

/* ── ВЕРТИКАЛЬНАЯ (portrait, max-width: 768px) ───────────────────── */
@media (max-width: 768px) and (orientation: portrait) {
  .sidebar { display: none !important; }
  .main-content { margin-left: 0 !important; }
  .topbar { padding: 0 12px !important; }
  .page-title { font-size: 15px !important; }
  .search-box { display: none !important; }
  .dashboard-body { padding: 10px 12px 70px !important; gap: 8px !important; }

  /* Dashboard — метрики 2x2 */
  .metrics-row, .metrics-grid { grid-template-columns: repeat(2,1fr) !important; gap: 8px !important; }
  /* Dashboard — канбан горизонтальный скролл */
  .kanban { overflow-x: auto !important; display: flex !important; gap: 8px !important; padding: 8px !important; }
  .k-col { min-width: 160px !important; flex-shrink: 0 !important; }
  /* Legacy kanban classes */
  .kanban-grid { overflow-x: auto !important; display: flex !important; gap: 8px !important; }
  .kanban-col { min-width: 160px !important; flex-shrink: 0 !important; }
  /* Панели в 1 колонку */
  .mid-grid, .bottom-grid, .form-row, .pros-cons, .criteria-grid { grid-template-columns: 1fr !important; }
  .full-panel, .panel, .panel-block { border-radius: 8px !important; }

  /* Pipeline — таблица с горизонтальным скроллом */
  .table-wrap { overflow-x: auto !important; }
  table { min-width: 500px !important; }
  /* Pipeline — поиск 100% ширины */
  .topbar-right { flex-wrap: wrap !important; gap: 6px !important; }
  .topbar-right > div[style*="width:450px"] { width: 100% !important; }

  /* Модалки */
  .modal { width: 96vw !important; max-width: 96vw !important; }
  .billing-grid, .pricing-grid, .int-grid { grid-template-columns: 1fr !important; }
  .usage-grid { grid-template-columns: 1fr !important; }

  /* Scoring — список слева во весь экран, детали выдвигаются */
  .scoring-shell { grid-template-columns: 1fr !important; height: auto !important; }
  .scoring-right { height: calc(100vh - 200px) !important; overflow-y: auto !important; }

  /* Bot settings — 1 колонка */
  #tab-bot > div[style*="grid-template-columns:1fr 1fr"],
  #tab-ai > div[style*="grid-template-columns:1fr 1fr"],
  #tab-preview > div[style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }

  /* Analytics — метрики 2x2 */
  .analytics-metrics { grid-template-columns: repeat(2,1fr) !important; }

  /* Profile — 1 колонка */
  .profile-grid { grid-template-columns: 1fr !important; }

  /* Диалоги — fullscreen чат */
  .dialog-shell { display: block !important; height: calc(100vh - 110px) !important; }
  .dialog-left { height: calc(100vh - 110px) !important; border-right: none !important; }
  .chat-area {
    display: none !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 58px !important;
    z-index: 999 !important;
    background: #050505 !important;
    flex-direction: column !important;
  }
  .chat-area.mobile-open {
    display: flex !important;
    bottom: 58px !important;
  }
  .mobile-back, .mobile-back-btn {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #f5c800 !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    font-family: 'Inter', sans-serif !important;
    padding: 0 !important;
    flex-shrink: 0 !important;
  }

  /* Мобильная навигация */
  .mobile-nav {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 9999 !important;
    background: #080808 !important;
    border-top: 1px solid rgba(255,255,255,0.08) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-around !important;
    padding: 6px 0 14px !important;
    height: 58px !important;
  }
  .mobile-nav-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 2px !important;
    color: rgba(255,255,255,0.4) !important;
    text-decoration: none !important;
    font-size: 9px !important;
    font-weight: 700 !important;
    font-family: 'Inter', sans-serif !important;
    padding: 2px 8px !important;
    min-height: 44px !important;
    justify-content: center !important;
  }
  .mobile-nav-item svg {
    width: 22px !important;
    height: 22px !important;
    stroke: rgba(255,255,255,0.4) !important;
    fill: none !important;
  }
  .mobile-nav-item.active { color: #f5c800 !important; }
  .mobile-nav-item.active svg { stroke: #f5c800 !important; }
}

/* ── ГОРИЗОНТАЛЬНАЯ (landscape, max-width: 900px) ────────────────── */
@media (max-width: 900px) and (orientation: landscape) {
  .sidebar {
    width: 52px !important;
    display: flex !important;
  }
  .main-content { margin-left: 52px !important; }
  .logo-text, .nav-item span, .nav-badge, .nav-section-label,
  .user-name, .user-role, .duck-txt, .ai-status-pill span {
    display: none !important;
  }
  .nav-item { justify-content: center !important; padding: 8px !important; }
  .sidebar-logo { justify-content: center !important; padding: 12px 8px !important; }
  .user-card { justify-content: center !important; }
  .duck-mascot { display: none !important; }
  .mobile-nav { display: none !important; }
}

/* ── Скрываем мобильную навигацию на десктопе ─────────────────────── */
@media (min-width: 769px) and (orientation: portrait),
       (min-width: 901px) {
  .mobile-nav { display: none !important; }
  .mobile-back, .mobile-back-btn { display: none !important; }
}
