:root{--navy:#0f1b2d;--navy-2:#16263d;--teal:#16b5a0;--teal-d:#0e8e7e;--teal-l:#e6f7f4;--ink:#1c2733;--muted:#6b7c8f;--line:#e3e9ef;--bg:#f4f7fa;--amber:#f0a13a;--amber-l:#fdf2e1;--green:#22a06b;--green-l:#e4f6ee}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg);font-size:14px}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:210px;background:var(--navy);color:#cdd8e4;display:flex;flex-direction:column;flex-shrink:0}.brand{padding:18px;display:flex;gap:10px;align-items:center;border-bottom:1px solid var(--navy-2)}.brand .logo{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--teal),var(--teal-d));display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff}.brand .nm{font-weight:700;color:#fff;font-size:14px}.brand .nm small{display:block;font-weight:400;color:#7e90a6;font-size:11px}.nav{padding:10px 0}.nav a{display:block;padding:10px 18px;color:#aebcce;font-size:13.5px;cursor:pointer;border-left:3px solid transparent}.nav a:hover{background:var(--navy-2);color:#fff}.nav a.active{background:var(--navy-2);color:#fff;border-left-color:var(--teal)}.main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{height:58px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 22px}.topbar h1{font-size:18px}.topbar h1 span{color:var(--muted);font-weight:500;font-size:13px;margin-left:8px}.btn{border:none;border-radius:8px;padding:9px 15px;font-size:13px;font-weight:600;cursor:pointer}.btn-primary{background:var(--teal);color:#fff}.content{flex:1;display:flex;min-height:0}.rail{width:200px;background:#fff;border-right:1px solid var(--line);padding:14px 0;overflow-y:auto;flex-shrink:0}.rail h3{font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);padding:8px 18px}.rail .item{padding:8px 18px;cursor:pointer;font-size:13px;border-left:3px solid transparent;display:flex;align-items:center;gap:8px}.rail .item:hover{background:var(--bg)}.rail .item.active{background:var(--teal-l);border-left-color:var(--teal);color:var(--teal-d);font-weight:600}.rail .dot{width:9px;height:9px;border-radius:50%;display:inline-block}.rail .sep{height:1px;background:var(--line);margin:10px 14px}.listwrap{flex:1;display:flex;flex-direction:column;min-width:0;background:#fff;border-right:1px solid var(--line)}.toolbar{padding:13px 20px;border-bottom:1px solid var(--line)}.search{width:100%;border:1px solid var(--line);border-radius:8px;padding:9px 12px;font-size:13px;background:var(--bg)}.tablescroll{overflow-y:auto;flex:1}table{width:100%;border-collapse:collapse}thead th{position:sticky;top:0;background:#fbfcfd;text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:11px 16px;border-bottom:1px solid var(--line)}tbody td{padding:12px 16px;border-bottom:1px solid var(--line);font-size:13.5px}tbody tr{cursor:pointer}tbody tr:hover{background:#f8fbfb}tbody tr.sel{background:var(--teal-l)}.cname{display:flex;align-items:center;gap:10px;font-weight:600}.av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;color:#fff}.sub{color:var(--muted)}.empty{color:var(--muted);text-align:center;padding:34px}.pill{font-size:11px;font-weight:700;padding:3px 10px;border-radius:6px}.p-client{background:var(--teal-l);color:var(--teal-d)}.p-prospect{background:var(--amber-l);color:var(--amber)}.p-fournisseur{background:#eef1f5;color:#5b6b7d}.tag{font-size:11px;padding:2px 9px;border-radius:20px;font-weight:600}.detail{width:400px;background:#fff;border-left:1px solid var(--line);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.dhead{padding:18px;border-bottom:1px solid var(--line);position:relative}.dclose{position:absolute;top:12px;right:12px;border:none;background:var(--bg);width:28px;height:28px;border-radius:7px;cursor:pointer;color:var(--muted)}.dtop{display:flex;gap:12px;align-items:center}.av-lg{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;color:#fff}.dtop h2{font-size:17px}.co{color:var(--muted);font-size:13px}.dmeta{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}.dfields{padding:14px 18px;border-bottom:1px solid var(--line)}.fld{display:flex;justify-content:space-between;padding:6px 0;font-size:13px}.fld .k{color:var(--muted)}.fld .v{font-weight:500;text-align:right}.fld .v.empty{color:#b3bfca;font-weight:400}.grphdr{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--teal-d);font-weight:700;margin:14px 0 4px;padding-bottom:5px;border-bottom:1px solid var(--line)}.tabs{display:flex;border-bottom:1px solid var(--line);padding:0 12px;gap:4px}.tabs button{border:none;background:none;padding:12px;font-size:13px;cursor:pointer;color:var(--muted);border-bottom:2px solid transparent;font-weight:600}.tabs button.active{color:var(--teal-d);border-bottom-color:var(--teal)}.tabbody{flex:1;overflow-y:auto;padding:16px 18px}.composer{border:1px solid var(--line);border-radius:10px;padding:10px;margin-bottom:16px}.composer textarea{width:100%;border:none;resize:vertical;font-family:inherit;font-size:13px;outline:none;min-height:46px}.composer .row{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:8px;margin-top:6px}.composer .lbl{font-size:11px;color:var(--muted)}.event{margin-bottom:14px}.event .ed{font-size:11.5px;color:var(--muted);margin-top:2px}.evcard{background:var(--bg);border:1px solid var(--line);border-radius:8px;padding:9px 11px;margin-top:6px;font-size:12.5px}.note-it{margin-top:12px;font-size:11px;color:var(--muted);font-style:italic}a{color:#3b82f6}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f1b2d73;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#fff;border-radius:12px;width:480px;max-width:92vw;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 18px 50px #0f1b2d40;overflow:hidden}.mhead{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line);position:relative}.mhead h2{font-size:16px}.mhead .dclose{position:static}.mbody{padding:14px 18px;overflow-y:auto;display:flex;flex-direction:column;gap:10px}.mbody label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted);font-weight:600}.mbody input,.mbody select{border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:13.5px;color:var(--ink);background:#fff;font-family:inherit}.mbody input:focus,.mbody select:focus{outline:none;border-color:var(--teal)}.mbody .frow{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mbody .frow>*{min-width:0}.mbody select{max-width:100%}.mbody .lbl{font-size:12px;color:var(--muted);font-weight:600;margin-bottom:4px}.tagpicker{display:flex;flex-wrap:wrap;gap:6px}.tagchip{font-size:12px;padding:4px 10px;border-radius:20px;font-weight:600;cursor:pointer;border:1px solid;background:#fff;-webkit-user-select:none;user-select:none}.tagchip.on{border-color:transparent}.merr{color:#c43d4d;font-size:12.5px;background:#fcebed;border:1px solid #f5c2c8;border-radius:8px;padding:8px 10px}.mfoot{display:flex;justify-content:flex-end;gap:8px;padding:12px 18px;border-top:1px solid var(--line);background:#fbfcfd}.mfoot .btn{background:var(--bg);color:var(--ink)}.mfoot .btn-primary{background:var(--teal);color:#fff}.mfoot .btn:disabled{opacity:.6;cursor:not-allowed}.ktools{display:flex;gap:10px;align-items:center}.psel{border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-size:13px;background:#fff;font-family:inherit;color:var(--ink);min-width:240px}.psel:focus{outline:none;border-color:var(--teal)}.kanban{flex:1;display:flex;gap:12px;padding:14px 18px;overflow-x:auto;overflow-y:hidden;background:var(--bg);min-height:0}.kcol{flex:0 0 280px;background:#fff;border:1px solid var(--line);border-radius:10px;display:flex;flex-direction:column;max-height:100%}.kcol.drop{border-color:var(--teal);box-shadow:0 0 0 2px var(--teal-l)}.khead{padding:12px 14px;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:4px;flex-shrink:0}.kname{font-weight:700;font-size:13px;color:var(--ink);line-height:1.3}.kmeta{display:flex;gap:8px;align-items:center;font-size:11.5px;color:var(--muted)}.kcount{background:var(--bg);padding:1px 7px;border-radius:10px;font-weight:600}.ktot{color:var(--teal-d);font-weight:600}.kbody{padding:10px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;flex:1;min-height:60px}.kcard{background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px 12px;cursor:grab;display:flex;flex-direction:column;gap:5px;transition:box-shadow .12s,transform .12s}.kcard:hover{box-shadow:0 2px 8px #0f1b2d14;border-color:#cdd8e4}.kcard:active{cursor:grabbing}.kcard.drag{opacity:.4}.kcard.won{border-left:3px solid var(--green)}.kcard.lost{border-left:3px solid #c43d4d}.ktitle{font-weight:600;font-size:13.5px;color:var(--ink);line-height:1.3}.kcontact{font-size:12px;color:var(--muted)}.kcontact a{cursor:pointer;color:var(--teal-d);font-weight:500}.kcontact a:hover{text-decoration:underline}.kcontact .muted{color:var(--muted)}.kcontact .kco{color:#9aa7b6}.kfoot{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:2px;flex-wrap:wrap}.kval{font-weight:700;color:var(--ink);font-size:13px}.kpill{font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.4px}.kpill.won{background:var(--green-l);color:var(--green)}.kpill.lost{background:#fcebed;color:#c43d4d}.ksrc{font-size:11px;color:var(--muted)}.kempty{font-size:12px;color:#b3bfca;text-align:center;padding:14px 6px;border:1px dashed var(--line);border-radius:8px;font-style:italic}.rail .item .ct{margin-left:auto;background:var(--bg);color:var(--muted);padding:1px 7px;border-radius:10px;font-size:11px;font-weight:600}.rail .item.active .ct{background:var(--teal);color:#fff}.statusdot{width:9px;height:9px;border-radius:50%;display:inline-block}.statusdot.s-ebauche{background:#9aa7b6}.statusdot.s-envoye{background:var(--amber)}.statusdot.s-signe{background:var(--green)}.statusdot.s-archive{background:#5b6b7d}.ds-ebauche{background:#eef1f5;color:#5b6b7d}.ds-envoye{background:var(--amber-l);color:var(--amber)}.ds-signe{background:var(--green-l);color:var(--green)}.ds-archive{background:#e6e9ec;color:#5b6b7d}.docttl{display:flex;flex-direction:column;gap:2px}.docttl-main{font-weight:600;color:var(--ink);font-size:13.5px}.docttl-tpl{color:var(--muted);font-size:11.5px}.detail.detail-doc{width:520px}.detail-doc .dhead h2{font-size:16px;line-height:1.3;margin-right:32px}.detail-doc .dmeta{margin-top:10px;display:flex;gap:6px;flex-wrap:wrap}.docsel{border:1px solid var(--line);border-radius:7px;padding:5px 8px;font-size:12.5px;background:#fff;color:var(--ink);font-family:inherit}.contactlink{cursor:pointer;color:var(--teal-d);font-weight:500}.contactlink:hover{text-decoration:underline}.pdfwrap{height:480px;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--bg)}.pdfwrap iframe{width:100%;height:100%;border:0;display:block;background:#fff}.actrow{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}.actrow .btn{background:var(--bg);color:var(--ink);font-size:12.5px;text-decoration:none;padding:8px 14px;border-radius:8px;border:1px solid var(--line)}.actrow .btn:hover{background:#eef1f5}.signpanel{display:flex;flex-direction:column;gap:10px}.signpanel label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted);font-weight:600}.signpanel input[type=text],.signpanel input[type=email],.signpanel input:not([type]){border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:13.5px;color:var(--ink);background:#fff;font-family:inherit}.signpanel input:focus{outline:none;border-color:var(--teal)}.signpanel .sigtype{font-family:Snell Roundhand,Brush Script MT,Lucida Handwriting,cursive;font-size:22px;letter-spacing:.5px;color:var(--navy)}.signpanel label.checkbox{flex-direction:row;align-items:flex-start;gap:10px;font-size:12.5px;color:var(--ink);font-weight:500;font-style:normal;background:var(--teal-l);border:1px solid #b9ece2;border-radius:8px;padding:10px 12px;line-height:1.45}.signpanel label.checkbox input{margin-top:2px;flex-shrink:0;width:16px;height:16px;cursor:pointer}.signpanel button{margin-top:6px;align-self:flex-start}.sigs{display:flex;flex-direction:column;gap:10px}.sigcard{border:1px solid var(--line);border-radius:10px;padding:12px 14px;background:#fbfcfd}.sighead{font-size:13.5px;margin-bottom:6px}.sighead .sub{color:var(--muted);font-weight:400;font-size:12.5px}.sigcard .fld{padding:3px 0;font-size:12.5px}.sighash{margin-top:8px;padding-top:8px;border-top:1px dashed var(--line)}.sighash .lbl{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px}.sighash code{font-family:SF Mono,Menlo,monospace;font-size:10.5px;color:var(--ink);word-break:break-all;line-height:1.5;display:block;background:#fff;border:1px solid var(--line);border-radius:6px;padding:6px 8px}.cdoclist{display:flex;flex-direction:column;gap:8px}.cdocrow{border:1px solid var(--line);border-radius:8px;padding:10px 12px;background:#fbfcfd}.cdoctop{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}.cdoctitle{font-weight:600;color:var(--teal-d);font-size:13px;text-decoration:none}.cdoctitle:hover{text-decoration:underline}.cdocmeta{display:flex;gap:10px;font-size:11.5px;color:var(--muted)}.cdocmeta span:not(:last-child):after{content:" ·";color:#cdd8e4;margin-left:6px}.dashbody{flex:1;padding:22px;overflow-y:auto;background:var(--bg);min-height:0}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:26px}.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 18px;display:flex;flex-direction:column;gap:6px;border-left:3px solid var(--line);transition:box-shadow .15s}.kpi:hover{box-shadow:0 2px 10px #0f1b2d0f}.kpi-lbl{font-size:11.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.kpi-val{font-size:24px;font-weight:700;color:var(--ink);line-height:1.1}.kpi-sub{font-size:11.5px;color:var(--muted)}.kpi-teal{border-left-color:var(--teal)}.kpi-green{border-left-color:var(--green)}.kpi-green .kpi-val{color:var(--green)}.kpi-amber{border-left-color:var(--amber)}.kpi-navy{border-left-color:var(--navy)}.kpi-purple{border-left-color:#7c5cd6}.funnelblock{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 20px}.funnelhdr{margin-bottom:14px;display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap}.funnelhdr h2{font-size:15px;font-weight:700;color:var(--ink)}.funnelhdr .sub{font-size:12px;color:var(--muted)}.funnel{display:flex;flex-direction:column;gap:8px}.funnel .frow{display:grid;grid-template-columns:260px 1fr 110px;gap:14px;align-items:center}.funnel .fname{font-size:12.5px;color:var(--ink);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.funnel .fbar{background:var(--bg);border-radius:6px;height:26px;position:relative;overflow:hidden}.funnel .fbar-fill{background:linear-gradient(90deg,var(--teal),var(--teal-d));height:100%;display:flex;align-items:center;padding:0 10px;border-radius:6px;min-width:30px;transition:width .2s}.funnel .fbar-count{color:#fff;font-weight:700;font-size:12px}.funnel .fval{font-size:12.5px;color:var(--ink);text-align:right;font-weight:600}.funnel .empty{padding:18px;text-align:center;color:var(--muted);font-style:italic}.funnelblock>.empty{padding:30px;text-align:center;color:var(--muted);font-style:italic}
