/* ================================================================
   mobile.css — Patch Mobile-First · Aba PEDIDOS
   PokeAlliance Shop

   ESTRATÉGIA:
   ─ Tudo dentro de @media (max-width: 768px)
   ─ Desktop não é tocado em nenhum momento
   ─ Não polui orders-ui.css / orders-kanban.css / style.css
   ─ Importado POR ÚLTIMO no index.html (após orders-kanban.css)
     para garantir precedência

   CLASSES ALTERADAS (resumo no final do arquivo)
================================================================ */

/* ================================================================
   1. TOPBAR DE PEDIDOS — layout vertical organizado
   ─ Afeta: .pedidos-topbar, .pedidos-topbar-left,
            .pedidos-topbar-right, .pedidos-search-wrap,
            #pedidos-status-filter, .pedidos-refresh-btn,
            .pedidos-my-filter-btn, .pedidos-titulo,
            .pedidos-count-badge
================================================================ */
@media (max-width: 768px) {

  /* Container principal vira coluna */
  .pedidos-page {
    padding: 12px 0 100px;
  }

  .pedidos-topbar {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    padding: 0 14px;
    margin-bottom: 14px;
  }

  /* Linha 1: título + badge */
  .pedidos-topbar-left {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: nowrap;
  }

  .pedidos-titulo {
    font-size: 18px;
    white-space: nowrap;
  }

  .pedidos-count-badge {
    font-size: 10px;
    padding: 2px 8px;
    flex-shrink: 0;
  }

  /* Linha 2: controles full-width em row */
  .pedidos-topbar-right {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 8px;
    width: 100%;
    flex-wrap: nowrap;
  }

  /* Botão "Meus pedidos" — ícone apenas, touch-friendly */
  .pedidos-my-filter-btn {
    min-width: 44px;
    min-height: 44px;
    padding: 0 12px;
    border-radius: 10px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    font-size: 11px;
    -webkit-tap-highlight-color: transparent;
  }

  /* Esconde o label de texto, mantém o ícone */
  .pedidos-my-filter-btn span:not(svg) {
    display: none;
  }

  /* Busca expande para preencher espaço disponível */
  .pedidos-search-wrap {
    flex: 1;
    min-width: 0;
    height: 44px;
    border-radius: 10px;
    padding: 0 12px;
    min-width: 0;
  }

  .pedidos-search-wrap input {
    font-size: 16px; /* Evita zoom automático no iOS */
    min-height: 44px;
  }

  /* Select de status — tamanho fixo, sem zoom */
  #pedidos-status-filter {
    height: 44px;
    font-size: 16px; /* Evita zoom automático no iOS */
    border-radius: 10px;
    padding: 0 8px;
    flex-shrink: 0;
    max-width: 100px;
    min-width: 80px;
    -webkit-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='rgba(255,255,255,0.4)' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 8px center;
    padding-right: 24px;
  }

  /* Botão refresh — touch-friendly */
  .pedidos-refresh-btn {
    width: 44px;
    height: 44px;
    min-width: 44px;
    border-radius: 10px;
    flex-shrink: 0;
    -webkit-tap-highlight-color: transparent;
  }
}

/* ================================================================
   2. TABS INTERNAS DE PEDIDOS (Fila / Histórico)
   ─ Afeta: .orders-tabs, .orders-tab, .orders-tab-badge
================================================================ */
@media (max-width: 768px) {

  .orders-tabs {
    display: flex;
    flex-direction: row;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    gap: 6px;
    padding: 0 14px 2px;
    margin-bottom: 12px;
    flex-wrap: nowrap;
  }

  .orders-tabs::-webkit-scrollbar {
    display: none;
  }

  .orders-tab {
    flex: 0 0 auto;
    min-height: 40px;
    padding: 8px 14px;
    font-size: 11px;
    white-space: nowrap;
    -webkit-tap-highlight-color: transparent;
  }
}

/* ================================================================
   3. LISTA DE PEDIDOS — container sem overflow lateral
   ─ Afeta: .pedidos-lista, #pedidos-lista
================================================================ */
@media (max-width: 768px) {

  .pedidos-lista {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 0 14px;
    /* Garante que nenhum filho quebre o body horizontalmente */
    overflow-x: hidden;
  }
}

/* ================================================================
   4. ORDER CARDS — width 100%, padding compacto, sem overflow
   ─ Afeta: .order-card, .order-card-header, .order-card-header-left,
            .order-card-header-right, .order-card-nick,
            .order-card-num, .order-card-time, .order-card-you-badge,
            .order-card-notif-dot, .order-status-badge,
            .order-queue-position, .order-queue-pos-num,
            .order-queue-pos-label
================================================================ */
@media (max-width: 768px) {

  .order-card {
    width: 100%;
    box-sizing: border-box;
    padding: 12px 14px;
    border-radius: 12px;
    /* Remove hover transform — causa jank em scroll */
    transform: none !important;
    -webkit-tap-highlight-color: transparent;
  }

  .order-card:active {
    transform: scale(0.98) !important;
    transition: transform 0.1s ease;
  }

  /* Header do card — permite quebra em duas linhas se necessário */
  .order-card-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 10px;
    margin-bottom: 10px;
  }

  .order-card-header-left {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-width: 0;
    overflow: hidden;
  }

  .order-card-header-right {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
    flex-wrap: wrap;
    justify-content: flex-end;
  }

  /* Nick do pedido — trunca com ellipsis */
  .order-card-nick {
    font-size: 13px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
    max-width: 140px;
  }

  .order-card-num {
    font-size: 11px;
    flex-shrink: 0;
    white-space: nowrap;
  }

  /* Hora — esconde se espaço apertado */
  .order-card-time {
    font-size: 10px;
    white-space: nowrap;
    flex-shrink: 0;
  }

  .order-card-you-badge {
    font-size: 8px;
    padding: 1px 5px;
    flex-shrink: 0;
  }

  /* Badge de notificação */
  .order-card-notif-dot {
    min-width: 18px;
    height: 18px;
    font-size: 10px;
    flex-shrink: 0;
  }

  /* Badge de status — compacto */
  .order-status-badge {
    font-size: 10px;
    padding: 3px 8px;
    white-space: nowrap;
    flex-shrink: 0;
  }

  /* Posição na fila — compacta */
  .order-queue-position {
    min-width: 36px;
    height: 36px;
    border-radius: 8px;
    flex-shrink: 0;
  }

  .order-queue-pos-num {
    font-size: 13px;
  }

  .order-queue-pos-label {
    font-size: 7px;
  }
}

/* ================================================================
   5. ETA BAR — layout column no mobile
   ─ Afeta: .order-eta-bar, .order-eta-queue, .order-eta-position,
            .order-eta-label
================================================================ */
@media (max-width: 768px) {

  .order-eta-bar {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 8px 10px;
    margin-bottom: 10px;
    border-radius: 8px;
    background: rgba(58,140,255,0.05);
    border: 1px solid rgba(58,140,255,0.12);
  }

  .order-eta-queue {
    gap: 6px;
    font-size: 12px;
  }

  /* Posição na fila: mantida mas compactada */
  .order-eta-position {
    font-size: 11px;
    color: rgba(255,255,255,0.4);
  }

  .order-eta-label {
    font-size: 12px;
  }
}

/* ================================================================
   6. PROGRESSO — compacto mas visível
   ─ Afeta: .order-progress-section, .order-progress-header,
            .order-progress-label, .order-progress-pct,
            .order-progress-bar, .order-progress-fill
================================================================ */
@media (max-width: 768px) {

  .order-progress-section {
    margin-bottom: 10px;
  }

  .order-progress-header {
    margin-bottom: 5px;
  }

  .order-progress-label {
    font-size: 9px;
    letter-spacing: 0.6px;
  }

  .order-progress-pct {
    font-size: 12px;
  }

  .order-progress-bar {
    height: 6px; /* Ligeiramente maior para visibilidade touch */
    border-radius: 3px;
  }
}

/* ================================================================
   7. ITENS DO PEDIDO — legíveis e compactos
   ─ Afeta: .order-items-section, .order-item, .order-item-info,
            .order-item-name, .order-item-progress,
            .order-item-bar-wrap, .order-item-bar, .order-item-qty
================================================================ */
@media (max-width: 768px) {

  .order-items-section {
    margin-bottom: 10px;
  }

  .order-item {
    padding: 6px 0;
  }

  .order-item-info {
    gap: 6px;
  }

  .order-item-name {
    font-size: 12px;
  }

  .order-item-progress {
    gap: 6px;
  }

  .order-item-bar-wrap {
    gap: 6px;
  }

  /* Barra de item — um pouco mais larga para leitura */
  .order-item-bar {
    width: 52px;
    height: 4px;
  }

  .order-item-qty {
    font-size: 10px;
    white-space: nowrap;
  }
}

/* ================================================================
   8. FOOTER DO CARD — botões empilhados, touch-friendly
   ─ Afeta: .order-card-footer, .order-card-footer-left,
            .order-card-footer-right, .order-card-admin-toggle,
            .order-card-hist-toggle, .order-card-cancel-btn
================================================================ */
@media (max-width: 768px) {

  .order-card-footer {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding-top: 10px;
    border-top: 1px solid rgba(255,255,255,0.05);
    margin-top: 10px;
  }

  .order-card-footer-left {
    display: flex;
    flex-direction: row;
    gap: 8px;
    flex-wrap: wrap;
  }

  .order-card-footer-right {
    display: flex;
    flex-direction: row;
    gap: 8px;
  }

  /* Botão Admin — touch-friendly */
  .order-card-admin-toggle {
    min-height: 36px;
    padding: 6px 12px;
    font-size: 11px;
    border-radius: 8px;
    -webkit-tap-highlight-color: transparent;
    flex: 1;
    justify-content: center;
  }

  /* Botão Histórico — touch-friendly */
  .order-card-hist-toggle {
    min-height: 36px;
    padding: 6px 12px;
    font-size: 11px;
    border-radius: 8px;
    -webkit-tap-highlight-color: transparent;
    flex: 1;
    justify-content: center;
  }

  /* Botão Cancelar — full width */
  .order-card-cancel-btn {
    min-height: 40px;
    padding: 8px 14px;
    font-size: 11px;
    border-radius: 8px;
    width: 100%;
    -webkit-tap-highlight-color: transparent;
    letter-spacing: 0.3px;
  }
}

/* ================================================================
   9. ADMIN PANEL (oa-panel) — stack vertical, inputs touch-friendly
   ─ Afeta: .oa-panel, .oa-actions, .oa-btn, .oa-btn--start,
            .oa-btn--complete, .oa-btn--cancel, .oa-btn--delete,
            .oa-service-grid, .oa-service-opt, .oa-qty-input,
            .oa-item-qty-input, .oa-obs-input, .oa-sla-row
================================================================ */
@media (max-width: 768px) {

  .oa-panel {
    padding: 12px;
    gap: 10px;
    border-radius: 10px;
  }

  /* SLA Info — texto legível */
  .oa-sla-row {
    font-size: 12px;
    flex-wrap: wrap;
    gap: 4px;
  }

  .oa-sla-label {
    color: rgba(255,255,255,0.5);
  }

  /* Service grid — coluna única no mobile */
  .oa-service-grid {
    grid-template-columns: 1fr !important;
    gap: 6px;
  }

  .oa-service-opt {
    min-height: 44px;
    padding: 10px 12px;
    font-size: 12px;
    -webkit-tap-highlight-color: transparent;
  }

  /* Quantidade — input maior */
  .oa-qty-input {
    width: 70px;
    height: 40px;
    font-size: 16px; /* Evita zoom iOS */
    padding: 6px 10px;
    border-radius: 8px;
  }

  /* Item qty inputs */
  .oa-item-qty-input {
    width: 56px;
    height: 36px;
    font-size: 16px; /* Evita zoom iOS */
    border-radius: 6px;
  }

  /* Obs textarea */
  .oa-obs-input {
    font-size: 16px; /* Evita zoom iOS */
    min-height: 72px;
    padding: 10px 12px;
    border-radius: 8px;
  }

  /* Ações admin — stack vertical com botões full width */
  .oa-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding-top: 10px;
  }

  .oa-btn {
    min-height: 44px;
    padding: 10px 16px;
    font-size: 12px;
    border-radius: 10px;
    width: 100%;
    justify-content: center;
    -webkit-tap-highlight-color: transparent;
  }

  /* Botão principal de ação: sempre full width */
  .oa-btn--start,
  .oa-btn--complete {
    flex: unset;
    width: 100%;
    font-size: 13px;
    min-height: 48px;
  }

  /* Botões secundários — lado a lado */
  .oa-btn--cancel,
  .oa-btn--delete {
    width: calc(50% - 4px);
    min-height: 40px;
    font-size: 11px;
  }

  /* Agrupa cancel + delete lado a lado */
  .oa-actions {
    flex-wrap: wrap;
    flex-direction: row;
  }

  .oa-btn--start,
  .oa-btn--complete {
    flex: 1 1 100%;
  }

  .oa-btn--cancel,
  .oa-btn--delete {
    flex: 1 1 calc(50% - 4px);
  }
}

/* ================================================================
   10. TIMELINE / HISTÓRICO — legível
   ─ Afeta: .order-timeline, .order-timeline-entry,
            .order-timeline-label, .order-timeline-meta
================================================================ */
@media (max-width: 768px) {

  .order-timeline {
    padding: 10px 0 4px;
    gap: 12px;
  }

  .order-timeline-entry {
    gap: 8px;
  }

  .order-timeline-label {
    font-size: 12px;
    line-height: 1.5;
  }

  .order-timeline-meta {
    font-size: 10px;
    gap: 6px;
    flex-wrap: wrap;
  }
}

/* ================================================================
   11. KANBAN — já tem @media 540px em orders-kanban.css
       Complementa com espaçamentos corretos no mobile
   ─ Afeta: #pedidos-kanban, .kb-card, .kb-card-actions,
            .kb-btn, .kb-view-toggle
================================================================ */
@media (max-width: 768px) {

  /* Container kanban — padding lateral */
  #pedidos-kanban {
    padding: 0 14px 100px;
    gap: 10px;
  }

  /* Cards kanban — touch-friendly */
  .kb-card {
    padding: 12px;
    border-radius: 10px;
    -webkit-tap-highlight-color: transparent;
  }

  .kb-card:active {
    transform: scale(0.98) !important;
    transition: transform 0.1s ease;
  }

  /* Ações do card kanban — stack vertical */
  .kb-card-actions {
    display: flex;
    flex-direction: column;
    gap: 6px;
  }

  .kb-btn {
    min-height: 40px;
    padding: 8px 12px;
    font-size: 11px;
    border-radius: 8px;
    -webkit-tap-highlight-color: transparent;
    justify-content: center;
    flex: unset;
    width: 100%;
  }

  .kb-btn--cancel {
    width: auto;
  }

  /* Toggle kanban/lista — acessível */
  .kb-view-toggle {
    min-height: 40px;
    padding: 8px 14px;
    font-size: 11px;
    -webkit-tap-highlight-color: transparent;
  }
}

/* ================================================================
   12. MODAL CAPTURA — padding correto, sem overflow, botão grande
   ─ Afeta: .captura-overlay, .captura-modal, .captura-modal-header,
            .captura-modal-title, .captura-modal-body,
            .captura-modal-price-block, qualquer botão dentro
================================================================ */
@media (max-width: 768px) {

  /* Overlay — bottom sheet */
  .captura-overlay {
    align-items: flex-end !important;
    padding: 0 !important;
  }

  .captura-modal {
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 20px 20px 0 0 !important;
    max-height: 88vh !important;
    overflow-y: auto;
    overflow-x: hidden;
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }

  .captura-modal-header {
    padding: 16px 18px 12px;
    position: sticky;
    top: 0;
    z-index: 2;
    background: inherit;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }

  .captura-modal-title {
    font-size: 16px;
    letter-spacing: 1.5px;
  }

  .captura-modal-body {
    padding: 14px 18px 20px;
  }

  /* Preço principal legível */
  .captura-modal-price-kk {
    font-size: 24px;
  }

  .captura-modal-price-brl {
    font-size: 14px;
  }

  /* Botão de adicionar ao carrinho — bem grande */
  .captura-modal-body .add-btn,
  .captura-modal .pkg-modal-add-btn,
  .captura-modal button[onclick*="addToCart"],
  .captura-modal button[onclick*="cart"],
  .captura-modal .captura-add-btn {
    min-height: 52px !important;
    font-size: 13px !important;
    border-radius: 12px !important;
    width: 100% !important;
    -webkit-tap-highlight-color: transparent;
  }
}

/* ================================================================
   13. TABS DE NAVEGAÇÃO PRINCIPAL — scroll horizontal suave
   (complemento ao mobile-patch.css que já existe)
   ─ Garante que as tabs de: itens, pacotes, captura, entregas,
     pedidos, wiki não fiquem cortadas
================================================================ */
@media (max-width: 768px) {

  /* Tabs nav — já está em mobile-patch.css mas reforça aqui */
  .tabs-nav {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch !important;
    flex-wrap: nowrap !important;
  }

  .tabs-nav::-webkit-scrollbar {
    display: none !important;
  }

  .tab-btn {
    flex: 0 0 auto !important;
    min-width: 44px !important;
    min-height: 44px !important;
    white-space: nowrap !important;
    -webkit-tap-highlight-color: transparent !important;
  }
}

/* ================================================================
   14. FILA / LISTA — overflow horizontal apenas quando necessário
   Previne que o body quebre sem bloquear scroll interno legítimo
================================================================ */
@media (max-width: 768px) {

  /* Wrapper da aba de pedidos — overflow interno controlado */
  #tab-pedidos {
    overflow-x: hidden;
    width: 100%;
    box-sizing: border-box;
  }

  /* Qualquer tabela dentro da área de pedidos pode scrollar horizontalmente
     de forma contida, sem vazar para o body */
  #tab-pedidos table,
  .pedidos-lista table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
  }
}

/* ================================================================
   15. INPUTS GLOBAIS NA ÁREA DE PEDIDOS — min 44px, sem zoom iOS
   ─ Afeta todos inputs/selects dentro de #tab-pedidos
================================================================ */
@media (max-width: 768px) {

  #tab-pedidos input[type="text"],
  #tab-pedidos input[type="number"],
  #tab-pedidos input[type="search"],
  #tab-pedidos select,
  #tab-pedidos textarea {
    font-size: 16px !important; /* 16px+ previne zoom automático no iOS */
  }

  #tab-pedidos input[type="text"],
  #tab-pedidos input[type="search"] {
    min-height: 44px;
  }

  #tab-pedidos select {
    min-height: 44px;
  }
}

/* ================================================================
   16. OBSERVAÇÕES DO PEDIDO — legível
   ─ Afeta: .order-obs
================================================================ */
@media (max-width: 768px) {

  .order-obs {
    font-size: 12px;
    padding: 8px 10px;
    border-radius: 8px;
    line-height: 1.5;
    margin-bottom: 8px;
  }
}

/* ================================================================
   17. NOTIF DOT (badge de mensagens não lidas)
================================================================ */
@media (max-width: 768px) {

  .order-card-notif-dot {
    font-size: 9px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
  }
}

/* ================================================================

   RESUMO DE CLASSES ALTERADAS
   ─────────────────────────────────────────────────────────────────
   TOPBAR / FILTROS:
     .pedidos-page, .pedidos-topbar, .pedidos-topbar-left,
     .pedidos-topbar-right, .pedidos-titulo, .pedidos-count-badge,
     .pedidos-my-filter-btn, .pedidos-search-wrap,
     #pedidos-status-filter, .pedidos-refresh-btn

   TABS INTERNAS:
     .orders-tabs, .orders-tab, .orders-tab-badge

   LISTA / CONTAINER:
     .pedidos-lista, #pedidos-lista, #tab-pedidos

   CARDS:
     .order-card, .order-card-header, .order-card-header-left,
     .order-card-header-right, .order-card-nick, .order-card-num,
     .order-card-time, .order-card-you-badge,
     .order-card-notif-dot, .order-status-badge,
     .order-queue-position, .order-queue-pos-num,
     .order-queue-pos-label

   ETA:
     .order-eta-bar, .order-eta-queue, .order-eta-position,
     .order-eta-label

   PROGRESSO:
     .order-progress-section, .order-progress-header,
     .order-progress-label, .order-progress-pct,
     .order-progress-bar, .order-progress-fill

   ITENS:
     .order-items-section, .order-item, .order-item-info,
     .order-item-name, .order-item-progress, .order-item-bar-wrap,
     .order-item-bar, .order-item-qty

   FOOTER:
     .order-card-footer, .order-card-footer-left,
     .order-card-footer-right, .order-card-admin-toggle,
     .order-card-hist-toggle, .order-card-cancel-btn

   ADMIN PANEL:
     .oa-panel, .oa-sla-row, .oa-service-grid, .oa-service-opt,
     .oa-qty-input, .oa-item-qty-input, .oa-obs-input,
     .oa-actions, .oa-btn, .oa-btn--start, .oa-btn--complete,
     .oa-btn--cancel, .oa-btn--delete

   TIMELINE:
     .order-timeline, .order-timeline-entry, .order-timeline-label,
     .order-timeline-meta

   KANBAN:
     #pedidos-kanban, .kb-card, .kb-card-actions, .kb-btn,
     .kb-view-toggle

   MODAL CAPTURA:
     .captura-overlay, .captura-modal, .captura-modal-header,
     .captura-modal-title, .captura-modal-body,
     .captura-modal-price-kk, .captura-modal-price-brl

   TABS NAV PRINCIPAL:
     .tabs-nav, .tab-btn

   CONTAINERS COM OVERFLOW FIX:
     #tab-pedidos         → overflow-x: hidden (contenção do container)
     .pedidos-lista        → overflow-x: hidden
     #pedidos-kanban       → padding lateral correto
     .captura-modal        → overflow-x: hidden, overflow-y: auto
     table dentro pedidos  → overflow-x: auto (scroll interno)

   GRIDS QUE VIRARAM COLUMN:
     .oa-service-grid    → grid-template-columns: 1fr (era 1fr 1fr)
     .oa-actions         → flex-wrap: row, filhos reorganizados
     .order-card-footer  → flex-direction: column
     .pedidos-topbar     → flex-direction: column

   SCROLL HORIZONTAL RESOLVIDO:
     .tabs-nav           → overflow-x: auto com scrollbar oculta
     .orders-tabs        → overflow-x: auto com scrollbar oculta
     Tabelas internas    → display:block + overflow-x:auto

   DESKTOP NÃO AFETADO:
     100% das regras estão dentro de @media (max-width: 768px)
     Nenhuma regra global foi adicionada ou modificada
     Nenhum !important é aplicado fora do bloco @media
     (exceto onde necessário para sobrepor inline styles do JS)

================================================================ */
