/* CABINET KANY v2 — Bleu #1a2a5e | Or #c9a84c | Blanc */
:root{
  --navy:#1a2a5e;--navy2:#243680;--navy3:#2e4499;
  --gold:#c9a84c;--gold2:#e0c06a;--gold3:#a07830;
  --white:#fff;--off:#f5f7fc;--gray:#e2e7f3;--gray2:#c0c8df;--gray3:#7a85a3;
  --text:#1a1a2e;--text2:#3a4060;
  --green:#1a8f4f;--red:#c0392b;--orange:#e07b20;--warn:#d4a017;
  --sb-w:265px;--tb-h:62px;--r:10px;--r2:6px;
  --sh:0 4px 24px rgba(26,42,94,.12);--sh2:0 2px 10px rgba(26,42,94,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:14.5px;scroll-behavior:smooth}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--off);color:var(--text);min-height:100vh}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--gray)}
::-webkit-scrollbar-thumb{background:var(--navy2);border-radius:3px}

.app-layout{display:flex;min-height:100vh}
.main-wrap{flex:1;margin-left:var(--sb-w);display:flex;flex-direction:column;transition:margin .3s}
.main-content{flex:1;padding:28px 28px 40px}

.sidebar{position:fixed;top:0;left:0;width:var(--sb-w);height:100vh;background:linear-gradient(180deg,var(--navy) 0%,#0f1a3d 100%);display:flex;flex-direction:column;z-index:200;overflow-y:auto;overflow-x:hidden;transition:transform .3s;box-shadow:3px 0 30px rgba(0,0,0,.35)}
.sb-logo{display:flex;align-items:center;gap:11px;padding:22px 18px 18px;border-bottom:1px solid rgba(201,168,76,.25);flex-shrink:0}
.sb-logo img{width:46px;height:46px;object-fit:contain;border-radius:8px;background:#fff;padding:3px;box-shadow:0 2px 10px rgba(0,0,0,.3)}
.sb-logo-name{display:block;color:var(--white);font-size:.82rem;letter-spacing:2px;line-height:1.1;font-weight:600}
.sb-logo-kany{display:block;color:var(--gold);font-size:1.1rem;font-weight:800;letter-spacing:2px;line-height:1.1}
.sb-nav{flex:1;padding:12px 0;overflow-y:auto}
.sb-section{font-size:.6rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gold);padding:14px 18px 5px;pointer-events:none}
.sb-link{display:flex;align-items:center;gap:11px;padding:10px 16px;margin:1px 8px;color:rgba(255,255,255,.75);border-radius:var(--r2);font-size:.88rem;font-weight:500;transition:all .2s;position:relative}
.sb-link:hover,.sb-link.active{background:linear-gradient(90deg,var(--gold) 0%,var(--gold3) 100%);color:var(--navy);font-weight:700;box-shadow:0 3px 10px rgba(201,168,76,.4)}
.sb-link i{width:20px;font-size:.95rem;flex-shrink:0}
.sb-badge{display:none;position:absolute;right:12px;top:50%;transform:translateY(-50%);background:var(--red);color:#fff;font-size:.65rem;font-weight:700;border-radius:10px;padding:1px 6px;min-width:18px;text-align:center}
.sb-footer{border-top:1px solid rgba(201,168,76,.2);padding:14px 12px;display:flex;align-items:center;gap:10px;flex-shrink:0}
.sb-avatar i{font-size:2rem;color:var(--gold)}
.sb-uname{color:#fff;font-size:.83rem;font-weight:600}
.sb-urole{color:var(--gold2);font-size:.7rem;text-transform:capitalize;margin-top:1px}
.sb-logout{margin-left:auto;color:rgba(255,255,255,.5);font-size:1.2rem;padding:6px;border-radius:6px;transition:all .2s}
.sb-logout:hover{color:var(--red);background:rgba(192,57,43,.15)}

.topbar{position:sticky;top:0;z-index:100;height:var(--tb-h);background:#fff;border-bottom:2px solid var(--gold);display:flex;align-items:center;gap:16px;padding:0 24px;box-shadow:var(--sh2);flex-shrink:0}
.sb-toggle{background:none;border:none;cursor:pointer;color:var(--navy);font-size:1.15rem;padding:6px 8px;border-radius:6px;transition:background .2s}
.sb-toggle:hover{background:var(--gray)}
.tb-title{font-size:1rem;font-weight:800;color:var(--navy);flex:1;letter-spacing:.3px}
.tb-right{display:flex;gap:14px}
.tb-contact{font-size:.78rem;color:var(--navy2);display:flex;align-items:center;gap:5px;font-weight:500}
.tb-contact:hover{color:var(--gold3)}
.tb-contact i{color:var(--gold)}

.card{background:#fff;border-radius:var(--r);box-shadow:var(--sh);margin-bottom:22px;overflow:hidden}
.card-header{background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);border-bottom:3px solid var(--gold);color:#fff;padding:13px 20px;display:flex;align-items:center;justify-content:space-between}
.card-header h2,.card-header h3{font-size:.9rem;font-weight:700;letter-spacing:.5px;display:flex;align-items:center;gap:8px}
.card-header i{color:var(--gold)}
.card-body{padding:20px}

.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:13px;margin-bottom:22px}
.stat-card{background:#fff;border-radius:var(--r);padding:17px 15px;display:flex;align-items:center;gap:14px;box-shadow:var(--sh2);border-left:4px solid var(--gold);transition:transform .2s,box-shadow .2s}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--sh)}
.stat-card.s-blue{border-color:var(--navy)}.stat-card.s-green{border-color:var(--green)}.stat-card.s-red{border-color:var(--red)}.stat-card.s-orange{border-color:var(--orange)}
.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}
.stat-card.s-blue .stat-icon{background:rgba(26,42,94,.1);color:var(--navy)}
.stat-card.s-green .stat-icon{background:rgba(26,143,79,.1);color:var(--green)}
.stat-card.s-red .stat-icon{background:rgba(192,57,43,.1);color:var(--red)}
.stat-card.s-orange .stat-icon{background:rgba(224,123,32,.1);color:var(--orange)}
.stat-card:not([class*="s-"]) .stat-icon{background:rgba(201,168,76,.12);color:var(--gold3)}
.stat-val{font-size:1.38rem;font-weight:800;color:var(--text);line-height:1}
.stat-lbl{font-size:.73rem;color:var(--gray3);margin-top:3px}

.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.86rem}
thead tr{background:linear-gradient(90deg,var(--navy),var(--navy2))}
thead th{padding:11px 13px;color:#fff;font-weight:600;text-align:left;white-space:nowrap;font-size:.8rem;letter-spacing:.3px}
tbody tr{border-bottom:1px solid var(--gray);transition:background .15s}
tbody tr:hover{background:rgba(201,168,76,.06)}
tbody td{padding:10px 13px;vertical-align:middle}
tr.row-imp{background:rgba(192,57,43,.05)!important}
tr.row-imp:hover{background:rgba(192,57,43,.1)!important}

.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:.72rem;font-weight:700;white-space:nowrap}
.b-ok{background:rgba(26,143,79,.12);color:var(--green)}.b-err{background:rgba(192,57,43,.12);color:var(--red)}.b-warn{background:rgba(212,160,23,.15);color:#8a6000}.b-info{background:rgba(26,42,94,.1);color:var(--navy)}.b-gold{background:rgba(201,168,76,.15);color:var(--gold3)}

.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 15px;border-radius:var(--r2);border:none;cursor:pointer;font-size:.84rem;font-weight:600;transition:all .2s;white-space:nowrap;text-decoration:none;font-family:inherit}
.btn i{font-size:.82rem}
.btn-navy{background:var(--navy);color:#fff}.btn-navy:hover{background:var(--navy3);box-shadow:0 3px 10px rgba(26,42,94,.3)}
.btn-gold{background:var(--gold);color:var(--navy)}.btn-gold:hover{background:var(--gold3);color:#fff;box-shadow:0 3px 10px rgba(201,168,76,.4)}
.btn-green{background:var(--green);color:#fff}.btn-green:hover{background:#157047}
.btn-red{background:var(--red);color:#fff}.btn-red:hover{background:#a32520}
.btn-warn{background:var(--warn);color:var(--navy)}.btn-warn:hover{background:#b8880f}
.btn-outline{background:transparent;border:2px solid var(--navy);color:var(--navy)}.btn-outline:hover{background:var(--navy);color:#fff}
.btn-sm{padding:5px 10px;font-size:.78rem}.btn-xs{padding:3px 7px;font-size:.72rem}.btn-icon{padding:6px 9px}
.btn-group{display:flex;gap:5px;flex-wrap:wrap;align-items:center}

.form-group{margin-bottom:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.form-row-4{display:grid;grid-template-columns:repeat(4,1fr);gap:13px}
label{display:block;font-size:.79rem;font-weight:600;color:var(--text2);margin-bottom:4px}
.req{color:var(--red);margin-left:2px}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=tel],input[type=month],select,textarea{width:100%;padding:9px 11px;border:1.5px solid var(--gray);border-radius:var(--r2);font-size:.87rem;color:var(--text);transition:border-color .2s,box-shadow .2s;background:#fff;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,.15)}
textarea{resize:vertical;min-height:80px}
.form-actions{display:flex;gap:8px;margin-top:18px;padding-top:15px;border-top:1px solid var(--gray)}
.check-row{display:flex;align-items:center;gap:8px;margin-top:2px}
.check-row input[type=checkbox]{width:16px;height:16px;cursor:pointer}
.check-row label{margin:0;cursor:pointer;font-weight:500}

.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:15px}
.search-box{position:relative;flex:1;min-width:200px}
.search-box i{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--gray3)}
.search-box input{padding-left:33px}

.alert{padding:10px 14px;border-radius:var(--r2);margin-bottom:13px;display:flex;align-items:center;gap:9px;font-size:.86rem;font-weight:500}
.alert-ok{background:rgba(26,143,79,.1);color:var(--green);border-left:4px solid var(--green)}
.alert-err{background:rgba(192,57,43,.1);color:var(--red);border-left:4px solid var(--red)}
.alert-warn{background:rgba(212,160,23,.1);color:#7a5a00;border-left:4px solid var(--warn)}
.alert-info{background:rgba(26,42,94,.08);color:var(--navy);border-left:4px solid var(--navy)}

.modal-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:300;align-items:center;justify-content:center;padding:18px}
.modal-ov.show{display:flex}
.modal{background:#fff;border-radius:var(--r);width:100%;max-width:680px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 70px rgba(0,0,0,.35);animation:mIn .22s ease}
@keyframes mIn{from{transform:scale(.93) translateY(-18px);opacity:0}to{transform:scale(1);opacity:1}}
.modal-hd{background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff;padding:15px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:3px solid var(--gold)}
.modal-hd h3{font-size:.9rem;font-weight:700;display:flex;align-items:center;gap:8px}
.modal-hd h3 i{color:var(--gold)}
.modal-close{background:none;border:none;color:#fff;font-size:1.25rem;cursor:pointer;opacity:.75;transition:opacity .2s;padding:2px 6px}
.modal-close:hover{opacity:1}
.modal-bd{padding:20px}
.modal-ft{padding:13px 20px;border-top:1px solid var(--gray);display:flex;justify-content:flex-end;gap:8px}

.pager{display:flex;gap:5px;justify-content:center;margin-top:18px;flex-wrap:wrap}
.pager a{padding:6px 11px;border-radius:var(--r2);border:1.5px solid var(--gray);font-size:.82rem;background:#fff;color:var(--text);transition:all .2s}
.pager a:hover,.pager a.on{background:var(--navy);border-color:var(--navy);color:#fff}

body.login-bg{background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 55%,#2e44a0 100%);display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-box{background:#fff;border-radius:16px;padding:42px 38px;width:100%;max-width:420px;box-shadow:0 24px 70px rgba(0,0,0,.35)}
.login-logo{text-align:center;margin-bottom:28px}
.login-logo img{width:90px;border-radius:12px;box-shadow:0 4px 18px rgba(0,0,0,.18)}
.login-logo h1{color:var(--navy);font-size:1.35rem;margin-top:12px;letter-spacing:2px;font-weight:800}
.login-logo h1 span{color:var(--gold)}
.login-logo p{color:var(--gray3);font-size:.8rem;margin-top:3px}

.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px}
.chart-box{position:relative;height:285px}
.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.quick-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;padding:16px 10px;border-radius:var(--r);background:var(--off);border:2px solid var(--gray);color:var(--navy);text-align:center;font-size:.8rem;font-weight:600;transition:all .2s;cursor:pointer;text-decoration:none}
.quick-btn:hover{background:var(--navy);border-color:var(--navy);color:var(--gold);transform:translateY(-2px);box-shadow:var(--sh2)}
.quick-btn i{font-size:1.4rem}

.amt{font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}
.amt-green{color:var(--green)}.amt-red{color:var(--red)}.amt-gold{color:var(--gold3)}.amt-blue{color:var(--navy)}

.quit-page{max-width:750px;margin:0 auto;background:#fff;padding:46px 50px 40px;font-family:'Times New Roman',serif;font-size:14px;line-height:1.6}
.quit-hdr{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;padding-bottom:18px;border-bottom:3px double var(--gold)}
.quit-cname{font-size:1.2rem;font-weight:800;color:var(--navy);letter-spacing:1px}
.quit-cname span{color:var(--gold)}
.quit-cinfo{font-size:.8rem;color:#555;margin-top:5px;line-height:1.7}
.quit-title{text-align:center;font-size:1.45rem;font-weight:800;color:var(--navy);margin:18px 0 4px;letter-spacing:3px;text-transform:uppercase}
.quit-num{text-align:center;color:var(--gold3);font-size:.88rem;margin-bottom:22px;font-style:italic}
.quit-table{width:100%;border-collapse:collapse;margin-bottom:20px}
.quit-table td{padding:9px 14px;border:1px solid #ddd;font-size:.88rem}
.quit-table td:first-child{font-weight:700;background:#f9f9f9;color:var(--navy);width:42%}
.quit-montant{text-align:center;margin:22px 0;padding:16px;background:linear-gradient(135deg,rgba(26,42,94,.05),rgba(201,168,76,.08));border:1px solid var(--gold);border-radius:8px}
.quit-montant .quit-m-label{font-size:.85rem;color:var(--gray3);margin-bottom:6px}
.quit-montant .quit-m-val{font-size:1.5rem;font-weight:800;color:var(--navy)}
.quit-sigs{display:flex;justify-content:space-between;margin-top:36px;padding-top:18px;border-top:2px solid var(--gold)}
.quit-sig{text-align:center;width:44%}
.quit-sig-title{font-weight:700;color:var(--navy);font-size:.85rem;margin-bottom:50px;text-transform:uppercase;letter-spacing:1px}
.quit-sig-line{border-bottom:1px solid #333;width:80%;margin:0 auto 5px}
.quit-foot{text-align:center;margin-top:24px;font-size:.72rem;color:#888;border-top:1px solid #eee;padding-top:10px}

#toast-cnt{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:7px}
.toast{padding:11px 16px;border-radius:var(--r2);color:#fff;font-size:.84rem;font-weight:600;box-shadow:0 4px 18px rgba(0,0,0,.2);animation:tIn .3s ease;display:flex;align-items:center;gap:8px}
@keyframes tIn{from{transform:translateX(20px);opacity:0}to{transform:translateX(0);opacity:1}}
.t-ok{background:var(--green)}.t-err{background:var(--red)}.t-warn{background:var(--warn);color:var(--navy)}.t-info{background:var(--navy)}

.spin{display:inline-block;width:18px;height:18px;border:2.5px solid rgba(201,168,76,.3);border-top-color:var(--gold);border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

@media(max-width:900px){
  .sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}
  .main-wrap{margin-left:0!important}
  .dash-grid,.form-row,.form-row-3,.form-row-4{grid-template-columns:1fr}
  .tb-right{display:none}.stats-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.main-content{padding:14px}.card-body{padding:14px}.quick-grid{grid-template-columns:1fr}}
@media print{.sidebar,.topbar,.btn,.toolbar,.pager,.no-print{display:none!important}.main-wrap{margin-left:0!important}.card{box-shadow:none!important}body{background:#fff!important}}
