/* DevisVox — Devis — Mobile */
@media (max-width: 768px) {

#devis-mobile-page {
  position: relative;
  --dv-accent:  #FF6B00; --dv-success: #10B981; --dv-warning: #F59E0B; --dv-danger: #DC2626;
  --dv-text: #0F172A; --dv-text2: #475569; --dv-text3: #94A3B8;
  --dv-border: #E2E8F0; --dv-border2: #CBD5E1; --dv-bg: #F9FAFB; --dv-bg2: #F1F5F9;
  --dv-r-sm: 14px; --dv-r-md: 18px; --dv-tr: .18s ease;
  display: flex; flex-direction: column; height: 100%;
  background: var(--dv-bg);
  font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Segoe UI', sans-serif;
  color: var(--dv-text);
  /* conteneur qui scrolle — iOS + Android détectent ce scroll pour cacher la barre URL */
  overflow-y: auto; overflow-x: hidden;
  touch-action: pan-y; overscroll-behavior-y: contain; -webkit-overflow-scrolling: touch;
  /* Force une couche GPU dédiée pour éviter les repaints intempestifs au scroll */
  will-change: transform;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
#devis-mobile-page::-webkit-scrollbar { display: none; }
#devis-mobile-page .dv-ph {
  position: relative;
  padding: 6px 6px 10px;
}
#devis-mobile-page .dv-ph::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: -14px;
  right: -14px;
  height: 1px;
  background: var(--dv-border);
}
#devis-mobile-page .dv-title { font-size: 21px; font-weight: 900; color: var(--dv-text); letter-spacing: -1px; line-height: 1.1; }
#devis-mobile-page .dv-filters { display: flex; gap: 6px; margin: 0 -14px; padding: 8px 8px 6px; }
#devis-mobile-page .dv-filter-btn { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 1px; padding: 4px 6px; border-radius: 12px; border: 1.5px solid var(--dv-border2); background: #fff; cursor: pointer; font-family: inherit; transition: background var(--dv-tr), border-color var(--dv-tr); -webkit-tap-highlight-color: transparent; }
#devis-mobile-page .dv-filter-btn.active { background: var(--dv-accent); border-color: var(--dv-accent); }
#devis-mobile-page .dv-filter-btn.active .dv-fn,
#devis-mobile-page .dv-filter-btn.active .dv-fv { color: #fff; }
#devis-mobile-page .dv-fn { font-size: 9px; font-weight: 700; color: var(--dv-text3); text-transform: uppercase; letter-spacing: .05em; line-height: 1; display: block; }
#devis-mobile-page .dv-fv { font-size: 11px; font-weight: 700; color: var(--dv-text2); line-height: 1; white-space: nowrap; }
#devis-mobile-page .dv-fchev { font-size: 9px; }
/* ── Bottom sheet filtres — position:fixed pour ne pas décaler quand la page a scrollé ── */
#devis-mobile-page .dv-filter-sheet { position: fixed; inset: 0; z-index: 50; }
#devis-mobile-page .dv-fs-backdrop  { position: absolute; inset: 0; background: rgba(15,23,42,.35); }
#devis-mobile-page .dv-fs-panel     { position: absolute; bottom: 0; left: 0; right: 0; background: #fff; border-radius: 20px 20px 0 0; padding: 8px 16px 28px; display: flex; flex-direction: column; gap: 0; animation: dv-sheet-in .22s ease; max-height: 90svh; overflow-y: auto; }
@keyframes dv-sheet-in { from { transform: translateY(40px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
#devis-mobile-page .dv-fs-handle    { width: 36px; height: 4px; background: var(--dv-border2); border-radius: 2px; margin: 8px auto 12px; }
#devis-mobile-page .dv-fs-title     { font-size: 11px; font-weight: 700; color: var(--dv-text3); text-transform: uppercase; letter-spacing: .06em; padding: 0 4px 10px; border-bottom: 1px solid var(--dv-border); margin-bottom: 4px; }
#devis-mobile-page .dv-fs-opt       { height: 44px; border: none; background: none; text-align: left; font-size: 15px; font-weight: 500; color: var(--dv-text); cursor: pointer; padding: 0 8px; border-radius: 10px; font-family: inherit; transition: background var(--dv-tr); }
#devis-mobile-page .dv-fs-opt:active { background: var(--dv-bg2); }
#devis-mobile-page .dv-fs-opt.dv-fs-selected { font-weight: 700; color: var(--dv-accent); }
#devis-mobile-page .dv-body { flex: 1; padding: 0 14px calc(var(--bottom-nav-height, 70px) + 16px); } /* padding-bottom dégage la barre de nav fixe */
#devis-mobile-page .dv-search-row { position: sticky; top: 0; z-index: 10; background: var(--dv-bg); padding: 12px 0 8px; margin-bottom: 4px; }
#devis-mobile-page .dv-sw { display: flex; align-items: center; gap: 8px; background: #fff; border: 1.5px solid var(--dv-border); border-radius: 12px; padding: 0 12px; height: 44px; }
#devis-mobile-page .dv-search-input { flex: 1; border: none; background: transparent; font-size: 14px; color: var(--dv-text); outline: none; font-family: inherit; }
#devis-mobile-page .dv-sw-mic { background: none; border: none; cursor: pointer; padding: 4px; color: var(--dv-text3); flex-shrink: 0; }
#devis-mobile-page .dv-sw-mic svg { width: 18px; height: 18px; stroke: currentColor; stroke-width: 1.8; fill: none; stroke-linecap: round; }
#devis-mobile-page .dv-sw.listening { border-color: var(--dv-accent); box-shadow: 0 0 0 3px rgba(255,107,0,.16); }
#devis-mobile-page .dv-voice-status { display: flex; align-items: center; gap: 8px; margin-top: 8px; padding: 8px 12px; background: rgba(255,107,0,.07); border-radius: 10px; }
#devis-mobile-page .dv-voice-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--dv-accent); animation: dv-pulse 1s ease-in-out infinite; }
#devis-mobile-page .dv-voice-txt { font-size: 12px; color: var(--dv-accent); font-weight: 600; }
@keyframes dv-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.3)} }
#devis-mobile-page .dv-list { display: flex; flex-direction: column; gap: 0; }
#devis-mobile-page .dv-row { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; border-bottom: 1px solid var(--dv-border); cursor: pointer; gap: 12px; transition: background var(--dv-tr); }
#devis-mobile-page .dv-row:last-child { border-bottom: none; }
#devis-mobile-page .dv-row:active { background: var(--dv-bg2); border-radius: 10px; }
#devis-mobile-page .dv-row-left  { display: flex; flex-direction: column; gap: 3px; flex: 1; min-width: 0; }
#devis-mobile-page .dv-num    { font-size: 11px; font-weight: 700; color: var(--dv-text3); }
#devis-mobile-page .dv-client { font-size: 15px; font-weight: 700; color: var(--dv-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#devis-mobile-page .dv-desc   { font-size: 12px; color: var(--dv-text2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
#devis-mobile-page .dv-row-right { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; flex-shrink: 0; }
#devis-mobile-page .dv-amount { font-size: 15px; font-weight: 800; color: var(--dv-text); }
#devis-mobile-page .dv-date   { font-size: 11px; color: var(--dv-text3); }
#devis-mobile-page .dv-badge  { font-size: 10px; font-weight: 700; padding: 3px 8px; border-radius: 20px; }
#devis-mobile-page .dv-ok { background: #DCFCE7; color: #166534; }
#devis-mobile-page .dv-wa { background: #FEF9C3; color: #854D0E; }
#devis-mobile-page .dv-er { background: #FEE2E2; color: #991B1B; }
#devis-mobile-page .dv-empty-msg { text-align: center; color: var(--dv-text3); font-size: 14px; line-height: 1.6; padding: 48px 24px; }

/* ── Chips filtre statut ── */
#devis-mobile-page .dv-status-chips {
  display: flex; gap: 7px; overflow-x: auto;
  padding: 6px 8px 4px; margin: 0 -14px;
  scrollbar-width: none; -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
}
#devis-mobile-page .dv-status-chips::-webkit-scrollbar { display: none; }
#devis-mobile-page .dv-sch {
  padding: 6px 14px; border-radius: 20px; flex-shrink: 0;
  border: 1.5px solid #E2E8F0;
  background: #fff; font-size: 13px; font-weight: 600;
  color: var(--dv-text2); cursor: pointer; font-family: inherit;
  white-space: nowrap;
  transition: background var(--dv-tr), border-color var(--dv-tr), color var(--dv-tr);
  -webkit-tap-highlight-color: transparent;
}
#devis-mobile-page .dv-sch-on { background: #FF6B00; border-color: #FF6B00; color: #fff; }

}
