*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=light]{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--bg-hover:#e2e8f0;--bg-sidebar:#1e293b;--bg-sidebar-hover:#334155;--bg-sidebar-active:#0f172a;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-sidebar:#e2e8f0;--text-sidebar-muted:#94a3b8;--border:#e2e8f0;--border-light:#f1f5f9;--accent:#3b82f6;--accent-hover:#2563eb;--accent-light:#dbeafe;--accent-text:#fff;--success:#22c55e;--success-light:#dcfce7;--warning:#f59e0b;--warning-light:#fef3c7;--danger:#ef4444;--danger-light:#fee2e2;--info:#06b6d4;--info-light:#cffafe;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000f;--shadow-lg:0 10px 15px #0000001a, 0 4px 6px #0000000d;--radius-sm:6px;--radius:8px;--radius-lg:12px;--radius-xl:16px;--sidebar-width:260px;--header-height:0px}[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--bg-hover:#475569;--bg-sidebar:#0f172a;--bg-sidebar-hover:#1e293b;--bg-sidebar-active:#1e3a5f;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-muted:#64748b;--text-sidebar:#e2e8f0;--text-sidebar-muted:#64748b;--border:#334155;--border-light:#1e293b;--accent:#60a5fa;--accent-hover:#3b82f6;--accent-light:#1e3a5f;--shadow-sm:0 1px 2px #0000004d;--shadow:0 1px 3px #0006;--shadow-md:0 4px 6px #0006;--shadow-lg:0 10px 15px #00000080}html,body,#root{height:100%;color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.app-layout{height:100vh;display:flex;overflow:hidden}.main-content{background:var(--bg-primary);flex:1;padding:24px 32px;overflow-y:auto}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-sidebar);flex-direction:column;height:100vh;display:flex;overflow:hidden}.sidebar-header{color:var(--text-sidebar);border-bottom:1px solid #ffffff1a;align-items:center;gap:12px;padding:20px 16px;display:flex}.sidebar-title{letter-spacing:-.02em;font-size:16px;font-weight:700}.sidebar-nav{flex:1;padding:8px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}.nav-item{border-radius:var(--radius-sm);color:var(--text-sidebar-muted);align-items:center;gap:10px;margin-bottom:1px;padding:8px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item-indent{padding-left:38px;font-size:12px}.nav-item:hover{background:var(--bg-sidebar-hover);color:var(--text-sidebar);text-decoration:none}.nav-item-wip{opacity:.7;color:#ef4444!important}.nav-item-wip:hover{opacity:1}.wip-dot{background:#ef4444;border-radius:50%;flex-shrink:0;width:6px;height:6px;margin-left:auto}.nav-group{margin-top:4px}.nav-group-header{border-radius:var(--radius-sm);width:100%;color:var(--text-sidebar);text-transform:uppercase;letter-spacing:.04em;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:8px 12px;font-size:12px;font-weight:700;transition:all .15s;display:flex}.nav-group-header:hover{background:var(--bg-sidebar-hover)}.nav-group-header.open{color:var(--text-sidebar)}.nav-group-chevron{color:var(--text-sidebar-muted);flex-shrink:0;margin-left:auto}.nav-group-items{padding-bottom:4px}.nav-item.active{background:var(--bg-sidebar-active);color:var(--text-sidebar)}.sidebar-footer{border-top:1px solid #ffffff1a;padding:12px 16px}.user-info{flex-direction:column;margin-bottom:8px;display:flex}.user-name{color:var(--text-sidebar);font-size:13px;font-weight:600}.user-role{color:var(--text-sidebar-muted);text-transform:capitalize;font-size:11px}.sidebar-actions{gap:8px;display:flex}.page{max-width:1400px}.page-header{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-header h1{letter-spacing:-.02em;font-size:24px;font-weight:700}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border-left:4px solid;align-items:center;gap:16px;padding:20px;transition:box-shadow .2s;display:flex}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-icon{background:var(--bg-tertiary);border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-info{flex-direction:column;display:flex}.stat-value{letter-spacing:-.02em;font-size:28px;font-weight:700;line-height:1.2}.stat-label{color:var(--text-secondary);font-size:12px;font-weight:500}.dashboard-sections{gap:20px;display:grid}.dashboard-section{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.dashboard-section h2{margin-bottom:12px;font-size:16px;font-weight:600}.placeholder-content{background:var(--bg-secondary);border-radius:var(--radius-lg);border:2px dashed var(--border);color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:80px 20px;display:flex}.placeholder-content h2{color:var(--text-secondary);font-size:18px;font-weight:600}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:var(--bg-secondary);border-radius:var(--radius-xl);width:100%;max-width:400px;box-shadow:var(--shadow-lg);padding:40px}.login-header{text-align:center;color:var(--accent);margin-bottom:32px}.login-header h1{color:var(--text-primary);margin-top:12px;font-size:24px;font-weight:700}.login-header p{color:var(--text-secondary);margin-top:4px;font-size:14px}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}input[type=text],input[type=password],input[type=email],input[type=number],input[type=date],input[type=time],input[type=search],textarea,select{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-primary);width:100%;color:var(--text-primary);outline:none;padding:10px 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}textarea{resize:vertical;min-height:80px}input[type=date],input[type=time],input[type=month]{cursor:pointer;position:relative}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;margin-right:-4px;padding:4px;transition:opacity .15s}input[type=time]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;margin-right:-4px;padding:4px;transition:opacity .15s}input[type=month]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;margin-right:-4px;padding:4px;transition:opacity .15s}input[type=date]:hover::-webkit-calendar-picker-indicator{opacity:1}input[type=time]:hover::-webkit-calendar-picker-indicator{opacity:1}input[type=month]:hover::-webkit-calendar-picker-indicator{opacity:1}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--accent-text)}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{border-radius:var(--radius);width:36px;height:36px;color:var(--text-sidebar-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.btn-icon:hover{color:var(--text-sidebar);background:#ffffff1a}.badge{background:var(--accent-light);color:var(--accent);text-transform:capitalize;border-radius:999px;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.table-container{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg-tertiary);padding:12px 16px;font-size:11px;font-weight:600}td{border-bottom:1px solid var(--border-light);color:var(--text-primary);padding:12px 16px;font-size:13px}tr:hover td{background:var(--bg-tertiary)}.error-message{color:var(--danger);background:var(--danger-light);border-radius:var(--radius);border:1px solid var(--danger);margin-bottom:16px;padding:10px 12px;font-size:13px}.loading-screen{height:100vh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.text-muted{color:var(--text-muted)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.toolbar-actions{align-items:center;gap:8px;display:flex}.search-box{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);flex:1;align-items:center;gap:8px;max-width:400px;padding:8px 12px;display:flex}.search-box input{background:0 0;border:none;outline:none;flex:1;padding:0;font-size:13px}.search-box input:focus{box-shadow:none}.badge-success{background:var(--success-light);color:var(--success)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-info{background:var(--info-light);color:var(--info)}.table-actions{gap:4px;display:flex}.btn-icon-sm{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.btn-icon-sm:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon-danger:hover{background:var(--danger-light);color:var(--danger)}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-height:90vh;animation:.2s ease-out modalIn;overflow-y:auto}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.modal-header h2{font-size:18px;font-weight:700}.modal-close{color:var(--text-muted);background:0 0}.modal-close:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-body{padding:16px 24px 24px}fieldset{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:16px}legend{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:0 8px;font-size:12px;font-weight:600}.form-row{margin-bottom:12px}.form-row:last-child{margin-bottom:0}.form-row.two-cols{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding-top:16px;display:flex}.login-card .btn-primary{width:100%}.role-chips{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.role-chip{border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.role-chip:hover{border-color:var(--accent);color:var(--accent)}.role-chip.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.role-badge{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;font-weight:500;display:inline-flex}code{background:var(--bg-tertiary);border-radius:4px;padding:2px 6px;font-family:Fira Code,Consolas,monospace;font-size:12px}.import-upload,.import-progress,.import-done{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:40px 20px;display:flex}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);cursor:pointer;color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;width:100%;padding:40px;transition:border-color .2s;display:flex;position:relative}.upload-zone:hover{border-color:var(--accent);color:var(--accent)}.upload-input{opacity:0;cursor:pointer;position:absolute;inset:0}.mapping-grid{flex-direction:column;gap:4px;display:flex}.mapping-header{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);grid-template-columns:180px 200px 1fr;gap:12px;padding:8px 0;font-size:11px;font-weight:600;display:grid}.mapping-row{grid-template-columns:180px 200px 1fr;align-items:center;gap:12px;padding:6px 0;display:grid}.mapping-row label{font-size:13px;font-weight:500}.mapping-row select{width:100%}.mapping-preview{white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.qr-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.qr-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;align-items:center;gap:8px;padding:12px;display:flex}.qr-image{width:140px;height:140px}.qr-info{flex-direction:column;align-items:center;gap:4px;display:flex}.qr-code-text{word-break:break-all;text-align:center;font-size:9px;line-height:1.3}.qr-actions{gap:4px;display:flex}.qr-scanner-overlay{z-index:1100;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.qr-scanner-card{background:var(--bg-secondary);border-radius:var(--radius-xl);width:100%;max-width:400px;overflow:hidden}.qr-scanner-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:14px 16px;font-weight:600;display:flex}.qr-scanner-header span{flex:1}.qr-scanner-viewport{width:100%;min-height:300px}.visite-row{background:var(--bg-tertiary);border-radius:var(--radius-sm);align-items:center;gap:8px;margin-bottom:6px;padding:8px;display:flex}.visite-row input[type=text],.visite-row input[type=date],.visite-row input[type=number]{padding:6px 8px;font-size:12px}.collapsible-section{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:16px;overflow:hidden}.collapsible-header{cursor:pointer;width:100%;color:var(--text-primary);text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:16px 20px;font-size:15px;font-weight:600;transition:background .15s;display:flex}.collapsible-header:hover{background:var(--bg-tertiary)}.collapsible-chevron{color:var(--text-muted);flex-shrink:0}.collapsible-icon{color:var(--accent);flex-shrink:0}.collapsible-title{flex:1}.collapsible-body{padding:0 20px 20px}.audit-filters{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.audit-filters select,.audit-filters input[type=date]{padding:6px 10px;font-size:12px}.config-status-bar{background:var(--bg-primary);border-radius:var(--radius);border:1px solid var(--border);flex-wrap:wrap;gap:16px;margin-bottom:20px;padding:12px 16px;display:flex}.config-status{align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.config-status.ok{color:var(--success)}.config-status.missing{color:var(--text-muted)}.export-layout{flex-direction:column;gap:16px;margin-bottom:16px;display:flex}.export-section h4{color:var(--text-secondary);margin-bottom:8px;font-size:13px;font-weight:600}.export-cols-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:6px;display:grid}.export-col-check,.export-item-check{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:8px;padding:6px 8px;font-size:13px;transition:background .1s;display:flex}.export-col-check:hover,.export-item-check:hover{background:var(--bg-tertiary)}.export-col-check input,.export-item-check input{width:16px;height:16px;accent-color:var(--accent)}.export-select-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.export-items-list{border:1px solid var(--border);border-radius:var(--radius);max-height:250px;padding:4px;overflow-y:auto}.societe-link-block{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-primary);margin-bottom:8px;padding:12px}.societe-checkbox{cursor:pointer;align-items:center;gap:8px;font-size:14px;display:flex}.societe-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent)}.suivi-fields{border-top:1px dashed var(--border);margin-top:10px;padding-top:10px}.inline-fields{align-items:center;gap:8px;display:flex}.inline-fields input,.inline-fields select{flex:1;width:auto}.permissions-layout{grid-template-columns:280px 1fr;align-items:start;gap:20px;display:grid}.users-list-panel{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);max-height:calc(100vh - 200px);padding:16px;position:sticky;top:24px;overflow-y:auto}.users-list-panel h3{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:12px;font-size:13px;font-weight:600}.users-list{flex-direction:column;gap:4px;display:flex}.user-item{border-radius:var(--radius);color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:10px 12px;transition:all .15s;display:flex}.user-item:hover{background:var(--bg-tertiary)}.user-item.active{background:var(--accent-light);color:var(--accent)}.user-item.inactive{opacity:.5}.user-item-info{flex-direction:column;flex:1;min-width:0;display:flex}.user-item-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-item-role{color:var(--text-muted);font-size:11px}.permissions-matrix-panel{min-width:0}.perm-user-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.perm-user-header h3{font-size:18px;font-weight:700}@media (width<=900px){.permissions-layout{grid-template-columns:1fr}.users-list-panel{max-height:200px;position:static}}.permissions-table .perm-col{text-align:center;width:80px}.permissions-table .category-row td{background:var(--bg-tertiary);text-transform:uppercase;letter-spacing:.06em;color:var(--accent);border-bottom:2px solid var(--accent);padding:8px 16px;font-size:11px;font-weight:700}.permissions-table .module-name{padding-left:28px;font-weight:500}.perm-checkbox{cursor:pointer;justify-content:center;align-items:center;display:inline-flex}.perm-checkbox input{display:none}.perm-check-icon{border-radius:var(--radius-sm);border:2px solid var(--border);width:28px;height:28px;color:var(--text-muted);justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.perm-checkbox.checked .perm-check-icon{background:var(--success);border-color:var(--success);color:#fff}.perm-checkbox:not(.disabled):hover .perm-check-icon{border-color:var(--accent)}.perm-checkbox.disabled{cursor:not-allowed;opacity:.4}@media (width<=768px){.sidebar{z-index:100;transition:left .3s;position:fixed;left:-100%}.sidebar.open{left:0}.main-content{padding:16px}.stats-grid{grid-template-columns:1fr}}
