:root{--navy:#232a44;--navy-light:#2f3a63;--purple:#8b2fd6;--purple-light:#b388e0;--bg:#f4f4f8;--card:#fff;--text:#1c2030;--muted:#5f6577;--border:#e3e4ec;--green:#157a4b;--red:#c0322c;--orange:#9a5f00;font-family:Helvetica Neue,Helvetica,Arial,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,sans-serif}button,a,input,select,textarea,summary{touch-action:manipulation}button,.chip,a{transition:background-color .15s,color .15s,border-color .15s,opacity .15s}button:focus-visible{outline:2px solid var(--purple);outline-offset:2px}a:focus-visible{outline:2px solid var(--purple);outline-offset:2px}summary:focus-visible{outline:2px solid var(--purple);outline-offset:2px}.chip:focus-visible{outline:2px solid var(--purple);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition:none!important;animation:none!important}}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0}h1{margin:0 0 16px;font-size:22px}h2{margin:0 0 10px;font-size:16px}a{color:var(--purple);text-decoration:none}.page-loading{text-align:center;color:var(--muted);padding:80px}.topnav{background:var(--navy);color:#fff;z-index:20;align-items:center;gap:24px;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.topnav-brand,.login-brand{letter-spacing:-.5px;font-size:20px;font-weight:700}.topnav-brand span,.login-brand span{color:var(--purple-light);font-weight:400}.topnav-links{flex:1;gap:4px;display:flex}.topnav-links a{color:#cfd3e4;border-radius:8px;padding:8px 14px;font-size:14px}.nav-ic,.nav-short{display:none}.topnav-links a:hover,.topnav-links a.active{color:#fff;background:var(--navy-light)}.topnav-links a.nav-cta{background:var(--purple);color:#fff;font-weight:600}.topnav-links a.nav-cta:hover{background:#9c45e2}.main{max-width:1180px;margin:0 auto;padding:28px 24px 80px}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px}.btn-primary{background:var(--purple);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600}.btn-primary:hover{background:#9c45e2}.btn-primary:active{background:#7a23c4}.btn-primary:disabled{opacity:.5;cursor:default}.btn-secondary{color:var(--navy);border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:10px;padding:9px 16px;font-size:14px;font-weight:500}.btn-secondary:hover{border-color:var(--purple);color:var(--purple)}.btn-secondary:active,.btn-danger:active{background:#f3ecfc}.chip:active{background:#ececf2}.chip.active:active{background:var(--navy-light)}.btn-ghost{color:#cfd3e4;cursor:pointer;background:0 0;border:none;font-size:13px}.btn-ghost:hover{color:#fff}.btn-danger{color:var(--red);border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:10px;padding:9px 16px}.btn-sm{border-radius:8px;padding:5px 10px;font-size:12.5px}label{color:var(--navy);flex-direction:column;gap:5px;font-size:13px;font-weight:600;display:flex}input,select,textarea{font:inherit;border:1px solid var(--border);color:var(--text);background:#fff;border-radius:9px;padding:9px 11px;font-weight:400}input:focus,select:focus,textarea:focus{outline:2px solid var(--purple-light);border-color:var(--purple)}.form-error{color:var(--red);font-size:13px}.login-page{min-height:100vh;background:var(--navy);place-items:center;min-height:100dvh;padding:16px;display:grid}.login-card{background:#fff;border-radius:16px;flex-direction:column;gap:16px;width:min(360px,100%);padding:36px 28px;display:flex}.link-btn{color:var(--purple);cursor:pointer;font:inherit;text-align:center;background:0 0;border:none;padding:6px;font-size:13px}.link-btn:hover{text-decoration:underline}.login-brand{color:var(--navy);font-size:28px}.login-brand span{color:var(--purple)}.login-sub{color:var(--muted);margin:-10px 0 8px;font-size:13px}.stats-row{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px;display:grid}.stat{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 18px}.stat .stat-label{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;font-size:12px}.stat .stat-value{margin-top:4px;font-size:22px;font-weight:700}.stat.alert .stat-value{color:var(--red)}.filters{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.chip{border:1px solid var(--border);cursor:pointer;color:var(--text);background:#fff;border-radius:999px;padding:6px 14px;font-size:13px}.chip.active{background:var(--navy);color:#fff;border-color:var(--navy)}.filters input[type=search]{flex:1;min-width:180px}table.list{border-collapse:collapse;background:var(--card);border-radius:12px;width:100%;overflow:hidden}table.list th{text-align:left;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);border-bottom:1px solid var(--border);background:#fafafc;padding:10px 12px;font-size:11.5px}table.list td{border-bottom:1px solid var(--border);padding:10px 12px;font-size:13.5px}table.list tr:last-child td{border-bottom:none}table.list tbody tr{cursor:pointer}table.list tbody tr:hover{background:#f8f5fd}.td-num{white-space:nowrap;font-weight:600}.row-actions{white-space:nowrap;align-items:center;gap:6px;display:inline-flex}.row-delete{cursor:pointer;opacity:.35;background:0 0;border:none;border-radius:8px;padding:4px 6px;font-size:14px}tr:hover .row-delete{opacity:1}.row-delete:focus-visible{opacity:1}.row-delete:hover{background:#fde9e8}.td-amount{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.badge{white-space:nowrap;border-radius:999px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.badge.envoyee{color:var(--orange);background:#fff4e0}.badge.payee{color:var(--green);background:#e3f6ec}.badge.brouillon{color:var(--muted);background:#ececf2}.badge.annulee{color:var(--muted);background:#ececf2;text-decoration:line-through}.badge.retard{color:var(--red);background:#fde9e8}.badge.devis{color:var(--purple);background:#ede3fb}.doc-form{flex-direction:column;gap:18px;display:flex}.form-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;display:grid}.lines-editor{counter-reset:line;flex-direction:column;gap:8px;display:flex}.line-edit{grid-template-columns:1.6fr 92px 64px 76px 96px 88px 84px 28px;grid-template-areas:"desc date qty unit price disc total rm";align-items:end;gap:8px;display:grid}.line-edit .f-desc{grid-area:desc}.line-edit .f-date{grid-area:date}.line-edit .f-qty{grid-area:qty}.line-edit .f-unit{grid-area:unit}.line-edit .f-price{grid-area:price}.line-edit .f-disc{grid-area:disc}.line-edit .f-total{grid-area:total}.line-edit .line-remove{grid-area:rm}.line-edit label{gap:3px}.line-edit input{width:100%;padding:8px 9px}.f-cap{text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-size:10.5px;font-weight:600}.line-edit:not(:first-child) .f-cap{display:none}.f-total{flex-direction:column;gap:3px;font-size:13px;display:flex}.f-total b{text-align:right;font-variant-numeric:tabular-nums;color:var(--navy);white-space:nowrap;padding:8px 2px}.lines-hint{color:var(--muted);margin:8px 0 0;font-size:12.5px}.line-remove{color:var(--muted);cursor:pointer;background:0 0;border:none;padding-bottom:9px;font-size:16px}.line-remove:hover{color:var(--red)}.actions-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.spacer{flex:1}.pay-popover{white-space:nowrap;align-items:center;gap:6px;display:inline-flex}.pay-popover input[type=date]{padding:4px 6px;font-size:12.5px}.notes-card{margin-bottom:18px}.notes-card summary{cursor:pointer;color:var(--navy);font-size:14px;font-weight:600}.notes-card textarea{box-sizing:border-box;width:100%;margin-top:10px}.draft-warning{border-color:var(--orange);background:#fffaf0;margin-bottom:16px;font-size:14px}.stats-grid{grid-template-columns:1fr 1fr;align-items:start;gap:18px;display:grid}table.list.compact td,table.list.compact th{padding:7px 10px;font-size:13px}table.list.compact tbody tr:hover{background:inherit}.month-bars{align-items:flex-end;gap:8px;padding-top:24px;display:flex}.month-bar{text-align:center;flex:1}.month-bar-fill{background:linear-gradient(180deg, var(--purple), var(--purple-light));border-radius:6px 6px 0 0;min-height:2px}.month-bar-label{color:var(--muted);margin-top:5px;font-size:11px}.month-bar-value{color:var(--navy);margin-bottom:3px;font-size:11px;font-weight:600}.bar-list{flex-direction:column;gap:7px;display:flex}.bar-row{grid-template-columns:minmax(90px,160px) 1fr auto;align-items:center;gap:10px;display:grid}.bar-label{white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;overflow:hidden}.bar-track{background:#efeef5;border-radius:6px;height:18px}.bar-fill{background:#f4d9b0;border-radius:6px;min-width:2px;height:100%;display:flex;overflow:hidden}.bar-paid{background:linear-gradient(90deg, var(--purple), var(--purple-light));height:100%}.bar-value{font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--navy);font-size:12.5px;font-weight:600}.bar-legend{color:var(--muted);gap:16px;margin-bottom:10px;font-size:12px;display:flex}.bar-legend .dot{vertical-align:-1px;border-radius:3px;width:10px;height:10px;margin-right:5px;display:inline-block}.bar-legend .dot-paid{background:var(--purple)}.bar-legend .dot-pending{background:#f4d9b0}.inv-logo{max-width:55mm;max-height:14mm;margin-bottom:2mm;display:block}.sheet-wrap{zoom:var(--sheet-zoom,1)}@media (max-width:760px){.main{padding:14px 10px calc(76px + env(safe-area-inset-bottom))}.topnav{gap:10px;height:50px;padding:0 14px}.topnav .nav-cta{display:none}.topnav-links{z-index:30;background:var(--navy);border-top:1px solid var(--navy-light);padding:5px 2px calc(5px + env(safe-area-inset-bottom));justify-content:space-around;gap:0;display:flex;position:fixed;bottom:0;left:0;right:0}.topnav-links a{letter-spacing:.1px;white-space:nowrap;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:2px;min-width:0;padding:5px 2px;font-size:10px;display:flex}.topnav-links a.nav-cta{color:#cfd3e4;background:0 0;font-weight:400;display:flex}.topnav-links a.nav-cta:hover{background:var(--navy-light)}.topnav-links a.nav-cta .nav-ic{color:var(--purple-light)}.topnav-links a.active,.topnav-links a.nav-cta.active{color:#fff;background:var(--navy-light)}.topnav-links a.active .nav-ic{color:var(--purple-light)}.nav-ic{width:22px;height:22px;display:block}.nav-short{display:block}.nav-full{display:none}.hide-m{display:none!important}.row-delete{opacity:.6;padding:10px;font-size:16px}table.list{display:block;overflow-x:auto}table.list td{padding:12px 10px;font-size:14px}.stats-row{grid-template-columns:1fr 1fr!important}.stats-grid{grid-template-columns:1fr}.month-bars{overflow-x:auto}input,select,textarea{font-size:16px}.btn-primary,.btn-secondary,.btn-danger{padding:12px 18px}.chip{padding:10px 16px}.actions-row{gap:8px}.sheet-wrap{align-items:flex-start}h1{font-size:19px}.lines-editor{gap:12px}.line-edit{border:1px solid var(--border);background:#fafafc;border-radius:12px;grid-template-columns:1fr 1fr 1fr;grid-template-areas:"desc desc desc""date qty unit""price disc total";align-items:start;gap:10px;padding:36px 12px 12px;position:relative}.line-edit:before{counter-increment:line;content:"Ligne " counter(line);letter-spacing:.5px;text-transform:uppercase;color:var(--purple);font-size:11px;font-weight:700;position:absolute;top:11px;left:13px}.line-edit:not(:first-child) .f-cap{display:inline}.line-edit .line-remove{padding:10px 12px;font-size:18px;position:absolute;top:2px;right:2px}.f-total b{padding:10px 2px;font-size:16px}}.dropzone{border:2px dashed var(--purple-light);text-align:center;color:var(--purple);cursor:pointer;background:#faf6ff;border-radius:14px;margin-top:8px;padding:44px 20px;font-weight:600}.dropzone.over{border-color:var(--purple);background:#ede3fb}.srg-review{grid-template-columns:1fr 1fr;align-items:start;gap:18px;margin-top:18px;display:grid}@media (max-width:900px){.srg-review{grid-template-columns:1fr}}.sheet-wrap{flex-direction:column;align-items:center;gap:18px;display:flex}.sheet{color:#111;background:#fff;flex-direction:column;width:210mm;min-height:296mm;padding:16mm 16mm 0;font-size:10.5pt;line-height:1.45;display:flex;position:relative;box-shadow:0 2px 18px #14183c21}[contenteditable=true]{border-radius:3px;outline:none}[contenteditable=true]:hover{background:#f3ecfc}[contenteditable=true]:focus{background:#ede3fb}.inv-header{justify-content:space-between;display:flex}.inv-company{font-size:10pt}.inv-company .inv-name{letter-spacing:-.3px;font-size:13pt;font-weight:700}.inv-company .inv-name span{color:var(--purple);font-weight:400}.inv-client{white-space:pre-line;min-width:55mm;margin-top:14mm;font-size:10.5pt}.inv-title-row{border-bottom:2.5px solid var(--navy);justify-content:space-between;align-items:baseline;margin-top:8mm;padding-bottom:3mm;display:flex}.inv-title{color:var(--navy);letter-spacing:.5px;font-size:17pt;font-weight:700}.inv-number{color:#444;font-size:11pt}.inv-meta{color:#444;gap:10mm;margin-top:3mm;font-size:9.5pt;display:flex}.inv-object{margin-top:5mm;font-size:11pt;font-weight:700}.inv-table{border-collapse:collapse;width:100%;margin-top:4mm;font-size:9.5pt}.inv-table th{text-align:left;background:var(--navy);color:#fff;text-transform:uppercase;letter-spacing:.4px;padding:2.2mm 2.5mm;font-size:8.5pt;font-weight:600}.inv-table th.r,.inv-table td.r{text-align:right}.inv-table td{border-bottom:.3mm solid #e8e8ee;padding:1.8mm 2.5mm}.inv-table tbody tr:nth-child(2n){background:#f7f7fa}.inv-totals{width:70mm;margin-top:4mm;margin-left:auto;font-size:10pt}.inv-totals .tot-row{justify-content:space-between;padding:1.4mm 2mm;display:flex}.inv-totals .tot-row.final{background:var(--navy);color:#fff;border-radius:1.5mm;margin-top:1mm;font-size:11pt;font-weight:700}.inv-conditions{color:#333;margin-top:5mm;font-size:9pt}.inv-clause{color:#444;text-align:justify;margin-bottom:3mm;font-size:7.5pt;line-height:1.4}.live-totals{color:var(--muted);font-size:13.5px}.live-totals b{color:var(--text)}.live-totals .live-ttc{color:var(--purple);font-size:15px}.line-live{text-align:right;font-variant-numeric:tabular-nums;color:var(--muted);font-size:13px;padding-right:8px!important}.inv-bank{color:#555;margin-top:2mm;font-size:8.5pt}.inv-fill{flex:1}.qr-bill{color:#000;background:#fff;border-top:.2mm dashed #888;width:210mm;height:105mm;margin-left:-16mm;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;display:flex}.qr-receipt{border-right:.2mm dashed #888;flex-direction:column;width:62mm;padding:5mm;display:flex}.qr-payment{gap:5mm;width:148mm;padding:5mm;display:flex}.qr-payment-left{width:51mm}.qr-payment-right{flex:1}.qr-title{margin-bottom:3mm;font-size:11pt;font-weight:700}.qr-heading{font-size:6pt;font-weight:700;line-height:1.3}.qr-receipt .qr-heading{font-size:6pt}.qr-payment .qr-heading{font-size:8pt}.qr-value{font-size:8pt;line-height:1.35}.qr-receipt .qr-value{font-size:8pt}.qr-payment .qr-value{font-size:10pt}.qr-block{margin-bottom:2.5mm}.qr-amount-row{gap:5mm;margin-top:auto;display:flex}.qr-receipt .qr-amount-row{margin-top:auto;margin-bottom:4mm}.qr-acceptance{text-align:right;font-size:6pt;font-weight:700}.qr-code-wrap{width:46mm;height:46mm;margin:1mm 0 3mm;position:relative}.qr-code svg{width:46mm;height:46mm;display:block}.qr-cross{width:7mm;height:7mm;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.qr-empty-field{border:.2mm solid #000;margin-top:1mm}.qr-page-note{color:#555;font-size:9pt}.sheet.sheet-po{padding:0}.sheet.sheet-po img{object-fit:contain;width:210mm;height:297mm;display:block}@page{size:A4 portrait;margin:0}@media print{body{background:#fff}.no-print,.topnav{display:none!important}.sheet-wrap{zoom:1!important}.main{max-width:none;margin:0;padding:0}.sheet-wrap{gap:0}.sheet{box-shadow:none;width:210mm;min-height:296mm}.sheet+.sheet{page-break-before:always}.qr-bill{break-inside:avoid;page-break-inside:avoid}.sheet.sheet-po img{height:296mm}[contenteditable=true]:hover,[contenteditable=true]:focus{background:0 0}}
