/* DevisVox — Factures — Mobile */
#p-factures{display:none;flex-direction:column;min-height:100%}
#p-factures.active{display:flex}
.lr-swipe{position:relative;overflow:hidden}
.lr-swipe-acts{position:absolute;right:0;top:0;bottom:0;display:flex;align-items:stretch;transform:translateX(100%);transition:transform .22s ease}
.lr-swipe.open .lr-swipe-acts{transform:translateX(0)}
.lr-swipe-act{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:0 18px;font-size:11px;font-weight:700;cursor:pointer;border:none;color:#fff;min-width:64px}
.lr-swipe-act.edit{background:var(--info-tx)}
.lr-swipe-act.send{background:var(--ok)}
.lr-swipe-act.del{background:var(--er)}
.lr-swipe-act svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2}
.period-dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:160px;background:var(--card);border-radius:var(--r);box-shadow:var(--sh2);border:1px solid var(--b2);z-index:200;overflow:hidden}
.period-opt{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;font-size:14px;font-weight:600;color:var(--text);cursor:pointer;border:none;background:transparent;font-family:inherit;width:100%;border-bottom:1px solid var(--b);transition:background .13s}
.period-opt:last-child{border-bottom:none}
.period-opt.on{color:var(--accent)}
.period-opt:active{background:var(--b)}
.fpill{display:inline-flex;align-items:center;justify-content:center;padding:6px 13px;border-radius:99px;font-size:13px;font-weight:600;color:var(--text2);background:var(--b);border:none;cursor:pointer;font-family:inherit;transition:background var(--tr),color var(--tr);white-space:nowrap}
.fpill.on{background:var(--accent);color:#fff}
.fpill:active{background:var(--b2)}

/* ── FACTURES MOBILE PAGE ─────────────────────────── */
#factures-mobile-page{display:flex;flex-direction:column;height:calc(100dvh - var(--bottom-nav-height,56px));overflow:hidden;background:var(--bg)}
#factures-mobile-page .fac-body{display:flex;flex-direction:column;flex:1;overflow:hidden}
#factures-mobile-page .fac-ph{padding:20px 20px 10px;padding-top:max(20px,env(safe-area-inset-top,0px));flex-shrink:0}
#factures-mobile-page .fac-title{font-size:28px;font-weight:900;color:var(--text);letter-spacing:-.5px;line-height:1.1}
#factures-mobile-page .fac-search-row{padding:0 16px 10px;flex-shrink:0}
#factures-mobile-page .fac-sw{display:flex;align-items:center;gap:8px;background:var(--card);border:1.5px solid var(--b2);border-radius:var(--r);padding:0 12px;height:44px;transition:border-color var(--tr)}
#factures-mobile-page .fac-sw:focus-within{border-color:var(--accent)}
#factures-mobile-page .fac-sw>svg{width:16px;height:16px;stroke:var(--text3);stroke-width:2;fill:none;flex-shrink:0;stroke-linecap:round;stroke-linejoin:round}
#factures-mobile-page .fac-search-input{flex:1;border:none;background:transparent;outline:none;font-size:14px;color:var(--text);font-family:inherit;min-height:unset;min-width:unset}
#factures-mobile-page .fac-search-input::placeholder{color:var(--text3)}
#factures-mobile-page .fac-filters{display:flex;gap:8px;padding:0 16px 12px;flex-shrink:0}
#factures-mobile-page .fac-filter-btn{flex:1 1 auto;padding:7px 6px;border-radius:99px;border:1.5px solid var(--b2);background:var(--card);font-size:11px;font-weight:600;color:var(--text2);cursor:pointer;font-family:inherit;white-space:nowrap;text-align:center;min-height:unset;min-width:0;overflow:hidden;text-overflow:ellipsis;transition:background var(--tr),border-color var(--tr),color var(--tr)}
#factures-mobile-page .fac-filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
#factures-mobile-page .fac-list{flex:1;overflow-y:auto;display:flex;flex-direction:column}
#factures-mobile-page .fac-list::-webkit-scrollbar{display:none}
#factures-mobile-page .fac-row{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--b);cursor:pointer;gap:12px;min-height:unset;transition:background var(--tr);background:var(--card)}
#factures-mobile-page .fac-row:last-child{border-bottom:none}
#factures-mobile-page .fac-row:active{background:var(--b)}
#factures-mobile-page .fac-row-left{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}
#factures-mobile-page .fac-num{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;min-height:unset;min-width:unset}
#factures-mobile-page .fac-client{font-size:15px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#factures-mobile-page .fac-desc{font-size:12px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#factures-mobile-page .fac-row-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}
#factures-mobile-page .fac-amount{font-size:15px;font-weight:800;color:var(--text)}
#factures-mobile-page .fac-date{font-size:11px;color:var(--text3)}
#factures-mobile-page .fac-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;min-height:unset;min-width:unset}
#factures-mobile-page .fac-ok{background:var(--ok-bg);color:var(--ok-tx)}
#factures-mobile-page .fac-wa{background:rgba(255,107,0,.1);color:var(--accent)}
#factures-mobile-page .fac-er{background:var(--er-bg);color:var(--er-tx)}
#factures-mobile-page .fac-draft{background:rgba(120,120,128,.1);color:var(--text3)}
#factures-mobile-page .fac-sent{background:rgba(59,130,246,.12);color:#3b82f6}
#factures-mobile-page .fac-empty-msg{text-align:center;padding:48px 20px;font-size:14px;color:var(--text3)}

/* ── MODAL RAPPORT INTERVENTION MOBILE ──────────────── */
.ri-sheet{position:relative;z-index:1;background:var(--card);border-radius:24px 24px 0 0;width:100%;max-width:600px;max-height:92dvh;display:flex;flex-direction:column;overflow:hidden}
.ri-handle{width:40px;height:4px;background:var(--b2);border-radius:2px;margin:12px auto 8px;flex-shrink:0}
.ri-head{padding:4px 20px 14px;border-bottom:1px solid var(--b);flex-shrink:0}
.ri-title{font-size:18px;font-weight:800;color:var(--text);margin:0 0 2px}
.ri-sub{font-size:12px;color:var(--text3);font-weight:600;margin:0;text-transform:uppercase;letter-spacing:.04em}
.ri-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:14px}
.ri-body::-webkit-scrollbar{display:none}
.ri-field{display:flex;flex-direction:column;gap:5px}
.ri-label{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.05em}
.ri-input{height:46px;border:1.5px solid var(--b2);border-radius:10px;padding:0 14px;font-size:15px;color:var(--text);background:var(--card);font-family:inherit;outline:none;width:100%;box-sizing:border-box;transition:border-color .15s}
.ri-input:focus{border-color:var(--accent)}
.ri-textarea{border:1.5px solid var(--b2);border-radius:10px;padding:12px 14px;font-size:14px;color:var(--text);background:var(--card);font-family:inherit;outline:none;width:100%;box-sizing:border-box;resize:none;line-height:1.5;transition:border-color .15s}
.ri-textarea:focus{border-color:var(--accent)}
.ri-footer{display:flex;gap:10px;padding:14px 20px 36px;flex-shrink:0;border-top:1px solid var(--b)}
.ri-btn-cancel{flex:1;height:52px;border-radius:14px;border:1.5px solid var(--b2);background:transparent;color:var(--text);font-size:15px;font-weight:700;cursor:pointer;font-family:inherit}
.ri-btn-ok{flex:1;height:52px;border-radius:14px;border:none;background:linear-gradient(135deg,#ff9500,#ff6b00);color:#fff;font-size:15px;font-weight:800;cursor:pointer;font-family:inherit;box-shadow:0 4px 14px rgba(255,107,0,.28)}
.ri-btn-cancel:active{opacity:.8}
.ri-btn-ok:active{opacity:.88;transform:scale(.98)}

/* ── EMAIL FACTURE FULLSCREEN ─────────────────────── */
#fac-email-fs{position:fixed;inset:0;z-index:9996;background:var(--bg);display:flex;flex-direction:column;transform:translateY(100%);transition:transform .35s ease-out;will-change:transform}
#fac-email-fs.dv-email-fs-open{transform:translateY(0)}
#fac-email-fs.dv-removing{animation:dvSlideDown .35s ease-in forwards!important;transition:none!important}
.dvem-attach-badge-rapport{background:rgba(124,58,237,.12);color:#7c3aed}

/* ── RAPPORT INTERVENTION FULLSCREEN ─────────────── */
#ri-fs, .ri-fs{position:fixed;inset:0;z-index:9996;background:var(--bg);display:flex;flex-direction:column;transform:translateY(100%);transition:transform .35s ease-out;will-change:transform}
#ri-fs.ri-fs-open, .ri-fs.ri-fs-open{transform:translateY(0)}
#ri-fs.dv-removing, .ri-fs.dv-removing{animation:dvSlideDown .35s ease-in forwards!important;transition:none!important}
.ri-fs-header{display:flex;align-items:center;gap:12px;padding:calc(env(safe-area-inset-top,0px) + 14px) 16px 14px;border-bottom:1px solid var(--b);flex-shrink:0;background:var(--card)}
.ri-fs-back{width:36px;height:36px;border:none;background:var(--b);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;color:var(--text)}
.ri-fs-header-text{display:flex;flex-direction:column;gap:1px;min-width:0}
.ri-fs-title{font-size:16px;font-weight:800;color:var(--text)}
.ri-fs-sub{font-size:12px;color:var(--text3);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ri-fs-body{flex:1;overflow-y:auto;padding:16px 20px 20px;display:flex;flex-direction:column;gap:14px}
.ri-fs-body::-webkit-scrollbar{display:none}
.ri-section-lbl{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:-6px}
.ri-row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ri-fs-footer{padding:12px 16px calc(env(safe-area-inset-bottom,0px) + 12px);background:var(--card);border-top:1px solid var(--b);flex-shrink:0}
.ri-fs-btn-save{width:100%;height:52px;border:none;border-radius:14px;background:#16a34a;color:#fff;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px}
.ri-fs-btn-save:active{opacity:.88;transform:scale(.98)}

/* ── Modal « Mode de paiement » (#modal-paiement-validation) — aligné design system ── */
#modal-paiement-validation .modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 0;margin-bottom:6px}
#modal-paiement-validation .modal-header h3{margin:0;font-size:17px;font-weight:800;color:var(--text)}
#modal-paiement-validation .btn-close-modal{background:none;border:none;font-size:18px;color:var(--text2);cursor:pointer;line-height:1;padding:4px}
#modal-paiement-validation .modal-body{padding:20px}
#modal-paiement-validation .mp-label{font-size:13px;color:var(--text2);margin-bottom:12px}
#modal-paiement-validation .mp-choices{display:flex;flex-wrap:wrap;gap:10px}
#modal-paiement-validation .mp-choice-btn{border:1.5px solid var(--b2);border-radius:20px;padding:8px 16px;background:var(--card);color:var(--text);font-size:14px;font-family:inherit;cursor:pointer;transition:var(--tr)}
#modal-paiement-validation .mp-choice-btn:active{transform:scale(.97)}
#modal-paiement-validation .mp-choice-btn.mp-active{background:var(--accent);color:#fff;border-color:var(--accent)}
#modal-paiement-validation .mp-error{color:var(--er);font-size:12px;margin-top:8px}
#modal-paiement-validation .modal-actions{display:flex;flex-direction:column;gap:10px;padding:0 18px calc(env(safe-area-inset-bottom,0px) + 16px)}
#modal-paiement-validation .modal-actions button{width:100%}

/* ── Modal signature rapport (#ri-sig-fs) — plein écran en paysage ── */
@media (orientation:landscape) {
  #ri-sig-fs .ri-fs-header { display:none !important; }
  #ri-sig-fs .ri-fs-footer { display:none !important; }
  #ri-sig-fs .ri-fs-body { flex:1; overflow-y:auto; padding: 8px 20px 0; gap: 6px; align-items: center; justify-content: center; }
  #ri-sig-fs .ri-fs-body .ri-label,
  #ri-sig-fs #ri-sig-texte { display:none !important; }
  #ri-sig-fs #ri-sig-canvas-modal {
    height: calc(100dvh - 35px) !important;
    width: 100% !important;
  }
}
