/* ═══════════════════ PRODUCTION OVERRIDES ════════════════════ */
/* Styles spécifiques à l'app production qui ne sont pas dans le design */

.hidden{display:none!important}
.form-input{height:48px;border:1.5px solid var(--b2);border-radius:var(--r-sm);padding:0 14px;font-size:15px;color:var(--text);background:var(--card);font-family:inherit;outline:none;transition:border-color var(--tr);width:100%}
.form-input:focus{border-color:var(--accent)}
.btn-primary{display:flex;align-items:center;justify-content:center;height:52px;border-radius:var(--r);background:linear-gradient(135deg,var(--accent-h),var(--accent) 50%,var(--accent-d));color:#fff;font-size:15px;font-weight:800;box-shadow:0 4px 14px rgba(255,107,0,.34);cursor:pointer;font-family:inherit;transition:transform var(--tr),opacity var(--tr);width:100%}
.btn-primary:active{transform:scale(.98);opacity:.9}
.btn-primary:disabled{opacity:.45;cursor:not-allowed;transform:none}

/* Loader */
.loader{position:fixed;inset:0;background:var(--bg);z-index:99999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}
.spinner{width:36px;height:36px;border:3px solid var(--b2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Page system production */
.page-content{display:none}
.page-content:not(.hidden){display:block}

/* Header desktop */
#header{height:var(--header-height);background:var(--card);border-bottom:1px solid var(--b2);position:fixed;top:0;left:0;right:0;z-index:800;display:flex;align-items:center}
.header-container{display:flex;align-items:center;padding:0 20px;width:100%;gap:12px}
.logo img{height:32px}
.nav-desktop{display:none}
.hamburger{background:transparent;padding:8px;display:flex;flex-direction:column;gap:5px;cursor:pointer}
.hamburger span{width:22px;height:2px;background:var(--text);border-radius:2px;display:block}
.dark-mode-toggle-container{margin-left:auto}
.dark-mode-switch{position:relative;display:inline-block;cursor:pointer}
.dark-mode-switch input{opacity:0;width:0;height:0}
.dark-mode-slider{display:flex;align-items:center;background:var(--b2);border-radius:99px;padding:3px;gap:2px;transition:var(--tr)}
.dark-mode-icon{font-size:14px;padding:2px 4px;border-radius:99px;transition:var(--tr)}

/* Sidebar desktop */
#sidebar{position:fixed;left:0;top:var(--header-height);bottom:0;width:var(--sidebar-width);background:var(--card);border-right:1px solid var(--b2);overflow-y:auto;z-index:700;display:none}
@media(min-width:769px){
  #sidebar{display:block}
  .nav-desktop{display:flex;align-items:center;gap:4px}
  .hamburger{display:none}
  .main-content{margin-left:var(--sidebar-width);margin-top:var(--header-height)}
}

/* Bottom nav production */
#bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height);background:var(--card);border-top:1px solid var(--b2);z-index:800}
@media(min-width:769px){#bottom-nav{display:none}}

/* Main content */
.main-content{padding-bottom:var(--bottom-nav-height)}

/* Toast */
#toast{position:fixed;bottom:calc(var(--bottom-nav-height) + 12px);left:50%;transform:translateX(-50%) translateY(8px);background:#0F172A;color:#fff;padding:10px 18px;border-radius:99px;font-size:13px;font-weight:600;white-space:nowrap;z-index:99999;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Overlay menu */
#overlay-menu{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:600}
#overlay-menu.active{display:block}

/* ═════════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════════════════════
   DevisVox v3 — css/style.css
   DESIGN TOKENS + CSS RESET + SHARED COMPONENTS + DARK MODE
   ══════════════════════════════════════════════════════════════ */

/* ─── CSS RESET ────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
button{cursor:pointer;font-family:inherit;-webkit-tap-highlight-color:transparent;border:none;background:none}
input,textarea,select{font-family:inherit}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ═══ SHARED ════════════════════════════════════════════════ */
.ph{padding:14px 20px 10px;flex-shrink:0}
.ph-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.ph-title{font-size:22px;font-weight:900;color:var(--text);letter-spacing:-.4px;line-height:1.2}

.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)}
.sw:focus-within{border-color:var(--accent)}
.sw svg{width:16px;height:16px;stroke:var(--text3);stroke-width:2;flex-shrink:0}
.sw input{flex:1;border:none;background:transparent;outline:none;font-size:14px;color:var(--text)}
.sw input::placeholder{color:var(--text3)}
.sw-mic{width:32px;height:32px;border-radius:8px;background:transparent;display:flex;align-items:center;justify-content:center;color:var(--text3);flex-shrink:0;transition:var(--tr)}
.sw-mic:active{background:var(--accent-wash);color:var(--accent)}

.lr{display:flex;align-items:center;padding:13px 20px;background:var(--card);border-bottom:1px solid var(--b);cursor:pointer;transition:background var(--tr);position:relative}
.lr:active{background:#F8F9FA}
.lr-l{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.lr-r{flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.l-n{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.04em}
.l-c{font-size:15px;font-weight:700;color:var(--text);line-height:1.2}
.l-d{font-size:12px;color:var(--text2);font-weight:500}
.l-a{font-size:16px;font-weight:800;color:var(--text)}
.l-dt{font-size:11px;color:var(--text3);font-weight:500}

.bd{display:inline-flex;align-items:center;padding:3px 9px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.02em;flex-shrink:0;white-space:nowrap}
.bd.ok{background:var(--ok-bg);color:var(--ok-tx)}
.bd.wa{background:var(--wa-bg);color:var(--wa-tx)}
.bd.er{background:var(--er-bg);color:var(--er-tx)}
.bd.info{background:var(--info-bg);color:var(--info-tx)}
.bd.vio{background:#EDE9FE;color:#6D28D9}

.btn-p{display:flex;align-items:center;justify-content:center;gap:8px;height:52px;border-radius:var(--r);background:linear-gradient(135deg,var(--accent-h),var(--accent) 50%,var(--accent-d));color:#fff;font-size:15px;font-weight:800;box-shadow:0 4px 14px rgba(255,107,0,.34);transition:transform var(--tr),opacity var(--tr)}
.btn-p:active{transform:scale(.98);opacity:.9}
.btn-s{display:flex;align-items:center;justify-content:center;gap:8px;height:52px;border-radius:var(--r);border:1.5px solid var(--b2)!important;background:var(--card);color:var(--text);font-size:15px;font-weight:700;transition:var(--tr)}
.btn-s:active{background:var(--b)}
.btn-ok{display:flex;align-items:center;justify-content:center;gap:8px;height:52px;border-radius:var(--r);background:linear-gradient(135deg,#34D399,var(--ok) 50%,var(--ok-d));color:#fff;font-size:15px;font-weight:800;box-shadow:0 4px 14px rgba(16,185,129,.3);transition:transform var(--tr)}
.btn-ok:active{transform:scale(.98)}

.fpill{flex-shrink:0;padding:5px 10px;border-radius:99px;border:1.5px solid var(--b2);background:var(--card);font-size:11px;font-weight:600;color:var(--text2);cursor:pointer;white-space:nowrap;transition:all .15s}
.fpill.on{background:var(--accent);color:#fff;border-color:var(--accent)}

.fab{position:absolute;bottom:20px;right:20px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(255,107,0,.44);font-size:24px;line-height:1;z-index:10;transition:var(--tr)}
.fab:active{transform:scale(.92)}

.sblk{background:var(--card);border-radius:var(--r);margin:0 16px 12px;overflow:hidden;box-shadow:var(--sh)}
.s-lbl{padding:10px 20px 4px;font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em}

/* ═══ OVERLAYS ════════════════════════════════════════════ */
.bs{display:none;position:absolute;inset:0;z-index:970;align-items:flex-end}
.bs.open{display:flex}
.bs-bg{position:absolute;inset:0;background:rgba(0,0,0,.5);animation:fadeIn .2s;z-index:0}
.bs-panel{position:relative;width:100%;background:var(--card);border-radius:24px 24px 0 0;padding:8px 0 32px;z-index:10;animation:slideUp .25s ease;box-shadow:0 -4px 32px rgba(0,0,0,.14)}
.bs-handle{width:40px;height:4px;border-radius:2px;background:#E0E0E0;margin:8px auto 14px}
.bs-info{padding:0 20px 12px;border-bottom:1px solid var(--b);margin-bottom:4px}
.bs-num{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.04em}
.bs-cli{font-size:18px;font-weight:800;color:var(--text);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bs-meta{font-size:13px;color:var(--text2);margin-top:2px}
.bs-act{display:flex;align-items:center;gap:14px;padding:0 20px;min-height:52px;background:transparent;font-size:15px;font-weight:600;color:var(--text);cursor:pointer;font-family:inherit;border-bottom:1px solid #F8F8F8;width:100%;text-align:left;transition:var(--tr)}
.bs-act:active{background:rgba(0,0,0,.04)}
.bs-ico{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.bs-act.er{color:var(--er)}

.am{display:none;position:absolute;inset:0;z-index:980;align-items:flex-end}
.am.open{display:flex}
.am-bg{position:absolute;inset:0;background:rgba(0,0,0,.5);animation:fadeIn .2s}
.am-sht{position:relative;width:100%;background:var(--card);border-radius:24px 24px 0 0;padding:8px 20px 32px;z-index:1;animation:slideUp .25s ease;max-height:90%;overflow-y:auto}
.am-sht::-webkit-scrollbar{display:none}
.am-hdl{width:40px;height:4px;border-radius:2px;background:#E0E0E0;margin:8px auto 16px}
.am-title{font-size:17px;font-weight:800;color:var(--text);margin-bottom:14px}
.am-row{display:flex;gap:8px;margin-top:18px}
.am-btn{flex:1;height:48px;border-radius:var(--r-sm);border:1.5px solid var(--b2);background:var(--card);font-size:14px;font-weight:700;color:var(--text);cursor:pointer;font-family:inherit;transition:var(--tr)}
.am-btn:active{background:var(--b)}
.am-btn.p{background:var(--accent);color:#fff;border-color:var(--accent)}
.am-btn.ok{background:var(--ok);color:#fff;border-color:var(--ok)}
.am-btn.er{background:var(--er);color:#fff;border-color:var(--er)}

.pdf-v{display:none;position:absolute;inset:0;z-index:960;background:var(--bg);flex-direction:column}
.pdf-v.open{display:flex}
.pdf-bar{height:54px;background:var(--card);border-bottom:1px solid var(--b2);display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0}
.pdf-bar-t{font-size:15px;font-weight:700;color:var(--text)}
.pdf-x{width:32px;height:32px;border-radius:8px;background:#F3F4F6;display:flex;align-items:center;justify-content:center;font-size:15px;cursor:pointer}
.pdf-body{flex:1;overflow-y:auto;padding:16px 12px;background:#E8EAED}
.pdf-body::-webkit-scrollbar{display:none}
.pdf-doc{background:var(--card);border-radius:4px;padding:20px 18px;box-shadow:0 2px 12px rgba(0,0,0,.12)}
.pdf-head{display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:14px;border-bottom:2.5px solid var(--accent)}
.pdf-logo{font-size:17px;font-weight:900;color:var(--accent)}
.pdf-parties{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.pdf-party{background:var(--bg);border-radius:8px;padding:10px 12px}
.pdf-plbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text3);margin-bottom:3px}
.pdf-pname{font-size:13px;font-weight:700;color:var(--text)}
.pdf-tbl{width:100%;border-collapse:collapse;margin-bottom:12px;font-size:12px}
.pdf-tbl th{background:#F3F4F6;padding:6px 8px;text-align:left;font-size:10px;text-transform:uppercase;color:var(--text2)}
.pdf-tbl td{padding:8px;border-bottom:1px solid #F3F4F6}
.pdf-ttc{display:flex;justify-content:space-between;padding:12px;background:var(--accent-light);border-radius:var(--r-sm);font-size:16px;font-weight:900;color:var(--accent)}
.pdf-dl{display:flex;align-items:center;justify-content:center;gap:8px;margin:14px 0 0;height:48px;background:var(--accent);color:#fff;border-radius:var(--r-sm);font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;width:100%}


/* ═══ ANIMATIONS ═════════════════════════════════════════ */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes slideRight{from{transform:translateX(100%)}to{transform:translateX(0)}}
@keyframes ripple{0%{transform:scale(.82);opacity:.85}100%{transform:scale(1.12);opacity:0}}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.4),0 12px 38px rgba(220,38,38,.5)}50%{box-shadow:0 0 0 16px rgba(220,38,38,0),0 12px 38px rgba(220,38,38,.5)}}
@keyframes waveBar{0%,100%{transform:scaleY(.35)}50%{transform:scaleY(1)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* ═══ DISABLED STATE ════════════════════════════════════════ */
button:disabled,.btn-p:disabled,.btn-ok:disabled{opacity:.42;cursor:not-allowed;pointer-events:none}

/* ═══ HOVER STATES (tablet/desktop pointer devices) ════════ */
@media (hover:hover) {
  .btn-p:hover{opacity:.88;transform:scale(.99)}
  .btn-s:hover{background:var(--b)}
  .btn-ok:hover{opacity:.88;transform:scale(.99)}
  .ntab:hover svg{stroke:var(--accent)}
  .ntab:hover span{color:var(--accent)}
  .lr:hover{background:var(--b)}
  .fpill:hover:not(.on){background:var(--b)}
  .bs-act:hover{background:rgba(0,0,0,.04)}
  .stg-btn-c:hover{background:var(--b)}
  .stg-btn-s:hover{opacity:.88}
  .fab:hover{transform:scale(1.06);box-shadow:0 6px 22px rgba(255,107,0,.52)}
  #vocal-mic-btn:hover{transform:scale(1.04)}
}

/* ── Nouveau-devis : grille 2 colonnes ── */
.nd-grid-2{margin-bottom:12px}

/* ── Tableau articles : en-têtes colonnes ── */
.devis-articles-header{display:flex}
.article-col-header{flex-shrink:0}
.devis-articles-header .article-col-header:nth-child(1){width:90px}
.devis-articles-header .article-col-header:nth-child(2){flex:1;min-width:0;flex-shrink:1}
.devis-articles-header .article-col-header:nth-child(3){width:52px;text-align:center}
.devis-articles-header .article-col-header:nth-child(4){width:50px}
.devis-articles-header .article-col-header:nth-child(5){width:65px;text-align:right}
.devis-articles-header .article-col-header:nth-child(6){width:16px}
.devis-articles-header .article-col-header:nth-child(7){width:80px;text-align:right}
.devis-articles-header .article-col-header:nth-child(8){width:55px;text-align:center}
.devis-articles-header .article-col-header:nth-child(9){width:36px}

/* ── Équipe / RH : layout filtres ── */
#rh-page-actions{margin-bottom:16px}
.rh-filter-bar select{max-width:220px}
.rh-filter-bar input[type="month"]{max-width:160px}
