:root{--primary-color:#0d3c6c;--secondary-color:#eee;--text-color:#333;--font-family:'Helvetica Neue',Arial,sans-serif;--border-color:#e0e0e0;--hover-color:#e9f0f8;--accent-bg:#f5f6fa;--btn-bg:var(--primary-color);--btn-hover:#085086;--white:#fff}
*{margin:0;padding:0;box-sizing:border-box}
.login-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:var(--secondary-color)}
.login-card{background:var(--white);padding:2rem;border-radius:12px;box-shadow:0 4px 20px #0000001a;width:100%;max-width:400px;text-align:center}
.login-card img.logo{height:80px;margin-bottom:1rem}
.login-card h2{margin-bottom:1.5rem;color:var(--primary-color)}
.login-card input{width:100%;padding:12px;margin:.6rem 0;border:1px solid var(--border-color);border-radius:8px;font-size:1rem}
.login-card input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #0d3c6c1a;outline:none}
.login-card button{width:100%;margin-top:1rem}
body{font-family:var(--font-family);background-color:var(--secondary-color);color:var(--text-color);line-height:1.6}
header{display:flex;justify-content:space-between;align-items:center;background-color:var(--white);padding:0 20px;border-bottom:2px solid var(--primary-color);height:80px}
header .logo img{height:60px}
nav ul{list-style:none;display:flex;gap:1rem}
nav ul li a{text-decoration:none;color:var(--primary-color);font-weight:700;padding:10px;transition:color .3s}
nav ul li a:hover,nav ul li a.active{color:var(--text-color)}
main{padding:2rem;background-color:var(--white);box-shadow:0 0 10px #0000000d;border-radius:8px;max-width:95%;width:1500px;margin:2rem auto;overflow-x:auto}
footer{text-align:center;padding:10px;margin-top:40px;font-size:.9rem;color:var(--text-color);border-top:1px solid #ccc}
.btn-primary,#add-client,#add-adherent,#upload-btn,.btn-delete,.btn-edit,.btn-save,.btn-cancel{background-color:var(--btn-bg);color:var(--white);border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease,opacity .2s ease,transform .05s ease}
.btn-primary:hover,#add-client:hover,#add-adherent:hover,#upload-btn:hover,.btn-delete:hover,.btn-edit:hover,.btn-save:hover,.btn-cancel:hover{background-color:var(--btn-hover)}
.btn-primary{padding:10px 16px;font-size:1rem}
.btn-primary:active{transform:translateY(1px)}
#add-client,#add-adherent{display:block;margin:1rem auto;padding:8px 16px;font-size:1rem}
#add-client .plus-icon{color:#fff;font-weight:700;margin-right:6px;font-size:1.2rem}
#add-adherent::before{content:"+";color:#fff;font-weight:700;margin-right:6px;font-size:1.2rem}
#add-user .plus-icon{color:#fff;font-weight:700;margin-right:6px;font-size:1.2rem}
.msg{padding:10px;margin:15px 0;border:1px solid var(--border-color);background:var(--white);color:var(--text-color);font-size:.95rem;border-radius:6px}
#filters{margin:1rem 0 2rem;display:flex;gap:1.5rem;align-items:center;flex-wrap:wrap}
#filters {margin: 1rem 0 2rem;display: flex;flex-wrap: wrap;gap: 1.5rem;align-items: flex-start;}
#filters label {display: block; font-weight: 700;font-size: 0.95rem;margin-bottom: 0.3rem;}
#filters select {display: block;padding: 6px 10px;border: 1px solid var(--border-color);border-radius: 6px;font-size: 0.95rem;width: 200px;background: #fff;}
.table-clients,.table-adherents,.table-bi{width:100%;max-width:100%;border-collapse:collapse;background-color:var(--white);box-shadow:0 0 8px #0000000d}
.table-clients th,.table-clients td,.table-adherents th,.table-adherents td,.table-bi th,.table-bi td{padding:12px 15px;border:1px solid var(--border-color);text-align:center;font-size:.95rem}
.table-clients th,.table-adherents th,.table-bi th{background-color:var(--primary-color);color:var(--white);text-transform:uppercase;letter-spacing:.05em}
.table-clients tr:nth-child(even),.table-adherents tr:nth-child(even),.table-bi tr:nth-child(even){background-color:var(--accent-bg)}
.table-clients tr:hover,.table-adherents tr:hover,.table-bi tr:hover{background-color:var(--hover-color)}
.table-clients th:last-child,.table-clients td:last-child,.table-adherents th:last-child,.table-adherents td:last-child,.table-bi th:last-child,.table-bi td:last-child{width:220px;white-space:nowrap;text-align:center;vertical-align:middle}
.btn-group{display:inline-flex;flex-wrap:nowrap;gap:6px;justify-content:center;align-items:center;white-space:nowrap}
.btn-group button{display:inline-block;padding:6px 10px;font-size:14px;border-radius:6px}
#table-scroll{max-height:600px;overflow-y:auto;border:1px solid var(--border-color);border-radius:6px;box-shadow:inset 0 0 4px #0000000d;margin-bottom:1rem}
.table-clients th.sortable,.table-adherents th.sortable{position:relative;cursor:pointer;user-select:none;white-space:nowrap;padding-right:30px!important;background-repeat:no-repeat;background-position:right 10px center;background-size:10px 14px;background-image:url("data:image/svg+xml;utf8,\ <svg xmlns='http://www.w3.org/2000/svg' width='10' height='14' viewBox='0 0 10 14' fill='none'>\ <path d='M5 2 L8 5 H2 Z' fill='%2399b0c7'/>\ <path d='M5 12 L2 9 H8 Z' fill='%2399b0c7'/>\ </svg>")}
.table-clients th.sortable.asc,.table-adherents th.sortable.asc{background-image:url("data:image/svg+xml;utf8,\ <svg xmlns='http://www.w3.org/2000/svg' width='10' height='14' viewBox='0 0 10 14' fill='none'>\ <path d='M5 2 L8 5 H2 Z' fill='%23ffffff'/>\ <path d='M5 12 L2 9 H8 Z' fill='%2399b0c7'/>\ </svg>")}
.table-clients th.sortable.desc,.table-adherents th.sortable.desc{background-image:url("data:image/svg+xml;utf8,\ <svg xmlns='http://www.w3.org/2000/svg' width='10' height='14' viewBox='0 0 10 14' fill='none'>\ <path d='M5 2 L8 5 H2 Z' fill='%2399b0c7'/>\ <path d='M5 12 L2 9 H8 Z' fill='%23ffffff'/>\ </svg>")}
.table-clients th.sortable:hover,.table-adherents th.sortable:hover{filter:brightness(1.05)}
.table-clients th,.table-clients td,.table-adherents th,.table-adherents td{text-align:center!important}
.table-clients tr:nth-child(even),.table-adherents tr:nth-child(even){background-color:var(--accent-bg)}
.table-clients tr:hover,.table-adherents tr:hover{background-color:var(--hover-color)}
.table-clients th:last-child,.table-clients td:last-child,.table-adherents th:last-child,.table-adherents td:last-child{width:220px;white-space:nowrap;text-align:center;vertical-align:middle}
.table-clients .btn-group,.table-adherents .btn-group{display:inline-flex;gap:6px;justify-content:center;align-items:center;white-space:nowrap}
#uploader{display:grid;gap:1rem}
#dropzone{border:2px dashed var(--primary-color);background:#f7fbff;border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:background .2s ease}
#dropzone.dz-hover{background:#e9f3ff}
.btn-like{display:inline-block;margin-top:.5rem;background-color:var(--btn-bg);color:#fff;padding:8px 14px;border-radius:6px;cursor:pointer}
#selected-files.card{background:#fff;border:1px solid var(--border-color);border-radius:8px;padding:1rem}
#file-list{list-style:none;margin-top:.5rem}
#file-list li{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;border-bottom:1px dashed #eee}
#file-list .btn-x{background:#c0392b;color:#fff;border:none;border-radius:4px;padding:2px 6px;cursor:pointer}
#upload-btn{display:inline-block;width:fit-content;margin:.5rem 0 0;padding:10px 16px}
#upload-btn:disabled{opacity:.6;cursor:not-allowed}
body .controler-wrap,/* si jamais tu ajoutes un wrapper */
#bi-list{max-width:960px;margin:0 auto}
.bi-title{font-weight:700;font-size:1rem;color:var(--primary-color);margin-bottom:.25rem;text-align:center;word-break:break-word}
.bi-card{background:var(--white);border:1px solid var(--border-color);border-radius:12px;padding:1rem 1.25rem;box-shadow:0 2px 8px #0000000a;display:grid;gap:1rem}
.bi-img-wrap{display:flex;justify-content:center}
.bi-img{max-width:100%;max-height:420px;object-fit:contain;display:block;border:1px solid var(--border-color);border-radius:8px}
.bi-form{display:grid;gap:1rem}
.bi-grid{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:.9rem 1rem}
.bi-field label{display:flex;flex-direction:column;font-weight:600;gap:6px;color:var(--text-color)}
.bi-field input[type="text"],.bi-field input[type="date"]{padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;background:#fff}
.bi-checks{display:flex;gap:1rem;flex-wrap:wrap}
.bi-checks .check{display:inline-flex;align-items:center;gap:.5rem;font-weight:500}
.bi-actions{display:flex;align-items:center;gap:.75rem}
.bi-counter{margin-left:auto;font-size:.9rem;color:#555}
body.controler-one main,/* si tu veux activer via classe body=controler-one */
main.controler-one{max-height:85vh;overflow:auto}
.text-center{text-align:center}
.mt-1{margin-top:.5rem}
.mt-2{margin-top:1rem}
.mt-3{margin-top:1.5rem}
main.controler-one #bi-list{max-width:960px;margin:0 auto}
main.controler-one .bi-card{background:var(--white);border:1px solid var(--border-color);border-radius:12px;padding:1.25rem;box-shadow:0 2px 8px #0000000f;display:grid;gap:1rem}
main.controler-one .bi-title{font-weight:700;font-size:1rem;color:var(--primary-color);text-align:center;word-break:break-word}
main.controler-one .bi-img-wrap{display:flex;justify-content:center}
main.controler-one .bi-img{max-width:100%;max-height:420px;object-fit:contain;display:block;border:1px solid var(--border-color);border-radius:8px}
main.controler-one .bi-form{display:grid;gap:1rem;background:var(--white);border:1px solid var(--border-color);border-radius:10px;padding:1rem}
main.controler-one .bi-grid{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:1rem}
main.controler-one .bi-field > label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:var(--text-color)}
main.controler-one .bi-field input[type="text"],main.controler-one .bi-field input[type="date"]{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;background:#fff;outline:none}
main.controler-one .bi-field input[type="text"]:focus,main.controler-one .bi-field input[type="date"]:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #0d3c6c1a}
main.controler-one .bi-checks{display:flex;gap:1rem;flex-wrap:wrap}
main.controler-one .bi-checks .check{display:inline-flex;align-items:center;gap:.5rem;font-weight:500}
main.controler-one .bi-actions{display:flex;align-items:center;gap:.75rem}
main.controler-one .bi-actions .btn-primary{background-color:var(--btn-bg);color:#fff;border:none;padding:10px 16px;border-radius:8px;font-size:1rem;cursor:pointer;transition:background-color .2s ease,transform .05s ease}
main.controler-one .bi-actions .btn-primary:hover{background-color:var(--btn-hover)}
main.controler-one .bi-actions .btn-primary:active{transform:translateY(1px)}
main.controler-one .bi-actions .bi-counter{margin-left:auto;font-size:.9rem;color:#555}
main.controler-one{max-height:85vh;overflow:auto}
.lightbox-overlay{position:fixed;inset:0;background:#000000a6;display:none;justify-content:center;align-items:center;z-index:9999}
.lightbox-content{position:relative;max-width:92vw;max-height:92vh;display:flex;justify-content:center;align-items:center}
.lightbox-content img{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:0 10px 30px #00000059}
.lightbox-close{position:absolute;top:-12px;right:-12px;background:var(--primary-color);color:#fff;border:none;width:32px;height:32px;line-height:28px;font-size:22px;border-radius:50%;cursor:pointer;box-shadow:0 2px 8px #00000040}
.lightbox-close:hover{background:var(--btn-hover)}
.bi-field.bi-check label{display:flex;align-items:center;gap:6px;font-weight:400}
.bi-actions{display:flex;justify-content:space-between;align-items:center;margin-top:1rem}
.bi-nav{display:flex;gap:10px;align-items:center}
.btn-nav{background:var(--btn-bg);color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:1rem;cursor:pointer}
.btn-nav:hover{background:var(--btn-hover)}
.btn-danger{background-color:#c0392b;color:#fff;border:none;border-radius:6px;padding:10px 16px;font-size:1rem;cursor:pointer;transition:background-color .2s ease,transform .05s ease}
.btn-danger:hover{background-color:#a93226}
.btn-danger:active{transform:translateY(1px)}
.bi-actions{gap:.75rem}
.bi-field input[type="text"],.bi-field input[type="date"]{height:38px;padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;box-sizing:border-box}
.bi-field select{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:block;width:100%;height:38px;line-height:38px;padding:0 36px 0 12px;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;background-color:#fff;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='10' viewBox='0 0 20 12' fill='%230d3c6c'><path d='M2 2l8 8 8-8'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:14px 10px;box-sizing:border-box;cursor:pointer}
.bi-field select::-ms-expand{display:none}
.bi-field select:focus,.bi-field input[type="text"]:focus,.bi-field input[type="date"]:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #0d3c6c1a;outline:none}
.chips{display:grid;gap:.5rem}
.chips-list{display:flex;flex-wrap:wrap;gap:.4rem}
.chip{background:var(--accent-bg);color:var(--text-color);border:1px solid var(--border-color);border-radius:999px;padding:6px 10px;font-size:.9rem;display:inline-flex;align-items:center;gap:.5rem}
.chip .chip-x{background:transparent;border:none;color:#666;font-size:16px;line-height:1;cursor:pointer}
.chip .chip-x:hover{color:#000}
.chips-input-row{display:flex;gap:.5rem;align-items:center}
.chips-input{flex:1;height:38px;padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;background:#fff;font-size:.95rem}
.chips-add{padding:8px 12px}
.chips-manage{padding:8px 12px}
.chips-suggestions{position:relative;z-index:2;border:1px solid var(--border-color);background:#fff;border-radius:8px;box-shadow:0 8px 20px #0000000f;max-height:220px;overflow:auto}
.chips-suggestion-item{padding:8px 12px;cursor:pointer}
.chips-suggestion-item:hover{background:var(--hover-color)}
.chips-wrap{position:relative}
.chips-box{display:flex;flex-wrap:wrap;gap:6px;align-items:center;min-height:38px;border:1px solid var(--border-color);border-radius:8px;padding:6px 8px;background:#fff}
.chips-input{border:none;outline:none;flex:1;min-width:160px;font-size:.95rem}
.chip{display:inline-flex;align-items:center;gap:6px;background:#e9f0f8;color:#0d3c6c;padding:4px 8px;border-radius:999px;font-weight:600}
.chip-x{border:none;background:transparent;color:#0d3c6c;cursor:pointer;font-size:14px;line-height:1}
.chips-suggestions{position:absolute;left:0;right:0;z-index:10;background:#fff;border:1px solid var(--border-color);border-radius:8px;margin-top:6px;max-height:220px;overflow:auto;box-shadow:0 6px 20px #00000014}
.chips-suggestion{padding:8px 10px;cursor:pointer}
.chips-suggestion:hover{background:#f4f8ff}
#panel-bi-attendus .filters-row select,#panel-bi-attendus .filters-row input[type="date"]{display:block;height:38px;line-height:38px;padding:0 12px;border:1px solid var(--border-color);border-radius:8px;font-size:.95rem;background-color:#fff;box-sizing:border-box;cursor:pointer;flex:0 0 auto;width:220px}
#panel-bi-attendus .filters-row{display:flex;flex-wrap:nowrap;gap:1.25rem;align-items:flex-end;overflow-x:auto;margin-bottom:2.5rem}
#panel-bi-attendus .filters-row select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:36px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='10' viewBox='0 0 20 12' fill='%230d3c6c'><path d='M2 2l8 8 8-8'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:14px 10px}
#panel-bi-attendus .filters-row select:focus,#panel-bi-attendus .filters-row input[type="date"]:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #0d3c6c1a;outline:none}
#panel-bi-attendus .filters-row label{flex:0 0 auto}
#panel-bi-attendus .table,#panel-bi-attendus .table-bi{width:100%;max-width:100%;border-collapse:collapse;background-color:var(--white);box-shadow:0 0 8px #0000000d}
#panel-bi-attendus .table th,#panel-bi-attendus .table td,#panel-bi-attendus .table-bi th,#panel-bi-attendus .table-bi td{padding:12px 15px;border:1px solid var(--border-color);text-align:center;font-size:.95rem}
#panel-bi-attendus .table thead th,#panel-bi-attendus .table-bi thead th{position:sticky;top:0;z-index:1;background-color:var(--primary-color);color:var(--white);text-transform:uppercase;letter-spacing:.05em}
#panel-bi-attendus .table tbody tr:nth-child(even),#panel-bi-attendus .table-bi tbody tr:nth-child(even){background-color:var(--accent-bg)}
#panel-bi-attendus .table tbody tr:hover,#panel-bi-attendus .table-bi tbody tr:hover{background-color:var(--hover-color)}
#panel-bi-attendus .table-wrap{max-height:600px;overflow:auto;border:1px solid var(--border-color);border-radius:6px;box-shadow:inset 0 0 4px #0000000d;margin-bottom:1rem}
#panel-bi-attendus #bi-attendus-table td:nth-child(5),#panel-bi-attendus #bi-attendus-table td:nth-child(6),#panel-bi-attendus #bi-attendus-table td:nth-child(7){text-align:right}
.table-clients .btn-edit,.table-clients .btn-delete,.table-clients .btn-save,.table-clients .btn-cancel,.table-adherents .btn-edit,.table-adherents .btn-delete,.table-adherents .btn-save,.table-adherents .btn-cancel,.table-clients a.btn-edit,.table-clients a.btn-delete,.table-clients a.btn-save,.table-clients a.btn-cancel,.table-adherents a.btn-edit,.table-adherents a.btn-delete,.table-adherents a.btn-save,.table-adherents a.btn-cancel{display:inline-block;background-color:var(--btn-bg);color:var(--white);border:none;border-radius:6px;padding:6px 10px;font-size:14px;text-decoration:none;cursor:pointer;transition:background-color .2s ease,opacity .2s ease,transform .05s ease;line-height:1.2;vertical-align:middle}
.table-clients .btn-edit:hover,.table-clients .btn-delete:hover,.table-clients .btn-save:hover,.table-clients .btn-cancel:hover,.table-adherents .btn-edit:hover,.table-adherents .btn-delete:hover,.table-adherents .btn-save:hover,.table-adherents .btn-cancel:hover,.table-clients a.btn-edit:hover,.table-clients a.btn-delete:hover,.table-clients a.btn-save:hover,.table-clients a.btn-cancel:hover,.table-adherents a.btn-edit:hover,.table-adherents a.btn-delete:hover,.table-adherents a.btn-save:hover,.table-adherents a.btn-cancel:hover{background-color:var(--btn-hover)}
.table-clients .btn-group,.table-adherents .btn-group{display:inline-flex;gap:6px;justify-content:center;align-items:center;white-space:nowrap}
.table-clients th:last-child,.table-clients td:last-child,.table-adherents th:last-child,.table-adherents td:last-child{width:220px;white-space:nowrap;text-align:center;vertical-align:middle}
#queue-info code{background:#f2f4f7;padding:2px 6px;border-radius:4px}
#queue-info strong{font-variant-numeric:tabular-nums}
#actions-traitement{display:flex;gap:.75rem;align-items:center}
#traitement-result{white-space:pre-wrap}
.btn-secondary{background-color:#777;color:#fff;border:none;border-radius:6px;padding:10px 16px;font-size:1rem;cursor:pointer;transition:background-color .2s ease,transform .05s ease}
.btn-secondary:hover{background-color:#555}
.btn-secondary:active{transform:translateY(1px)}
.bi-actions{display:flex;justify-content:space-between;align-items:center;gap:.75rem}
.bi-left-btns{display:flex;gap:.75rem}
#bi-attendus-table th:nth-child(3),#bi-attendus-table td:nth-child(3){display:none}
.taux-red{color:red;font-weight:700}
.taux-orange{color:orange;font-weight:700}
.taux-green{color:green;font-weight:700}
.table-actions{margin-top:1rem;display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}
.cell-missing{background-color:#ffe5b4}
#bi-attendus-table th.sortable{position:relative;cursor:pointer;user-select:none;white-space:nowrap;vertical-align:middle;padding-right:30px!important;background-repeat:no-repeat;background-position:right 10px center;background-size:10px 14px;background-image:url("data:image/svg+xml;utf8,\ <svg xmlns='http://www.w3.org/2000/svg' width='10' height='14' viewBox='0 0 10 14' fill='none'>\ <path d='M5 2 L8 5 H2 Z' fill='%23999'/>\ <path d='M5 12 L2 9 H8 Z' fill='%23999'/>\ </svg>")}
#bi-attendus-table th.sortable.asc{background-image:url("data:image/svg+xml;utf8,\ <svg xmlns='http://www.w3.org/2000/svg' width='10' height='14' viewBox='0 0 10 14' fill='none'>\ <path d='M5 2 L8 5 H2 Z' fill='%23ffffff'/>\ <path d='M5 12 L2 9 H8 Z' fill='%2399b0c7'/>\ </svg>")}
#bi-attendus-table th.sortable.desc{background-image:url("data:image/svg+xml;utf8,\ <svg xmlns='http://www.w3.org/2000/svg' width='10' height='14' viewBox='0 0 10 14' fill='none'>\ <path d='M5 2 L8 5 H2 Z' fill='%2399b0c7'/>\ <path d='M5 12 L2 9 H8 Z' fill='%23ffffff'/>\ </svg>")}
#bi-attendus-table th.sortable.text-right{text-align:right;padding-right:30px!important}
#bi-attendus-table th.sortable:hover{filter:brightness(1.05)}
.table-bi th.sortable{position:relative;cursor:pointer;user-select:none;white-space:nowrap;padding-right:30px!important;background-repeat:no-repeat;background-position:right 10px center;background-size:10px 14px;background-image:url("data:image/svg+xml;utf8,\ <svg xmlns='http://www.w3.org/2000/svg' width='10' height='14' viewBox='0 0 10 14' fill='none'>\ <path d='M5 2 L8 5 H2 Z' fill='%2399b0c7'/>\ <path d='M5 12 L2 9 H8 Z' fill='%2399b0c7'/>\ </svg>")}
.table-bi th.sortable.asc{background-image:url("data:image/svg+xml;utf8,\ <svg xmlns='http://www.w3.org/2000/svg' width='10' height='14' viewBox='0 0 10 14' fill='none'>\ <path d='M5 2 L8 5 H2 Z' fill='%23ffffff'/>\ <path d='M5 12 L2 9 H8 Z' fill='%2399b0c7'/>\ </svg>")}
.table-bi th.sortable.desc{background-image:url("data:image/svg+xml;utf8,\ <svg xmlns='http://www.w3.org/2000/svg' width='10' height='14' viewBox='0 0 10 14' fill='none'>\ <path d='M5 2 L8 5 H2 Z' fill='%2399b0c7'/>\ <path d='M5 12 L2 9 H8 Z' fill='%23ffffff'/>\ </svg>")}
table th,table td{text-align:center!important}
#bi-attendus-table th.text-right,#bi-attendus-table td.text-right{text-align:center!important}
#panel-bi-attendus #bi-attendus-table td:nth-child(5),#panel-bi-attendus #bi-attendus-table td:nth-child(6),#panel-bi-attendus #bi-attendus-table td:nth-child(7){text-align:center!important}
#traitement-result{white-space:pre-wrap;font-family:monospace;background:#f9f9f9;padding:1em;margin-top:1em;border-radius:6px;border:1px solid #ddd;max-height:300px;overflow-y:auto}
.filters-anomalies label{display:inline-block;margin-right:1rem;min-width:180px}
.bi-card{position:relative}
.bi-header{position:relative;display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}
.bi-nav-top{position:absolute;top:.5rem;right:.5rem;display:flex;align-items:center;gap:.5rem;z-index:2}
.bi-nav-top .btn-nav{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:var(--btn-bg);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:background 0.2s,transform .05s}
.bi-nav-top .btn-nav:hover{background:var(--btn-hover)}
.bi-nav-top .btn-nav:active{transform:translateY(1px)}
.bi-nav-top .bi-counter{font-weight:600;color:#333;font-size:.95rem;line-height:1;display:flex;align-items:center;height:38px}.filters-anomalies-tardifs {display: flex;flex-wrap: wrap;gap: 1.5rem;align-items: center;margin: 1rem 0 2rem 0;}
.filters-anomalies-tardifs label {font-weight: bold;font-size: 0.95rem;display: block;min-width: 180px;       /* même largeur que filtres anomalies */}
.filters-anomalies-tardifs select,
.filters-anomalies-tardifs input[type="date"] {height: 38px;line-height: 38px;padding: 0 36px 0 12px;  /* espace pour la flèche à droite */border: 1px solid var(--border-color);border-radius: 8px;font-size: 0.95rem;background-color: #fff;-webkit-appearance: none;-moz-appearance: none;appearance: none;cursor: pointer;box-sizing: border-box;}
.filters-anomalies-tardifs select {background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='10' viewBox='0 0 20 12' fill='%230d3c6c'><path d='M2 2l8 8 8-8'/></svg>");background-repeat: no-repeat;background-position: right 12px center;background-size: 14px 10px;}
.filters-anomalies-tardifs select:focus,
.filters-anomalies-tardifs input[type="date"]:focus {border-color: var(--primary-color);box-shadow: 0 0 0 3px rgba(13,60,108,0.1);outline: none;}
#f-reset-tardifs {margin-left: 0.5rem;}
#client-buttons {display: flex; align-items: center; gap: 15px; margin-top: 20px;}
#client-buttons button {background-color: #0d3c6c; color: white; border: none;border-radius: 6px;padding: 10px 16px;font-size: 15px;cursor: pointer; transition: background-color 0.2s ease, transform 0.1s ease;}
#client-buttons button:hover {background-color: #0d3c6c;transform: translateY(-1px);}
#client-buttons button:active {background-color: #0d3c6c;transform: translateY(0);}
.plus-icon,
.refresh-icon {margin-right: 8px;font-weight: bold;}
.filters-anomalies-tardifs{margin:1rem 0 2rem;display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;}
.filters-anomalies-tardifs label{display:block;margin-right:1rem;min-width:180px;font-weight:700;font-size:.95rem;}
.filters-anomalies-tardifs select,
.filters-anomalies-tardifs input[type="date"]{height:38px;line-height:38px;padding:0 12px;border:1px solid var(--border-color);border-radius:6px;font-size:.95rem;background-color:#fff;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;width:200px;}
.filters-anomalies-tardifs select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='10' viewBox='0 0 20 12' fill='%230d3c6c'><path d='M2 2l8 8 8-8'/></svg>");background-repeat:no-repeat;background-position:right 12px center;background-size:14px 10px;}
.filters-anomalies input[type="date"]{height:38px;line-height:38px;padding:0 12px;border:1px solid var(--border-color);border-radius:6px;font-size:.95rem;background:#fff;width:190px;box-sizing:border-box;}
.filters-anomalies input[type="date"]:first-of-type{margin-right:.5rem;}
.page-desc {font-size: 1rem;color: var(--text-color);margin: 1rem 0 1.5rem;line-height: 1.6;max-width: 900px;white-space: normal;}
.user-info{display:flex;align-items:center;gap:1rem;margin-left:auto}
.user-role{background:var(--primary-color);color:var(--white);padding:4px 10px;border-radius:12px;font-weight:600;text-transform:capitalize;font-size:.9rem;box-shadow:0 0 4px #0002}
.btn-logout{background-color:#c0392b;color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:.9rem;cursor:pointer;transition:background-color .2s ease,transform .05s ease}
.btn-logout:hover{background-color:#e74c3c}
.btn-logout:active{transform:translateY(1px)}
header{display:flex;align-items:center;justify-content:space-between;background-color:var(--white);padding:0 20px;border-bottom:2px solid var(--primary-color);height:80px;gap:1rem}
.msg-error{background:#ffe8e8;border:1px solid #d9534f;color:#b30000;padding:10px 15px;border-radius:6px;margin:1rem 0;font-weight:500}
#bi-actions button,#client-buttons button{min-width:180px}
.table-wrap{max-height:500px;overflow-y:auto;overflow-x:auto;margin-top:1rem;border:1px solid #ccc;border-radius:6px;background:#fff;box-shadow:0 1px 3px #0000001a}
.table-wrap table{border-collapse:collapse;width:100%;min-width:1100px}
.table-wrap th,.table-wrap td{padding:8px 12px;border:1px solid #ddd;text-align:left;white-space:nowrap}
.table-wrap thead th{position:sticky;top:0;background-color:#003366;z-index:1;font-weight:600}
.table-wrap tbody tr:nth-child(even){background:#fafafa}
.table-wrap tbody tr:hover{background:#f0f8ff}
.table-wrap::-webkit-scrollbar{height:10px;width:10px}
.table-wrap::-webkit-scrollbar-thumb{background:#bbb;border-radius:5px}
.table-wrap::-webkit-scrollbar-thumb:hover{background:#999}
nav ul{display:flex;flex-wrap:nowrap;justify-content:space-around;align-items:center;gap:8px}
nav ul li a{font-size:.9rem;white-space:nowrap;padding:6px 10px}
.table-clients .input-inline{width:95%;padding:6px 8px;border:1px solid var(--border-color);border-radius:6px;font-size:.95rem}
.table-clients .new-row td{background:#f4f8ff}
.table-clients .btn-group{display:flex;gap:6px;justify-content:center;align-items:center}
.table-clients .btn-edit,.table-clients .btn-delete,.table-clients .btn-save,.table-clients .btn-cancel{padding:6px 10px;font-size:14px}
.bi-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.bi-title{font-size:1.2rem;font-weight:700;color:#333}
.bi-nav-top{display:flex;align-items:center;gap:.5rem}
.btn-nav{background:#eee;border:none;padding:.4rem .6rem;cursor:pointer;border-radius:4px;font-size:1rem;transition:background .2s}
.btn-nav:hover{background:#ccc}
.bi-counter{font-size:.9rem;color:#555}