@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700;800&family=DM+Mono:wght@400;500&display=swap";#root{max-width:none!important;padding:0!important;text-align:left!important;margin:0!important}body{place-items:unset!important;display:block!important}:root{--font: "DM Sans", system-ui, sans-serif;--font-mono: "DM Mono", monospace;--primary: #4f46e5;--primary-hover: #4338ca;--primary-light: #eef2ff;--primary-muted: #c7d2fe;--success: #059669;--success-bg: #d1fae5;--warning: #d97706;--warning-bg: #fef3c7;--danger: #dc2626;--danger-bg: #fee2e2;--info: #2563eb;--info-bg: #dbeafe;--bg: #f1f5f9;--surface: #ffffff;--surface2: #f8fafc;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-2: #334155;--text-3: #64748b;--text-4: #94a3b8;--topbar: linear-gradient(135deg, #1e1b4b 0%, #3730a3 60%, #4f46e5 100%);--topbar-h: 60px;--s1: 0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.05);--s2: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.05);--s3: 0 8px 24px rgba(0,0,0,.1), 0 4px 8px rgba(0,0,0,.06);--s4: 0 20px 48px rgba(0,0,0,.14), 0 8px 16px rgba(0,0,0,.08);--r1: 6px;--r2: 10px;--r3: 14px;--r4: 20px;--t1: all .15s ease;--t2: all .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;scroll-behavior:smooth}body{min-height:100vh;font-family:var(--font);font-size:14px;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;overflow-x:hidden}#root{min-height:100vh;width:100%;max-width:none!important;padding:0!important;text-align:left!important}a{color:var(--primary);text-decoration:none}button{font-family:var(--font);cursor:pointer}input,select,textarea{font-family:var(--font)}img{max-width:100%;display:block}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:99px}.app-shell{display:flex;flex-direction:column;min-height:100vh}.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-h);background:var(--topbar);display:flex;align-items:center;justify-content:space-between;padding:0 20px;z-index:100;box-shadow:0 2px 20px #1e1b4b80;gap:12px}.topbar-brand{display:flex;align-items:center;gap:10px;cursor:pointer;flex-shrink:0;text-decoration:none}.topbar-brand-icon{width:36px;height:36px;border-radius:10px;background:#ffffff26;display:flex;align-items:center;justify-content:center;font-size:18px;border:1px solid rgba(255,255,255,.2);flex-shrink:0}.topbar-brand-name{color:#fff;font-weight:800;font-size:15px;letter-spacing:-.3px;line-height:1.1}.topbar-brand-sub{color:#ffffff73;font-size:9px;letter-spacing:1.2px;text-transform:uppercase}.topbar-nav{display:flex;gap:3px;align-items:center;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:1;justify-content:center}.topbar-nav::-webkit-scrollbar{display:none}.nav-btn{background:transparent;border:1px solid transparent;color:#ffffffa6;border-radius:var(--r2);padding:6px 12px;font-size:12.5px;font-weight:600;transition:var(--t1);white-space:nowrap;flex-shrink:0}.nav-btn:hover{background:#ffffff1a;color:#fff}.nav-btn.active{background:#ffffff2e;border-color:#ffffff40;color:#fff}.profile-btn{display:flex;align-items:center;gap:8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.18);border-radius:var(--r2);padding:5px 12px;transition:var(--t1);flex-shrink:0}.profile-btn:hover{background:#ffffff2e}.profile-btn .avatar{width:30px;height:30px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:13px;flex-shrink:0}.profile-btn .pname{color:#fff;font-weight:700;font-size:12.5px}.profile-btn .prole{color:#ffffff73;font-size:9px;text-transform:uppercase;letter-spacing:.8px}.profile-btn .chevron{color:#ffffff80;font-size:9px}.profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border-radius:var(--r4);box-shadow:var(--s4);min-width:270px;z-index:200;overflow:hidden;border:1px solid var(--border);animation:dropIn .18s ease}.profile-dropdown-header{background:var(--topbar);padding:22px 20px 18px;text-align:center}.profile-dropdown-avatar{width:60px;height:60px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;margin:0 auto 10px;font-size:24px;color:#fff;font-weight:800;border:2.5px solid rgba(255,255,255,.35)}.profile-dropdown-name{color:#fff;font-weight:800;font-size:16px}.profile-dropdown-poste{color:#ffffffa6;font-size:12px;margin-top:3px}.profile-dropdown-body{padding:14px 18px}.profile-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--surface2);border-radius:var(--r2);margin-bottom:8px}.profile-row-icon{font-size:16px;flex-shrink:0}.profile-row-label{font-size:10px;color:var(--text-4);text-transform:uppercase;letter-spacing:.5px}.profile-row-val{font-size:13px;color:var(--text);font-weight:600;word-break:break-all}.btn-logout{width:100%;padding:10px;border-radius:var(--r2);background:var(--danger);color:#fff;border:none;font-weight:700;font-size:13px;margin-top:6px;transition:var(--t1)}.btn-logout:hover{background:#b91c1c;transform:translateY(-1px)}.sidebar{position:fixed;top:0;left:0;bottom:0;width:240px;background:var(--topbar);display:flex;flex-direction:column;padding:16px 12px;z-index:100;box-shadow:4px 0 20px #0003;transition:transform .3s ease}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:8px 8px 16px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:16px}.sidebar-user{background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:var(--r3);padding:12px;margin-bottom:20px}.sidebar-user-avatar{width:40px;height:40px;border-radius:50%;background:#ffffff26;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;font-weight:800;flex-shrink:0}.sidebar-user-name{color:#fff;font-weight:700;font-size:13px}.sidebar-user-email{color:#ffffff80;font-size:11px;margin-top:2px;word-break:break-all}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:4px}.sidebar-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r2);color:#ffffffa6;border:1px solid transparent;font-size:13.5px;font-weight:600;background:transparent;text-align:left;transition:var(--t1)}.sidebar-item:hover{background:#ffffff1a;color:#fff}.sidebar-item.active{background:#ffffff29;border-color:#fff3;color:#fff}.sidebar-item-icon{font-size:16px;flex-shrink:0}.sidebar-logout{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--r2);background:#ef44442e;border:1px solid rgba(239,68,68,.3);color:#fca5a5;font-size:13px;font-weight:700;margin-top:8px;transition:var(--t1)}.sidebar-logout:hover{background:#ef44444d}.with-sidebar{margin-left:240px}.sidebar-topbar{height:52px;background:var(--topbar);display:flex;align-items:center;justify-content:space-between;padding:0 20px;box-shadow:0 2px 12px #0000004d;position:sticky;top:0;z-index:50}.sidebar-topbar-title{color:#fff;font-weight:700;font-size:14px}.page{padding-top:calc(var(--topbar-h) + 20px);min-height:100vh}.page-inner{max-width:1320px;margin:0 auto;padding:0 20px 40px}.archive-dropdown{position:absolute;top:calc(100% + 8px);left:0;background:var(--surface);border-radius:var(--r3);box-shadow:var(--s4);padding:12px;min-width:280px;z-index:200;border:1px solid var(--border);max-height:420px;overflow-y:auto;animation:dropIn .18s ease}.archive-region-tabs{display:flex;gap:5px;margin-bottom:10px}.archive-region-tab{padding:4px 12px;border-radius:6px;border:none;font-size:12px;font-weight:700;transition:var(--t1);cursor:pointer;background:var(--surface2);color:var(--text-2)}.archive-region-tab.active{background:var(--primary);color:#fff}.archive-wilaya-title{font-size:11px;font-weight:700;color:var(--text-4);text-transform:uppercase;letter-spacing:.5px;padding:6px 4px 4px;border-bottom:1px solid var(--border);margin-bottom:4px}.archive-agence-btn{display:flex;align-items:center;gap:7px;width:100%;text-align:left;padding:7px 10px;border:none;border-radius:var(--r1);background:transparent;color:var(--text-2);font-size:13px;margin-bottom:2px;transition:var(--t1)}.archive-agence-btn:hover{background:var(--primary-light);color:var(--primary)}.card{background:var(--surface);border-radius:var(--r3);border:1px solid var(--border);box-shadow:var(--s1);padding:20px;margin-bottom:16px}.card-title{font-size:16px;font-weight:700;color:var(--text);margin-bottom:16px;display:flex;align-items:center;gap:8px}.card-section-title{font-size:13px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:20px}.kpi{border-radius:var(--r3);padding:18px 16px;color:#fff;box-shadow:var(--s2);transition:transform .2s}.kpi:hover{transform:translateY(-2px)}.kpi-val{font-size:30px;font-weight:800;line-height:1}.kpi-label{font-size:12px;opacity:.85;margin-top:6px}.kpi-primary{background:linear-gradient(135deg,#4f46e5,#6366f1)}.kpi-success{background:linear-gradient(135deg,#059669,#10b981)}.kpi-danger{background:linear-gradient(135deg,#dc2626,#ef4444)}.kpi-warning{background:linear-gradient(135deg,#d97706,#f59e0b)}.kpi-info{background:linear-gradient(135deg,#2563eb,#3b82f6)}.kpi-violet{background:linear-gradient(135deg,#7c3aed,#8b5cf6)}.kpi-slate{background:linear-gradient(135deg,#475569,#64748b)}.btn{display:inline-flex;align-items:center;gap:6px;border-radius:var(--r2);padding:8px 16px;font-size:13px;font-weight:700;border:none;transition:var(--t1);cursor:pointer;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--s2)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#047857;transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover:not(:disabled){background:#b45309}.btn-ghost{background:var(--surface2);color:var(--text-2);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--border)}.btn-outline{background:transparent;color:var(--primary);border:1.5px solid var(--primary)}.btn-outline:hover:not(:disabled){background:var(--primary-light)}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:11px 22px;font-size:14px}.btn-icon{padding:7px;border-radius:var(--r1)}.field{margin-bottom:14px}.field-label{display:block;font-size:12px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.field-input,.field-select,.field-textarea{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--r2);background:var(--surface);color:var(--text);font-size:13px;font-family:var(--font);transition:var(--t1);appearance:none}.field-input:focus,.field-select:focus,.field-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51f}.field-textarea{min-height:90px;resize:vertical}.field-select{cursor:pointer}.filter-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end;background:var(--surface);border:1px solid var(--border);border-radius:var(--r3);padding:14px;margin-bottom:16px;box-shadow:var(--s1)}.filter-group{display:flex;flex-direction:column;gap:4px;min-width:120px;flex:1}.filter-label{font-size:11px;font-weight:700;color:var(--text-4);text-transform:uppercase;letter-spacing:.5px}.filter-inp{padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--r1);background:var(--surface);color:var(--text);font-size:13px;transition:border-color .15s;font-family:var(--font)}.filter-inp:focus{outline:none;border-color:var(--primary)}.month-filter{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:#eef2ff;border:1px solid var(--primary-muted);border-radius:var(--r2);padding:10px 14px;margin-bottom:16px}.month-filter-label{font-size:13px;font-weight:700;color:var(--primary)}.month-filter input{padding:6px 10px;border-radius:7px;border:1.5px solid var(--primary-muted);font-size:12px;background:#fff;font-family:var(--font)}.month-filter input:focus{outline:none;border-color:var(--primary)}.month-clear{padding:5px 10px;border-radius:6px;background:var(--danger);color:#fff;border:none;font-size:12px;font-weight:700;transition:var(--t1)}.month-clear:hover{background:#b91c1c}.table-wrap{overflow-x:auto;border-radius:var(--r3);border:1px solid var(--border)}.tbl{width:100%;border-collapse:collapse;min-width:600px}.tbl thead tr{background:var(--surface2)}.tbl th{padding:11px 14px;text-align:left;font-size:11px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border);white-space:nowrap}.tbl td{padding:11px 14px;font-size:13px;color:var(--text-2);border-bottom:1px solid var(--border);vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr:hover{background:#f8faff}.tbl-empty{padding:40px;text-align:center;color:var(--text-4);font-size:14px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:99px;font-size:11px;font-weight:700;white-space:nowrap}.badge-success{background:var(--success-bg);color:#065f46}.badge-danger{background:var(--danger-bg);color:#991b1b}.badge-warning{background:var(--warning-bg);color:#78350f}.badge-info{background:var(--info-bg);color:#1e40af}.badge-primary{background:var(--primary-light);color:#3730a3}.badge-neutral{background:#f1f5f9;color:#475569}.region-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.region-card{border-radius:var(--r3);padding:28px 20px;text-align:center;cursor:pointer;color:#fff;box-shadow:var(--s2);transition:var(--t2)}.region-card:hover{transform:translateY(-4px);box-shadow:var(--s4)}.region-card-icon{font-size:36px;margin-bottom:10px}.region-card-name{font-size:18px;font-weight:800}.region-card-sub{font-size:13px;opacity:.8;margin-top:4px}.rc-est{background:linear-gradient(135deg,#dc2626,#ef4444)}.rc-centre{background:linear-gradient(135deg,#2563eb,#3b82f6)}.rc-ouest{background:linear-gradient(135deg,#059669,#10b981)}.service-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:20px}.service-card{padding:18px;border-radius:var(--r3);color:#fff;cursor:pointer;transition:var(--t2);box-shadow:var(--s2)}.service-card:hover:not(.done){transform:translateY(-2px);box-shadow:var(--s3)}.service-card.todo{background:linear-gradient(135deg,#4338ca,#6366f1)}.service-card.done{background:linear-gradient(135deg,#059669,#10b981);cursor:default}.service-card.disabled{background:var(--border-strong);cursor:not-allowed;opacity:.7}.service-card-name{font-weight:800;font-size:14px}.service-card-sub{font-size:12px;opacity:.8;margin-top:5px}.task-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r3);margin-bottom:14px;overflow:hidden;box-shadow:var(--s1);transition:border-color .15s}.task-card:hover{border-color:var(--primary-muted)}.task-card.masked{opacity:.7;border-style:dashed;border-color:var(--danger)}.task-header{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;background:var(--surface2);border-bottom:1px solid var(--border);gap:8px}.task-title{font-weight:700;font-size:14px;color:var(--text);display:flex;align-items:center;gap:6px;flex:1}.task-actions{display:flex;gap:6px;align-items:center}.task-body{padding:14px 16px}.critere-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border);gap:12px}.critere-row:last-of-type{border-bottom:none}.critere-label{flex:1;font-size:13px;color:var(--text-2)}.critere-select{padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--r1);background:var(--surface);font-size:12.5px;color:var(--text);min-width:140px;cursor:pointer;font-family:var(--font);flex-shrink:0;transition:border-color .15s}.critere-select:focus{outline:none;border-color:var(--primary)}.task-comment-field{margin-top:12px}.progress-wrap{height:8px;background:var(--border);border-radius:99px;overflow:hidden;margin:8px 0}.progress-fill{height:100%;border-radius:99px;transition:width .3s ease;background:linear-gradient(90deg,var(--primary),#818cf8)}.progress-label{font-size:12px;font-weight:700;color:var(--text-3)}.detail-topbar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:20px;padding:16px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r3);box-shadow:var(--s1)}.detail-service-name{font-size:18px;font-weight:800;color:var(--text);flex:1}.detail-score{font-size:13px;font-weight:700;color:var(--text-3);display:flex;align-items:center;gap:6px}.score-pill{background:var(--primary-light);color:var(--primary);padding:4px 12px;border-radius:99px;font-weight:800;font-size:15px}.archive-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:16px}.archive-export-btns{display:flex;gap:8px;flex-wrap:wrap}.archive-date-list{display:flex;flex-direction:column;gap:8px}.archive-date-row{display:flex;align-items:center;gap:12px;padding:11px 14px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r2);transition:var(--t1)}.archive-date-row:hover{border-color:var(--primary);background:#f8faff}.archive-date-btn{background:none;border:none;color:var(--primary);font-weight:700;font-size:13.5px;cursor:pointer;padding:0}.archive-date-btn:hover{text-decoration:underline}.archive-detail-summary{display:flex;gap:20px;flex-wrap:wrap;padding:14px 18px;background:var(--primary-light);border:1px solid var(--primary-muted);border-radius:var(--r2);margin-bottom:18px}.archive-detail-item label{font-size:11px;color:var(--text-4);text-transform:uppercase}.archive-detail-item span{font-size:14px;font-weight:700;color:var(--text);display:block}.archive-service-block{margin-bottom:20px}.archive-service-header{background:linear-gradient(90deg,var(--primary),#818cf8);color:#fff;padding:10px 16px;border-radius:var(--r2) var(--r2) 0 0;font-weight:700;font-size:14px;display:flex;justify-content:space-between;align-items:center}.archive-tache-block{border:1px solid var(--border);border-top:none;padding:14px 16px;background:var(--surface)}.archive-tache-block:last-child{border-radius:0 0 var(--r2) var(--r2)}.archive-tache-title{font-weight:700;font-size:13px;color:var(--text-2);margin-bottom:10px}.mission-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r3);margin-bottom:12px;overflow:hidden;transition:var(--t1);box-shadow:var(--s1)}.mission-card:hover{box-shadow:var(--s2);border-color:var(--primary-muted)}.mission-card-header{padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer}.mission-card-body{padding:14px 18px;border-top:1px solid var(--border);background:var(--surface2)}.agence-row{padding:10px 14px;border:1px solid var(--border);border-radius:var(--r2);margin-bottom:8px;background:var(--surface)}.agence-row-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.agence-row-name{font-weight:700;font-size:13px;color:var(--text)}.agence-row-meta{font-size:12px;color:var(--text-4);margin-top:3px}.agence-row-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.modal-overlay{position:fixed;inset:0;background:#0f172a8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:300;padding:16px}.modal{background:var(--surface);border-radius:var(--r4);box-shadow:var(--s4);width:100%;max-width:640px;max-height:90vh;overflow-y:auto;animation:dropIn .2s ease}.modal-header{padding:22px 24px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-header-colored{padding:22px 24px;border-radius:var(--r4) var(--r4) 0 0;color:#fff}.modal-title{font-size:18px;font-weight:800}.modal-body{padding:20px 24px}.modal-footer{padding:14px 24px 20px;display:flex;gap:8px;justify-content:flex-end}.modal-close{background:#ffffff26;border:none;color:#fff;padding:4px 10px;border-radius:6px;font-size:16px;cursor:pointer}.dropdown-checklist{position:absolute;top:calc(100% + 6px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r3);padding:12px;width:270px;box-shadow:var(--s4);z-index:150;animation:dropIn .15s ease}.chk-item{display:flex;align-items:center;gap:8px;padding:7px 4px;border-bottom:1px solid var(--border);font-size:13px;color:var(--text-2);cursor:pointer}.chk-item:last-of-type{border-bottom:none}.chk-item input{cursor:pointer}.empty-state{text-align:center;padding:48px 24px;color:var(--text-4)}.empty-state-icon{font-size:48px;margin-bottom:12px}.empty-state-title{font-size:16px;font-weight:700;color:var(--text-3);margin-bottom:6px}.empty-state-text{font-size:13px}.user-status-active{background:var(--success-bg);color:#065f46}.user-status-inactive{background:var(--danger-bg);color:#991b1b}.user-role-admin{background:#ede9fe;color:#5b21b6}.user-role-inspector{background:var(--info-bg);color:#1e40af}.user-role-service{background:#fef3c7;color:#78350f}.recl-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r2);padding:14px 16px;margin-bottom:8px;transition:var(--t1)}.recl-card:hover{border-color:var(--primary-muted);box-shadow:var(--s2)}.recl-meta{font-size:12px;color:var(--text-4);display:flex;gap:12px;flex-wrap:wrap;margin-top:4px}.recl-comment{font-size:13px;color:var(--text-2);background:var(--surface2);border:1px solid var(--border);border-radius:var(--r1);padding:8px 10px;margin-top:8px;border-left:3px solid var(--primary)}.recl-actions{display:flex;gap:8px;margin-top:10px}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r3);padding:18px;box-shadow:var(--s1);margin-bottom:16px}.chart-card-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:14px}.chart-wrap{height:240px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);padding:16px;position:relative;overflow:hidden}.login-blob{position:absolute;border-radius:50%;background:#6366f112;pointer-events:none}.login-card{background:#ffffff0f;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:var(--r4);padding:40px 32px;width:100%;max-width:420px;box-shadow:0 32px 64px #0006;position:relative;z-index:1;animation:fadeUp .5s ease}.login-logo{width:68px;height:68px;border-radius:18px;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 14px}.login-title{color:#fff;font-size:26px;font-weight:800;text-align:center;margin-bottom:4px}.login-sub{color:#ffffff73;font-size:13px;text-align:center;margin-bottom:28px}.login-field{margin-bottom:14px}.login-label{color:#ffffffa6;font-size:12px;font-weight:700;display:block;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.login-input{width:100%;padding:11px 14px;background:#ffffff14;border:1.5px solid rgba(255,255,255,.15);border-radius:var(--r2);color:#fff;font-size:14px;font-family:var(--font);transition:border-color .2s}.login-input:focus{outline:none;border-color:#818cf8;box-shadow:0 0 0 3px #818cf833}.login-input::placeholder{color:#ffffff4d}.login-btn{width:100%;padding:13px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:var(--r2);font-size:15px;font-weight:800;cursor:pointer;transition:var(--t1);box-shadow:0 4px 16px #4f46e566}.login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #4f46e580}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:var(--r2);padding:10px 14px;color:#fca5a5;font-size:13px;margin-bottom:12px}.login-footer{color:#fff3;font-size:11px;text-align:center;margin-top:22px}@keyframes dropIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@media(max-width:768px){:root{--topbar-h: 56px}.topbar{padding:0 12px;gap:8px}.topbar-brand-sub{display:none}.topbar-nav{gap:2px}.nav-btn{padding:5px 9px;font-size:11.5px}.profile-btn .pname,.profile-btn .prole,.profile-btn .chevron{display:none}.profile-btn{padding:4px 6px}.page-inner{padding:0 12px 32px}.page{padding-top:calc(var(--topbar-h) + 12px)}.kpi-grid{grid-template-columns:1fr 1fr;gap:10px}.kpi-val{font-size:24px}.region-grid{grid-template-columns:1fr}.region-card{padding:20px 16px}.service-grid{grid-template-columns:1fr 1fr;gap:10px}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.with-sidebar{margin-left:0}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:90}.detail-topbar{flex-direction:column;align-items:flex-start}.critere-row{flex-direction:column;align-items:flex-start;gap:6px}.critere-select{min-width:100%;width:100%}.filter-bar{padding:10px;gap:6px}.filter-group{min-width:140px}.archive-toolbar{flex-direction:column;align-items:flex-start}.archive-export-btns{flex-wrap:wrap}.modal{max-width:100%;border-radius:var(--r3)}.modal-body,.modal-header,.modal-footer{padding:14px 16px}.stats-grid{grid-template-columns:1fr!important}.tbl{min-width:500px}.profile-dropdown{right:-10px;min-width:240px}.task-header{flex-wrap:wrap}.agence-row-actions{gap:4px}.btn{padding:7px 12px;font-size:12px}.btn-sm{padding:4px 8px;font-size:11px}}@media(max-width:480px){.kpi-grid,.service-grid{grid-template-columns:1fr 1fr}.topbar-nav{display:none}.topbar-mobile-menu{display:flex}}.mobile-nav-drawer{position:fixed;top:var(--topbar-h);left:0;right:0;background:#1e1b4b;z-index:99;padding:12px;display:flex;flex-direction:column;gap:4px;box-shadow:0 8px 24px #0000004d;animation:dropIn .2s ease}.mobile-nav-item{padding:11px 14px;border-radius:var(--r2);color:#ffffffbf;border:1px solid transparent;font-size:14px;font-weight:600;background:transparent;text-align:left;transition:var(--t1)}.mobile-nav-item:hover{background:#ffffff1a;color:#fff}.mobile-nav-item.active{background:#ffffff29;border-color:#fff3;color:#fff}.hamburger{background:#ffffff1a;border:1px solid rgba(255,255,255,.18);border-radius:var(--r1);padding:6px 9px;color:#fff;font-size:18px;display:none}@media(max-width:480px){.hamburger{display:flex;align-items:center;justify-content:center}}
