*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--c-bg: #f4f6f9;--c-surface: #ffffff;--c-surface-2: #f0f3f7;--c-border: #e2e8f0;--c-border-2: #cbd5e1;--c-text: #0f172a;--c-text-2: #475569;--c-text-3: #94a3b8;--c-primary: #0f766e;--c-primary-h: #0d6b64;--c-primary-lt: #e6f4f3;--c-primary-mid: #14b8a6;--c-danger: #dc2626;--c-danger-lt: #fef2f2;--c-warn: #d97706;--c-warn-lt: #fffbeb;--c-success: #16a34a;--c-success-lt: #f0fdf4;--c-sidebar: #0f172a;--c-sidebar-h: #1e293b;--c-sidebar-txt: #94a3b8;--c-sidebar-act: #14b8a6;--font-sans: "DM Sans", system-ui, sans-serif;--font-mono: "DM Mono", monospace;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--sh-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--sh-md: 0 4px 16px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04);--sh-lg: 0 12px 40px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.06);--tr: .18s ease}html{font-size:15px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-sans);background:var(--c-bg);color:var(--c-text);line-height:1.6}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--c-bg)}.spinner{width:36px;height:36px;border:3px solid var(--c-border);border-top-color:var(--c-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-shell{display:flex;min-height:100vh}.sidebar{width:240px;flex-shrink:0;background:var(--c-sidebar);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform var(--tr)}.sidebar-logo{padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-logo-mark{display:flex;align-items:center;gap:10px}.logo-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--c-primary-mid),var(--c-primary));border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:15px;letter-spacing:-.5px}.logo-text{color:#fff;font-weight:600;font-size:15px;letter-spacing:-.3px}.logo-sub{color:var(--c-sidebar-txt);font-size:11px;margin-top:1px}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:2px}.nav-section-label{color:var(--c-sidebar-txt);font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:12px 8px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-md);color:var(--c-sidebar-txt);font-size:14px;font-weight:450;text-decoration:none;cursor:pointer;border:none;background:none;width:100%;transition:background var(--tr),color var(--tr)}.nav-item:hover{background:var(--c-sidebar-h);color:#e2e8f0}.nav-item.active{background:#14b8a61f;color:var(--c-sidebar-act)}.nav-item.active svg{color:var(--c-sidebar-act)}.nav-item svg{width:17px;height:17px;flex-shrink:0}.nav-item span{flex:1;text-align:left}.sidebar-footer{padding:16px 12px;border-top:1px solid rgba(255,255,255,.06)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-md)}.avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--c-primary-mid),var(--c-primary));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:13px;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-username{color:#e2e8f0;font-size:13px;font-weight:500;truncate:true;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-role{color:var(--c-sidebar-txt);font-size:11px}.main-content{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh}.topbar{height:60px;background:var(--c-surface);border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:50;box-shadow:var(--sh-sm)}.topbar-title{font-size:16px;font-weight:600;color:var(--c-text)}.topbar-actions{display:flex;align-items:center;gap:12px}.page-content{padding:28px;flex:1}.page-header{margin-bottom:24px}.page-title{font-size:22px;font-weight:700;color:var(--c-text);letter-spacing:-.4px}.page-subtitle{color:var(--c-text-2);font-size:14px;margin-top:4px}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);box-shadow:var(--sh-sm)}.card-header{padding:18px 22px 16px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:15px;font-weight:600;color:var(--c-text)}.card-body{padding:22px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);padding:20px 22px;box-shadow:var(--sh-sm);display:flex;align-items:flex-start;gap:14px}.stat-icon{width:42px;height:42px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.teal{background:var(--c-primary-lt);color:var(--c-primary)}.stat-icon.green{background:var(--c-success-lt);color:var(--c-success)}.stat-icon.amber{background:var(--c-warn-lt);color:var(--c-warn)}.stat-icon.red{background:var(--c-danger-lt);color:var(--c-danger)}.stat-icon svg{width:20px;height:20px}.stat-label{font-size:12px;color:var(--c-text-2);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:26px;font-weight:700;color:var(--c-text);letter-spacing:-.5px;margin-top:2px}.stat-sub{font-size:12px;color:var(--c-text-3);margin-top:2px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:500;color:var(--c-text-2)}.form-label.required:after{content:" *";color:var(--c-danger)}.form-input,.input,.form-select,input[type=text],input[type=email],input[type=password],input[type=date],input[type=time],input[type=number],input[type=search],input[type=tel],input[type=url],select,textarea{width:100%;padding:9px 13px;background:var(--c-surface);border:1px solid var(--c-border-2);border-radius:var(--r-xl);font-family:var(--font-sans);font-size:14px;color:var(--c-text);transition:border-color var(--tr),box-shadow var(--tr);outline:none;box-sizing:border-box}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}textarea{min-height:80px;resize:vertical}.form-input:focus,.input:focus,.form-select:focus,input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=date]:focus,input[type=time]:focus,input[type=number]:focus,input[type=search]:focus,select:focus,textarea:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px #0f766e1f}.form-input.error,.input.error{border-color:var(--c-danger)}.form-input:disabled,.input:disabled,select:disabled,textarea:disabled{background:var(--c-surface-2);color:var(--c-text-3);cursor:not-allowed}.form-error{font-size:12px;color:var(--c-danger);display:flex;align-items:center;gap:4px}.form-hint{font-size:12px;color:var(--c-text-3)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.input-wrapper{position:relative}.input-icon-left{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--c-text-3);width:16px;height:16px;pointer-events:none}.input-icon-right{position:absolute;right:11px;top:50%;transform:translateY(-50%);color:var(--c-text-3);width:16px;height:16px;cursor:pointer}.form-input.has-left,.input.has-left{padding-left:38px}.form-input.has-right,.input.has-right{padding-right:38px}.form-select{width:100%;padding:9px 36px 9px 13px;background:var(--c-surface);border:1px solid var(--c-border-2);border-radius:var(--r-xl);font-family:var(--font-sans);font-size:14px;color:var(--c-text);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;outline:none;transition:border-color var(--tr);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.form-select:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px #0f766e1f}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;border-radius:var(--r-md);font-family:var(--font-sans);font-size:14px;font-weight:500;cursor:pointer;border:none;transition:background var(--tr),box-shadow var(--tr),transform .1s;white-space:nowrap;text-decoration:none}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn svg{width:15px;height:15px}.btn-primary{background:var(--c-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--c-primary-h);box-shadow:0 4px 12px #0f766e4d}.btn-secondary{background:var(--c-surface);color:var(--c-text);border:1px solid var(--c-border-2)}.btn-secondary:hover:not(:disabled){background:var(--c-surface-2)}.btn-danger{background:var(--c-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{background:transparent;color:var(--c-text-2)}.btn-ghost:hover:not(:disabled){background:var(--c-surface-2)}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:12px 24px;font-size:15px}.btn-full{width:100%}.btn-icon{padding:8px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:100px;font-size:12px;font-weight:500}.badge-admin{background:#ede9fe;color:#6d28d9}.badge-gestionnaire{background:var(--c-primary-lt);color:var(--c-primary)}.badge-utilisateur{background:var(--c-surface-2);color:var(--c-text-2)}.badge-active{background:var(--c-success-lt);color:var(--c-success)}.badge-inactive{background:var(--c-danger-lt);color:var(--c-danger)}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:14px}.table th{padding:11px 16px;text-align:left;font-size:11px;font-weight:600;color:var(--c-text-2);text-transform:uppercase;letter-spacing:.05em;background:var(--c-surface-2);border-bottom:1px solid var(--c-border)}.table th:first-child{border-radius:var(--r-sm) 0 0 0}.table th:last-child{border-radius:0 var(--r-sm) 0 0}.table td{padding:13px 16px;border-bottom:1px solid var(--c-border);color:var(--c-text);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--c-surface-2)}.table-actions{display:flex;gap:6px}.pagination{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-top:1px solid var(--c-border);font-size:13px;color:var(--c-text-2)}.pagination-controls{display:flex;gap:6px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .15s ease}.modal{background:var(--c-surface);border-radius:var(--r-xl);box-shadow:var(--sh-lg);width:100%;max-width:480px;margin:16px;animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--c-border)}.modal-title{font-size:16px;font-weight:600}.modal-body{padding:24px;display:flex;flex-direction:column;gap:16px}.modal-footer{padding:16px 24px 20px;border-top:1px solid var(--c-border);display:flex;gap:10px;justify-content:flex-end}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login-shell{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}@media (max-width: 768px){.login-shell{grid-template-columns:1fr}}.login-left{background:var(--c-sidebar);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;position:relative;overflow:hidden}.login-left:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 50%,rgba(20,184,166,.15) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(15,118,110,.1) 0%,transparent 50%)}.login-left-content{position:relative;z-index:1;text-align:center;max-width:320px}.login-brand-icon{width:64px;height:64px;background:linear-gradient(135deg,var(--c-primary-mid),var(--c-primary));border-radius:18px;margin:0 auto 24px;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:800;color:#fff;letter-spacing:-1px;box-shadow:0 12px 32px #0f766e66}.login-brand-name{color:#fff;font-size:26px;font-weight:700;letter-spacing:-.5px}.login-brand-sub{color:var(--c-sidebar-txt);font-size:14px;margin-top:8px;line-height:1.5}.login-features{margin-top:40px;display:flex;flex-direction:column;gap:12px}.login-feature{display:flex;align-items:center;gap:10px;color:#94a3b8;font-size:13px}.login-feature svg{color:var(--c-primary-mid);flex-shrink:0}.login-right{display:flex;align-items:center;justify-content:center;padding:48px;background:var(--c-bg)}.login-form-wrap{width:100%;max-width:380px}.login-title{font-size:24px;font-weight:700;color:var(--c-text);letter-spacing:-.4px;margin-bottom:6px}.login-subtitle{color:var(--c-text-2);font-size:14px;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:18px}.alert{padding:12px 14px;border-radius:var(--r-md);font-size:13px;display:flex;align-items:flex-start;gap:9px}.alert-error{background:var(--c-danger-lt);color:var(--c-danger);border:1px solid #fecaca}.alert-success{background:var(--c-success-lt);color:var(--c-success);border:1px solid #bbf7d0}.alert-warn{background:var(--c-warn-lt);color:var(--c-warn);border:1px solid #fde68a}.alert-info{background:var(--c-primary-lt);color:var(--c-primary);border:1px solid #99f6e4}.alert svg{flex-shrink:0;margin-top:1px}.pw-strength{display:flex;flex-direction:column;gap:6px}.pw-bars{display:flex;gap:3px}.pw-bar{height:3px;flex:1;border-radius:2px;background:var(--c-border);transition:background .3s}.pw-bar.filled-0{background:var(--c-danger)}.pw-bar.filled-1,.pw-bar.filled-2{background:var(--c-warn)}.pw-bar.filled-3{background:var(--c-primary)}.pw-bar.filled-4{background:var(--c-success)}.pw-checks{display:flex;flex-wrap:wrap;gap:4px 12px}.pw-check{font-size:11px;display:flex;align-items:center;gap:4px}.pw-check.ok{color:var(--c-success)}.pw-check.err{color:var(--c-text-3)}.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}.search-wrap{position:relative;flex:1;min-width:200px;max-width:360px}.search-input{width:100%;padding:9px 13px 9px 36px;border:1px solid var(--c-border-2);border-radius:var(--r-xl);font-family:var(--font-sans);font-size:14px;outline:none;background:var(--c-surface);color:var(--c-text);transition:border-color var(--tr)}.search-input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px #0f766e1f}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--c-text-3);width:15px;height:15px}.empty-state{text-align:center;padding:56px 24px;color:var(--c-text-3)}.empty-state svg{width:40px;height:40px;margin:0 auto 12px;opacity:.4}.empty-state p{font-size:14px}.divider{height:1px;background:var(--c-border);margin:8px 0}.text-sm{font-size:13px}.text-xs{font-size:12px}.text-muted{color:var(--c-text-2)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flex-center{display:flex;align-items:center;justify-content:center}.gap-2{gap:8px}.mt-4{margin-top:16px}.section-gap{display:flex;flex-direction:column;gap:24px}.mfa-code-display{font-family:var(--font-mono);font-size:13px;background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--r-md);padding:12px;word-break:break-all;color:var(--c-text)}.qr-placeholder{width:180px;height:180px;background:var(--c-surface-2);border:2px dashed var(--c-border-2);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;color:var(--c-text-3);font-size:12px;text-align:center;padding:12px;margin:0 auto}
