.topbar-icon-btn{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-width:46px;padding:5px 6px;border-radius:8px;color:var(--grey-500);text-decoration:none;transition:background .15s,color .15s;flex-shrink:0;position:relative;font-size:.62rem;font-weight:600;letter-spacing:.01em;line-height:1;}
.topbar-icon-btn:hover,.topbar-icon-btn.active{background:var(--grey-100);color:var(--psg-navy);}
.topbar-icon-btn svg{width:22px;height:22px;flex-shrink:0;}
.topbar-sep{width:1px;height:36px;background:var(--grey-200);margin:0 4px;flex-shrink:0;}
.topbar-user-trigger{display:flex;align-items:center;gap:7px;cursor:pointer;padding:6px 10px;border-radius:8px;color:var(--grey-700);font-size:.875rem;font-weight:500;position:relative;transition:background .15s;white-space:nowrap;user-select:none;}
.topbar-user-trigger:hover{background:var(--grey-100);}
.topbar-user-trigger>.u-icon{width:18px;height:18px;color:var(--grey-400);flex-shrink:0;}
.topbar-user-trigger>.chevron{width:14px;height:14px;color:var(--grey-400);transition:transform .2s;flex-shrink:0;}
.topbar-user-trigger.open>.chevron{transform:rotate(180deg);}
.topbar-user-dd{display:none;position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid var(--grey-200);border-radius:10px;padding:8px;min-width:190px;box-shadow:0 8px 24px rgba(0,0,0,.1);z-index:1000;}
.topbar-user-dd.open{display:block;}
.topbar-user-dd-role{padding:8px 10px 6px;font-size:.7rem;color:var(--grey-400);font-weight:600;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--grey-100);margin-bottom:4px;}
.topbar-user-dd a{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;color:var(--grey-600);text-decoration:none;font-size:.875rem;transition:background .15s,color .15s;}
.topbar-user-dd a:hover{background:var(--grey-100);color:var(--grey-900);}
.topbar-user-dd a svg{width:16px;height:16px;}

/* ── full-viewport lock ── */
html,body{height:100%;overflow:hidden;}
.app{height:100vh;overflow:hidden;}
.main{height:100vh;min-height:0;overflow:hidden;display:flex;flex-direction:column;}
.cpt-shell{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden;}

/* ── page header ── */
.cpt-page-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-8) 0;flex-shrink:0;gap:var(--space-3);}
.cpt-page-kicker{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--psg-gold-dark,#b8860b);margin-bottom:2px;}
.cpt-page-title{font-size:1.5rem;font-weight:900;color:var(--psg-navy);margin:0;line-height:1.1;}
.cpt-page-sub{font-size:.8rem;color:var(--grey-400);font-weight:600;margin-top:3px;}

/* ── tabs — floating card like cmd-stats ── */
.cpt-tabs{display:flex;gap:2px;padding:0 var(--space-5);border-bottom:2px solid var(--grey-100);background:#fff;flex-shrink:0;margin:var(--space-5) var(--space-8) 0;border-radius:10px;border:1px solid #d9d9d9;}
.cpt-tab{padding:12px 16px;font-size:.8rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--grey-400);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;white-space:nowrap;display:flex;align-items:center;gap:6px;}
.cpt-tab:hover{color:var(--grey-700);}
.cpt-tab.active{color:var(--psg-navy);border-bottom-color:var(--psg-navy);}
.cpt-tab .tab-count{background:var(--grey-100);color:var(--grey-500);border-radius:999px;padding:1px 7px;font-size:.65rem;font-weight:800;}
.cpt-tab.active .tab-count{background:var(--psg-navy);color:#fff;}
#irrTab.active{color:#dc2626;border-bottom-color:#dc2626;}
#irrTab.active .tab-count{background:#dc2626;color:#fff;}
/* ── Irregularités panel ── */
.irr-row{display:grid;grid-template-columns:100px 100px minmax(0,1fr) 90px 160px 200px;gap:var(--space-3);align-items:start;padding:10px var(--space-5);border-bottom:1px solid var(--grey-50);font-size:.83rem;}
.irr-row > *{text-align:left;}
.irr-row > *:last-child{text-align:center;display:flex;flex-wrap:wrap;gap:4px;justify-content:center;}
.irr-row:hover{background:var(--grey-50);}
.irr-row.irr-resolved{opacity:.55;}
.irr-note{color:var(--grey-700);font-weight:600;line-height:1.45;word-break:break-word;}
.irr-meta{font-size:.68rem;color:var(--grey-400);font-weight:600;margin-top:2px;}

/* ── scrollable panels area ── */
.cpt-panels-wrap{flex:1;min-height:0;overflow-y:auto;background:var(--grey-100);padding:var(--space-5) var(--space-8);}
.cpt-panel{display:none;}
.cpt-panel.active{display:block;}

/* stat tiles */
.cpt-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-3);margin-bottom:var(--space-5);}
.cpt-stat{background:#fff;border:1px solid #d9d9d9;border-radius:12px;padding:var(--space-4);position:relative;overflow:hidden;}
.cpt-stat::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--sa,var(--psg-navy));opacity:.3;}
.cpt-stat-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--grey-500);}
.cpt-stat-value{font-size:1.2rem;font-weight:800;color:var(--psg-navy);margin-top:5px;}

/* bills table */
.bl-table{width:100%;border-collapse:collapse;font-size:.875rem;}
.bl-table th{padding:10px 14px;font-weight:800;font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;color:var(--grey-500);border-bottom:2px solid var(--grey-100);text-align:left;white-space:nowrap;}
.bl-table td{padding:10px 14px;border-bottom:1px solid var(--grey-50);vertical-align:middle;color:var(--grey-700);font-weight:600;}
.bl-table tbody tr:hover{background:var(--grey-50);}
.bl-table tbody tr:last-child td{border-bottom:0;}
.bl-ref{font-weight:800;color:var(--psg-navy);font-family:monospace;font-size:.82rem;}
.status-badge{display:inline-flex;align-items:center;border-radius:999px;padding:2px 9px;font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;}
.status-pending{background:#fef3c7;color:#92400e;}
.status-paid{background:#dcfce7;color:#166534;}
.status-cancelled{background:var(--grey-100);color:var(--grey-400);}
.bl-actions{display:flex;gap:5px;}
.bl-empty{padding:60px;text-align:center;color:var(--grey-400);font-weight:700;}

/* filters toolbar */
.cpt-toolbar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0 var(--space-4);flex-wrap:wrap;}

.btn-sm{padding:var(--space-2) var(--space-3);}

/* coming soon */
.coming-soon{padding:80px;text-align:center;}
.coming-soon svg{width:48px;height:48px;color:var(--grey-200);margin-bottom:16px;}
.coming-soon-title{font-size:1rem;font-weight:800;color:var(--grey-400);margin:0 0 8px;}
.coming-soon-sub{font-size:.85rem;color:var(--grey-300);font-weight:600;}

/* modal */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:900;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal-box{background:#fff;border-radius:14px;max-width:620px;width:92%;max-height:92vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2);}
.modal-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);background:#f1f5f999;padding:9px 15px;flex-shrink:0;margin:20px 20px 0 20px;border-bottom:0;}
.modal-title{font-size:.88rem;font-weight:900;text-transform:uppercase;letter-spacing:.05em;color:var(--psg-navy);margin:0;}
.modal-close{background:none;border:none;cursor:pointer;color:var(--grey-400);display:flex;align-items:center;padding:4px;border-radius:6px;}
.modal-close:hover{background:var(--grey-200);color:var(--grey-700);}
.modal-close svg{width:16px;height:16px;}
.modal-body{padding:var(--space-5);}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:8px;background:none;}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);}
.form-grid-2 .span-2{grid-column:1/-1;}
.form-label{display:block;font-size:.75rem;font-weight:700;color:var(--grey-600);margin-bottom:4px;}
.form-hint{font-size:.7rem;color:var(--grey-400);margin-top:3px;font-weight:600;}

/* order lines */
.order-lines{display:grid;gap:var(--space-2);}
.order-line-row{display:grid;grid-template-columns:1fr 140px 28px;gap:var(--space-2);align-items:center;}
.btn-rm{background:none;border:1px solid var(--grey-200);border-radius:5px;cursor:pointer;width:28px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--grey-400);}
.btn-rm:hover{background:#fee2e2;color:#dc2626;border-color:#fca5a5;}
.amount-check{font-size:.72rem;font-weight:700;margin-top:4px;}
.amount-ok{color:#16a34a;}.amount-err{color:#dc2626;}

@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* rapprochement */
.rapp-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-3);margin-bottom:var(--space-5);}
.rapp-stat{background:#fff;border:1px solid #d9d9d9;border-radius:12px;padding:var(--space-4);position:relative;overflow:hidden;}
.rapp-stat::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--sa,var(--psg-navy));opacity:.3;}
.rapp-stat-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--grey-500);}
.rapp-stat-value{font-size:1.2rem;font-weight:800;color:var(--psg-navy);margin-top:5px;}
.rapp-section-title{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--grey-500);padding:10px var(--space-5);border-bottom:1px solid var(--grey-100);background:var(--grey-50);}
.rapp-line-row{display:grid;grid-template-columns:100px 120px 1fr 120px auto;gap:var(--space-3);align-items:center;padding:10px var(--space-5);border-bottom:1px solid var(--grey-50);font-size:.85rem;}
.rapp-line-row:hover{background:var(--grey-50);}
.rapp-line-row:last-child{border-bottom:0;}
.rapp-amount-in{font-weight:800;color:#16a34a;}
.rapp-amount-out{font-weight:800;color:#dc2626;}
.rapp-desc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--grey-700);font-weight:600;}
.rapp-hint{font-size:.68rem;font-weight:700;background:#dbeafe;color:#1e40af;border-radius:999px;padding:1px 7px;display:inline-flex;align-items:center;white-space:nowrap;}
.rapp-empty{padding:30px var(--space-5);text-align:center;color:var(--grey-300);font-weight:700;font-size:.85rem;}

/* lines modal enrichments */
.lines-rec-summary{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--grey-100);border-bottom:2px solid var(--grey-100);}
.lines-rec-cell{padding:10px 16px;background:#fff;font-size:.78rem;font-weight:700;}
.lines-rec-cell-label{font-size:.6rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--grey-400);display:block;margin-bottom:3px;}
.lines-rec-ok{color:#166534;}.lines-rec-warn{color:#b45309;}.lines-rec-err{color:#991b1b;}
.lines-filter-tabs{display:flex;gap:0;border-bottom:2px solid var(--grey-100);}
.lines-filter-tab{padding:8px 16px;font-size:.72rem;font-weight:800;cursor:pointer;color:var(--grey-400);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;}
.lines-filter-tab.active{color:var(--psg-navy);border-bottom-color:var(--psg-navy);}
.linked-chip{display:inline-flex;align-items:center;gap:3px;border-radius:5px;padding:2px 7px;font-size:.68rem;font-weight:800;text-decoration:none;white-space:nowrap;}
.linked-chip-order{background:#dbeafe;color:#1e40af;}.linked-chip-order:hover{background:#bfdbfe;}
.linked-chip-bill{background:#f3e8ff;color:#6b21a8;}.linked-chip-bill:hover{background:#e9d5ff;}
.rapp-link-btn{font-size:.68rem;font-weight:800;padding:2px 8px;border:1px solid var(--grey-200);border-radius:5px;background:#fff;cursor:pointer;color:var(--grey-600);white-space:nowrap;}
.rapp-link-btn:hover{background:var(--psg-navy);color:#fff;border-color:var(--psg-navy);}
/* bulk monetico modal */
.bulk-preview-table{width:100%;border-collapse:collapse;font-size:.78rem;}
.bulk-preview-table th{padding:7px 10px;font-weight:800;font-size:.6rem;text-transform:uppercase;letter-spacing:.04em;color:var(--grey-400);border-bottom:2px solid var(--grey-100);text-align:left;}
.bulk-preview-table td{padding:7px 10px;border-bottom:1px solid var(--grey-50);vertical-align:middle;}
.bulk-ok{color:#166534;font-weight:800;}.bulk-warn{color:#b45309;font-weight:800;}.bulk-err{color:#dc2626;font-weight:800;}
/* rapprochement modal */
.rapp-modal-info{background:var(--grey-50);border-radius:8px;padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);display:flex;gap:var(--space-4);flex-wrap:wrap;font-size:.82rem;}
.rapp-info-item{display:flex;flex-direction:column;gap:2px;}
.rapp-info-label{font-size:.62rem;font-weight:800;text-transform:uppercase;color:var(--grey-400);}
.rapp-info-value{font-weight:800;color:var(--psg-navy);}
.rapp-select-table{width:100%;border-collapse:collapse;font-size:.82rem;}
.rapp-select-table th{padding:7px 10px;font-weight:800;font-size:.62rem;text-transform:uppercase;letter-spacing:.04em;color:var(--grey-400);border-bottom:2px solid var(--grey-100);text-align:left;position:sticky;top:0;background:#fff;}
.rapp-select-table td{padding:7px 10px;border-bottom:1px solid var(--grey-50);vertical-align:middle;}
.rapp-select-table tbody tr:hover{background:var(--grey-50);}
.rapp-select-table tbody tr.row-selected{background:#f0fdf4;}
.rapp-cb{width:15px;height:15px;cursor:pointer;accent-color:var(--psg-navy);}
.rapp-total-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-radius:8px;margin-top:var(--space-3);font-size:.85rem;font-weight:800;}
.rapp-total-ok{background:#dcfce7;color:#166534;}
.rapp-total-warn{background:#fef3c7;color:#92400e;}
.rapp-total-over{background:#fee2e2;color:#991b1b;}
.rapp-date-filters{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);}
/* custom link category badges */
.custom-cat{display:inline-flex;border-radius:999px;padding:2px 8px;font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;}
.custom-cat-charges_sociales{background:#fef3c7;color:#b45309;}
.custom-cat-commission{background:#dbeafe;color:#1e40af;}
.custom-cat-ecart{background:#f3f4f6;color:#6b7280;}
.custom-cat-divers{background:#f0fdf4;color:#166534;}
/* OUT tabs */
.rapp-out-tabs{display:flex;gap:0;border-bottom:2px solid var(--grey-100);margin-bottom:var(--space-3);flex-wrap:wrap;}
.rapp-out-tab{padding:7px 13px;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--grey-400);cursor:pointer;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;background:none;transition:color .15s,border-color .15s;white-space:nowrap;}
.rapp-out-tab:hover{color:var(--grey-700);}
.rapp-out-tab.active{color:var(--psg-navy);border-bottom-color:var(--psg-navy);}
.rapp-out-panel{display:none;}
.rapp-out-panel.active{display:block;}

/* import tabs inside modal */
.imp-tabs{display:flex;gap:2px;border-bottom:2px solid var(--grey-100);margin-bottom:0;}
.imp-tab{padding:8px 14px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--grey-400);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;}
.imp-tab:hover{color:var(--grey-700);}
.imp-tab.active{color:var(--psg-navy);border-bottom-color:var(--psg-navy);}
.imp-panel{display:none;}.imp-panel.active{display:block;}

/* import drop zone (file, not PDF) */
.import-drop{border-radius:10px;border:2px dashed var(--grey-200);background:var(--grey-50);transition:border-color .15s,background .15s;cursor:pointer;margin-bottom:var(--space-3);}
.import-drop:hover,.import-drop.drag-over{border-color:var(--psg-gold);background:rgba(64,174,240,.04);}
.import-drop.has-file{border-style:solid;border-color:#16a34a;background:#f0fdf4;}
.import-drop-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:24px 16px;cursor:pointer;text-align:center;}
.import-drop-label svg{width:28px;height:28px;color:var(--grey-300);transition:color .15s;}
.import-drop:hover .import-drop-label svg,.import-drop.drag-over .import-drop-label svg,.import-drop.has-file .import-drop-label svg{color:#16a34a;}
.import-drop-text{font-size:.85rem;font-weight:700;color:var(--grey-600);}
.import-drop.has-file .import-drop-text{color:#166534;}
.import-drop-hint{font-size:.7rem;color:var(--grey-400);font-weight:500;}

/* preview table */
.preview-wrap{max-height:280px;overflow-y:auto;border:1px solid var(--grey-100);border-radius:8px;margin-bottom:var(--space-3);}
.preview-table{width:100%;border-collapse:collapse;font-size:.78rem;}
.preview-table th{padding:7px 10px;font-weight:800;font-size:.62rem;text-transform:uppercase;letter-spacing:.04em;color:var(--grey-400);border-bottom:2px solid var(--grey-100);text-align:left;position:sticky;top:0;background:#fff;}
.preview-table td{padding:6px 10px;border-bottom:1px solid var(--grey-50);vertical-align:middle;}
.preview-table tbody tr:hover{background:var(--grey-50);}
.preview-table tbody tr.deselected{opacity:.35;text-decoration:line-through;}
.import-summary{display:flex;gap:var(--space-4);font-size:.78rem;font-weight:700;margin-bottom:var(--space-3);flex-wrap:wrap;}
.import-summary span{display:inline-flex;align-items:center;gap:5px;}

/* file drop */
.file-drop{border-radius:10px;border:2px dashed var(--grey-200);background:var(--grey-50);transition:border-color .15s,background .15s;cursor:pointer;}
.file-drop:hover,.file-drop.drag-over{border-color:var(--psg-gold);background:rgba(64,174,240,.04);}
.file-drop.has-file{border-style:solid;border-color:var(--psg-gold);background:rgba(64,174,240,.06);}
.file-drop-input{display:none;}
.file-drop-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:22px 12px;cursor:pointer;text-align:center;}
.file-drop-label svg{width:24px;height:24px;color:var(--grey-300);transition:color .15s;}
.file-drop:hover .file-drop-label svg,.file-drop.drag-over .file-drop-label svg,.file-drop.has-file .file-drop-label svg{color:var(--psg-gold);}
.file-drop-text{font-size:.82rem;font-weight:700;color:var(--grey-600);}
.file-drop.has-file .file-drop-text{color:var(--psg-navy);}
.file-drop-hint{font-size:.7rem;color:var(--grey-400);font-weight:500;}

@media(max-width:900px){.cpt-stats{grid-template-columns:repeat(2,1fr);}}
