﻿/* DevisVox — Devis — Mobile */
#p-devis{display:none;flex-direction:column;min-height:100%}
#p-devis.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)}
.frow-devis{display:flex;gap:6px;align-items:center;flex-wrap:nowrap}

/* ── DEVIS MOBILE PAGE ────────────────────────────── */
#devis-mobile-page{display:flex;flex-direction:column;height:calc(100dvh - var(--bottom-nav-height,56px));overflow:hidden;background:var(--bg)}
#devis-mobile-page .dv-body{display:flex;flex-direction:column;flex:1;overflow:hidden}
#devis-mobile-page .dv-ph{padding:20px 20px 10px;padding-top:max(20px,env(safe-area-inset-top,0px));flex-shrink:0}
#devis-mobile-page .dv-title{font-size:28px;font-weight:900;color:var(--text);letter-spacing:-.5px;line-height:1.1}
#devis-mobile-page .dv-search-row{padding:0 16px 10px;flex-shrink:0}
#devis-mobile-page .dv-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)}
#devis-mobile-page .dv-sw:focus-within{border-color:var(--accent)}
#devis-mobile-page .dv-sw>svg{width:16px;height:16px;stroke:var(--text3);stroke-width:2;fill:none;flex-shrink:0;stroke-linecap:round;stroke-linejoin:round}
#devis-mobile-page .dv-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}
#devis-mobile-page .dv-search-input::placeholder{color:var(--text3)}
#devis-mobile-page .dv-sw-mic{width:32px;height:32px;min-height:unset;min-width:unset;border-radius:8px;background:transparent;border:none;display:flex;align-items:center;justify-content:center;color:var(--text3);flex-shrink:0;cursor:pointer;padding:0}
#devis-mobile-page .dv-sw-mic svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round}
#devis-mobile-page .dv-sw-mic:active{background:var(--accent-wash);color:var(--accent)}
#devis-mobile-page .dv-filters{display:flex;gap:8px;padding:0 16px 12px;flex-shrink:0}
#devis-mobile-page .dv-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)}
#devis-mobile-page .dv-filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
#devis-mobile-page .dv-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:5px;padding:4px 0}
#devis-mobile-page .dv-list::-webkit-scrollbar{display:none}
#devis-mobile-page .dv-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)}
#devis-mobile-page .dv-row:last-child{border-bottom:none}
#devis-mobile-page .dv-row:active{background:var(--b)}
#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(--text3);text-transform:uppercase;letter-spacing:.04em;min-height:unset;min-width:unset}
#devis-mobile-page .dv-client{font-size:15px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#devis-mobile-page .dv-desc{font-size:12px;color:var(--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(--text)}
#devis-mobile-page .dv-date{font-size:11px;color:var(--text3)}
#devis-mobile-page .dv-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;min-height:unset;min-width:unset}
#devis-mobile-page .dv-ok{background:var(--ok-bg);color:var(--ok-tx)}
#devis-mobile-page .dv-wa{background:rgba(255,107,0,.1);color:var(--accent)}
#devis-mobile-page .dv-er{background:var(--er-bg);color:var(--er-tx)}
#devis-mobile-page .dv-draft{background:rgba(255,107,0,.1);color:var(--accent)}
#devis-mobile-page .dv-sent{background:rgba(59,130,246,.12);color:#3b82f6}
#devis-mobile-page .dv-empty-msg{text-align:center;padding:48px 20px;font-size:14px;color:var(--text3)}

/* ── VIEWER PDF MOBILE — styles dans base.css ─────── */

/* ── MODAL EMAIL DEVIS ────────────────────────────── */
.em-sheet{position:relative;z-index:1;background:var(--card);border-radius:24px 24px 0 0;width:100%;max-width:480px;display:flex;flex-direction:column;max-height:92dvh;overflow:hidden;box-shadow:0 -8px 40px rgba(0,0,0,.18)}
.em-handle{width:40px;height:4px;border-radius:2px;background:var(--b2);margin:12px auto 0;flex-shrink:0}
.em-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--b);flex-shrink:0}
.em-title{font-size:17px;font-weight:700;color:var(--text)}
.em-num{font-size:13px;font-weight:600;color:var(--text3)}
.em-body{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:16px}
.em-field-group{display:flex;flex-direction:column;gap:6px}
.em-label{font-size:11px;font-weight:700;color:var(--text3);letter-spacing:.06em;text-transform:uppercase}
.em-input{width:100%;height:44px;border:1.5px solid var(--b2);border-radius:10px;padding:0 12px;font-size:15px;color:var(--text);background:var(--bg);font-family:inherit;outline:none;box-sizing:border-box;transition:border-color .15s}
.em-input:focus{border-color:var(--accent)}
.em-textarea{width:100%;border:1.5px solid var(--b2);border-radius:10px;padding:10px 12px;font-size:14px;color:var(--text);background:var(--bg);font-family:inherit;outline:none;resize:none;box-sizing:border-box;transition:border-color .15s;line-height:1.5}
.em-textarea:focus{border-color:var(--accent)}
.em-attach{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--b);border-radius:10px;font-size:13px;font-weight:600;color:var(--text2)}
.em-attach svg{flex-shrink:0;stroke:var(--text3)}
.em-footer{display:flex;gap:10px;padding:14px 20px 32px;border-top:1px solid var(--b);flex-shrink:0}
.em-btn-cancel{flex:1;height:48px;border:1.5px solid var(--b2);border-radius:12px;background:transparent;font-size:15px;font-weight:600;color:var(--text2);cursor:pointer;font-family:inherit}
.em-btn-send{flex:2;height:48px;border:none;border-radius:12px;background:var(--accent);font-size:15px;font-weight:700;color:#fff;cursor:pointer;font-family:inherit}
.em-btn-send:active{opacity:.85}
.em-btn-cancel:active{background:var(--b)}

/* ── FULLSCREEN EMAIL DEVIS ──────────────────────── */
#dv-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}
#dv-email-fs.dv-email-fs-open{transform:translateY(0)}
#dv-email-fs.dv-removing{animation:dvSlideDown .35s ease-in forwards!important;transition:none!important}
.dvem-header{display:flex;align-items:center;gap:12px;padding:calc(env(safe-area-inset-top,0px) + 14px) 16px 14px;background:var(--card);border-bottom:1px solid var(--b);flex-shrink:0}
.dvem-back{width:36px;height:36px;border:none;background:var(--b);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);flex-shrink:0;padding:0}
.dvem-header-text{flex:1;text-align:center;margin-right:36px}
.dvem-title{display:block;font-size:16px;font-weight:700;color:var(--text)}
.dvem-subtitle{display:block;font-size:12px;color:var(--text3);margin-top:2px}
.dvem-body{flex:1;overflow-y:auto;padding:20px 20px 4px;display:flex;flex-direction:column;gap:14px}
.dvem-section-lbl{font-size:11px;font-weight:700;color:var(--text3);letter-spacing:.06em;text-transform:uppercase;margin:0}
.dvem-row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dvem-attachments{display:flex;flex-direction:column;gap:8px}
.dvem-attach-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--b);border-radius:10px}
.dvem-attach-badge{font-size:10px;font-weight:800;background:#e53935;color:#fff;padding:2px 7px;border-radius:4px;letter-spacing:.04em;flex-shrink:0}
.dvem-attach-name{font-size:13px;font-weight:600;color:var(--text2)}
.dvem-footer{display:flex;gap:10px;padding:14px 20px calc(env(safe-area-inset-bottom,0px) + 20px);border-top:1px solid var(--b);background:var(--card);flex-shrink:0}
.dvem-btn-cancel{flex:1;height:48px;border:1.5px solid var(--b2);border-radius:12px;background:transparent;font-size:15px;font-weight:600;color:var(--text2);cursor:pointer;font-family:inherit}
.dvem-btn-cancel:active{background:var(--b)}
.dvem-btn-send{flex:2;height:48px;border:none;border-radius:12px;background:#16a34a;font-size:15px;font-weight:700;color:#fff;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px}
.dvem-btn-send:active{opacity:.85}

/* ── MODAL SUCCÈS SIGNATURE ───────────────────────── */
#modal-succes-signature.modal{align-items:center;justify-content:center}
.ssc-card{position:relative;z-index:1;background:var(--card);border-radius:16px;width:calc(100% - 48px);max-width:340px;padding:28px 20px 24px;display:flex;flex-direction:column;align-items:center;gap:10px;box-shadow:0 8px 40px rgba(0,0,0,.18);text-align:center}
.ssc-icon{width:52px;height:52px;border-radius:50%;background:var(--ok-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:4px}
.ssc-title{font-size:18px;font-weight:800;color:var(--text);margin:0}
.ssc-num{font-size:15px;font-weight:700;color:var(--accent);margin:0}
.ssc-body{font-size:14px;color:var(--text2);margin:0}
.ssc-meta{font-size:13px;color:var(--text3);line-height:1.6;margin:0}
.ssc-btn{width:100%;height:52px;border:none;border-radius:14px;background:var(--accent);color:#fff;font-size:16px;font-weight:800;cursor:pointer;font-family:inherit;margin-top:8px}
.ssc-btn:active{opacity:.88}

/* ── MODAL SIGNATURE ──────────────────────────────── */
#signature-modal{position:fixed!important;inset:0!important;z-index:9990!important;display:flex!important;align-items:center!important;justify-content:center!important;background:rgba(0,0,0,.5)!important}
#signature-modal.hidden{display:none!important}
#signature-modal .modal-overlay{display:none}
.sg-sheet{position:relative;z-index:1;background:var(--card);border-radius:16px;width:calc(100% - 32px);max-width:400px;padding:0 0 20px;box-shadow:0 8px 40px rgba(0,0,0,.22);display:flex;flex-direction:column;overflow:hidden}
.sg-handle{width:40px;height:4px;border-radius:2px;background:var(--b2);margin:12px auto 8px;flex-shrink:0}
.sg-head{display:flex;align-items:center;justify-content:space-between;padding:8px 16px 0 20px;flex-shrink:0}
.sg-title{font-size:17px;font-weight:700;color:var(--text)}
.sg-close{width:32px;height:32px;border:none;background:rgba(0,0,0,.06);border-radius:50%;font-size:16px;color:var(--text2);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1}
.sg-sub{padding:6px 20px 14px;font-size:13px;color:var(--text3);line-height:1.4;flex-shrink:0}
.sg-canvas-wrap{position:relative;margin:0 20px;border:1.5px dashed var(--b2);border-radius:14px;overflow:hidden;flex-shrink:0;background:#fff;min-height:200px}
.sg-canvas{display:block;width:100%;height:auto;min-height:200px;touch-action:none}
.sg-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text3);pointer-events:none;font-weight:500}
.sg-legal{margin:10px 20px 0;font-size:11px;color:var(--text3);line-height:1.5;flex-shrink:0}
.sg-footer{display:flex;gap:10px;padding:14px 20px 0;flex-shrink:0}
.sg-btn-clear{flex:1;height:48px;border:1.5px solid var(--b2);border-radius:12px;background:transparent;font-size:15px;font-weight:600;color:var(--text2);cursor:pointer;font-family:inherit}
.sg-btn-validate{flex:2;height:48px;border:none;border-radius:12px;background:#FF6B00;font-size:15px;font-weight:700;color:#fff;cursor:pointer;font-family:inherit}
.sg-btn-validate:active{opacity:.85}
.sg-btn-clear:active{background:var(--b2)}
@media (orientation:landscape){
  #signature-modal{align-items:stretch}
  #signature-modal .sg-sheet{width:100%;max-width:100%;height:100dvh!important;max-height:100dvh!important;border-radius:0;overflow-y:auto}
  #signature-canvas{height:calc(100dvh - 56px)!important;min-height:0!important}
  #signature-modal .sg-canvas-wrap{margin-top:12px!important}
  #signature-modal .sg-handle{display:none!important}
  #signature-modal .sg-head{display:none!important}
  #signature-modal .sg-sub{display:none!important}
  #signature-modal .sg-footer{display:none!important}
  #signature-modal .sg-sheet{display:flex;flex-direction:column;justify-content:center;align-items:center}
  #signature-modal .sg-canvas-wrap{margin:0 16px;width:calc(100% - 32px);min-height:0;flex:1}
  #signature-modal .sg-canvas{height:100%;min-height:0}
}

/* ── BOTTOM SHEET MOBILE ──────────────────────────── */
.v2-bs-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:970}
.v2-bs-overlay.open{display:block;animation:dvFadeIn .35s ease}
.v2-bs{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--card);border-radius:24px 24px 0 0;z-index:971;padding:0 0 32px;box-shadow:0 -4px 32px rgba(0,0,0,.14);will-change:transform}
.v2-bs.open{display:block;animation:dvSlideUp .35s ease-out}
.v2-bs-handle{width:40px;height:4px;border-radius:2px;background:var(--b2);margin:12px auto 14px}
.v2-bs-info{padding:0 20px 14px;border-bottom:1px solid var(--b);margin-bottom:4px}
.v2-bs-ref{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.v2-bs-cli{font-size:19px;font-weight:800;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.v2-bs-actions{display:flex;flex-direction:column}
.v2-bs-btn{display:flex;align-items:center;gap:14px;padding:0 20px;min-height:52px;min-width:unset;background:transparent;font-size:15px;font-weight:600;color:var(--text);cursor:pointer;font-family:inherit;border:none;border-bottom:1px solid var(--b);width:100%;text-align:left;transition:background .13s}
.v2-bs-btn:active{background:rgba(0,0,0,.04)}
.v2-bs-btn-del{color:var(--er)}
.v2-bs-ico{width:36px;height:36px;border-radius:10px;background:var(--b2);flex-shrink:0;fill:none;stroke:var(--text2);stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;padding:8px;box-sizing:border-box}
.v2-bs-btn-del .v2-bs-ico{background:var(--er-bg);stroke:var(--er)}
.v2-bs-btn-sign .v2-bs-ico{background:var(--ok-bg);stroke:var(--ok)}
.v2-bs-btn-pdf .v2-bs-ico{background:var(--info-bg);stroke:var(--info-tx)}
.v2-bs-btn-send .v2-bs-ico{background:var(--info-bg);stroke:var(--info-tx)}
.v2-bs-btn-rapport .v2-bs-ico{background:rgba(124,58,237,.12);stroke:#7C3AED}
.v2-bs-btn-edit .v2-bs-ico{background:var(--ok-bg);stroke:var(--ok)}
.v2-bs-btn-planif .v2-bs-ico{background:rgba(255,107,0,0.12);stroke:var(--accent)}
.v2-bs-btn-facture .v2-bs-ico { stroke: #2ecc71; }

/* Modal Planifier le chantier */
.planif-recap{background:rgba(255,107,0,0.06);border:1.5px solid var(--accent);border-radius:var(--r-sm);padding:12px;font-size:14px;line-height:1.6;margin-bottom:4px}
.planif-equipe-list{display:flex;flex-direction:column;gap:8px}
.planif-equipe-item{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600}

#planifier-modal {
    align-items: stretch;
}
#planifier-modal .modal-content {
    height: 100dvh;
    max-height: 100dvh;
    border-radius: 0;
    max-width: 100%;
    padding: 14px 16px 20px;
    overflow-y: auto;
}
#planifier-modal .modal-header {
    margin-bottom: 14px;
}
#planifier-modal #planif-notes {
    min-height: 100px;
    resize: vertical;
}
#planifier-modal .form-group {
    margin-bottom: 14px;
}
#planifier-modal .modal-actions {
    display: flex;
    gap: 10px;
    margin-top: 20px;
}
#planifier-modal .btn-secondary {
    flex: 1;
}
#planifier-modal .btn-primary {
    flex: 2;
}
#planifier-modal .planif-recap {
    margin-bottom: 16px;
}
.v2-bs-btn-payer .v2-bs-ico{background:var(--ok-bg);stroke:var(--ok)}
.v2-bs-btn-payer{color:#16A34A}
.v2-bs-btn-avoir .v2-bs-ico{background:rgba(124,58,237,.12);stroke:#7C3AED}
.v2-bs-btn-avoir{color:#7C3AED}

/* ── MODAL CRÉER FACTURE ──────────────────────────── */
.fac-create-sheet{position:relative;z-index:1;background:var(--card);border-radius:16px 16px 0 0;width:100%;max-width:600px;padding:16px 20px 36px;display:flex;flex-direction:column;gap:12px}
.fac-create-handle{width:40px;height:4px;background:var(--b2);border-radius:2px;margin:0 auto 4px}
.fac-create-title{font-size:18px;font-weight:800;color:var(--text);margin:0}
.fac-create-body{font-size:14px;color:var(--text2);line-height:1.5;margin:0}
.fac-create-note{font-size:12px;color:var(--text3);line-height:1.4;margin:0}
.fac-create-actions{display:flex;gap:10px;margin-top:4px}
.fac-create-btn-later{flex:1;height:52px;border-radius:14px;border:1.5px solid var(--border,#e5e7eb);background:transparent;color:var(--text);font-size:15px;font-weight:700;cursor:pointer;font-family:inherit}
.fac-create-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)}
.fac-create-btn-later:active{opacity:.8}
.fac-create-btn-ok:active{opacity:.88;transform:scale(.98)}
