@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=DM+Mono:wght@400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--navy:#1a1d2e;--navy2:#2d3561;--blue:#1e4d8c;--accent:#4f8ef7;--accent2:#7c3aed;--border:#e9ecf2;--bg:#f4f6fb;--text:#1a1d2e;--text2:#6b7280;--text3:#9ca3af}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:DM Sans,sans-serif}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:.35s both fadeIn}.login-wrap{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.login-left{background:linear-gradient(145deg,var(--navy) 0%,var(--navy2) 55%,var(--blue) 100%);flex-direction:column;justify-content:center;align-items:center;padding:64px;display:flex;position:relative;overflow:hidden}.login-left:before{content:"";border:1px solid #ffffff0d;border-radius:50%;width:600px;height:600px;position:absolute;top:-150px;right:-150px}.login-left:after{content:"";border:1px solid #ffffff0d;border-radius:50%;width:350px;height:350px;position:absolute;bottom:-80px;left:-80px}.brand-wrap{align-items:center;gap:14px;margin-bottom:48px;display:flex}.brand-logo{background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;font-size:24px;display:flex;box-shadow:0 8px 24px #4f8ef759}.brand-name{color:#fff;letter-spacing:-.5px;font-size:26px;font-weight:700}.brand-name span{color:var(--accent)}.login-headline{color:#fff;text-align:center;letter-spacing:-.5px;margin-bottom:14px;font-size:26px;font-weight:700;line-height:1.3}.login-tagline{color:#ffffff80;text-align:center;max-width:340px;font-size:15px;line-height:1.7}.features{flex-direction:column;gap:14px;width:100%;max-width:320px;margin-top:44px;display:flex}.feat{color:#ffffffb3;align-items:center;gap:12px;font-size:14px;display:flex}.feat-icon{background:#ffffff14;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:15px;display:flex}.login-right{background:#f8fafd;justify-content:center;align-items:center;padding:60px;display:flex}.login-card{width:100%;max-width:420px}.login-title{color:var(--navy);letter-spacing:-.8px;margin-bottom:6px;font-size:30px;font-weight:700}.login-sub{color:var(--text2);margin-bottom:36px;font-size:15px}.field{margin-bottom:20px}.field label{color:#374151;letter-spacing:.5px;text-transform:uppercase;margin-bottom:7px;font-size:11px;font-weight:700;display:block}.field input,.field select{border:1.5px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:10px;outline:none;padding:13px 16px;font-family:inherit;font-size:15px;transition:border-color .2s,box-shadow .2s}.field input:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4f8ef71f}.btn{cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;font-family:inherit;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:linear-gradient(135deg,var(--navy2),var(--blue));color:#fff;letter-spacing:.2px;border-radius:10px;width:100%;padding:14px;font-size:15px}.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 20px #1d4d8c4d}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-sm{border-radius:8px;padding:8px 16px;font-size:13px}.btn-xs{border-radius:7px;padding:6px 12px;font-size:12px}.btn-outline{border:1.5px solid var(--border);color:var(--text2);cursor:pointer;background:0 0;border-radius:8px;padding:8px 16px;font-family:inherit;font-size:13px}.btn-outline:hover{color:var(--text);background:#f4f6fb;border-color:#c7d2e8}.btn-blue{color:#2563eb;background:#eff4ff;border:1.5px solid #dde8ff}.btn-blue:hover{background:#dde8ff}.btn-green{color:#16a34a;background:#f0fdf4;border:1.5px solid #bbf7d0}.btn-green:hover{background:#dcfce7}.btn-red{color:#dc2626;background:#fef2f2;border:1.5px solid #fecaca}.btn-red:hover{background:#fee2e2}.error-msg{color:#dc2626;background:#fef2f2;border:1px solid #fca5a5;border-radius:9px;align-items:center;gap:8px;margin-bottom:16px;padding:11px 16px;font-size:13px;display:flex}.success-msg{color:#16a34a;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:9px;margin-bottom:16px;padding:11px 16px;font-size:13px}.demo-box{background:#f0f4ff;border:1px solid #dde5ff;border-radius:12px;margin-top:28px;padding:18px}.demo-title{color:var(--accent);letter-spacing:.8px;text-transform:uppercase;margin-bottom:12px;font-size:11px;font-weight:700}.demo-item{border-bottom:1px solid #4f8ef71a;justify-content:space-between;align-items:center;padding:6px 0;display:flex}.demo-item:last-child{border-bottom:none}.demo-email{color:#374151;font-family:DM Mono,monospace;font-size:11px}.demo-pwd{color:var(--accent);font-family:DM Mono,monospace;font-size:11px;font-weight:600}.demo-click{color:var(--text3);cursor:pointer;font-size:11px;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.demo-click:hover{color:var(--accent)}.header{border-bottom:1px solid var(--border);z-index:100;background:#fff;justify-content:space-between;align-items:center;height:64px;padding:0 32px;display:flex;position:sticky;top:0}.header-brand{align-items:center;gap:10px;display:flex}.header-logo{background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:9px;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.header-name{color:var(--navy);letter-spacing:-.4px;font-size:18px;font-weight:700}.header-name span{color:var(--accent)}.header-sep{background:var(--border);width:1px;height:24px;margin:0 16px}.header-page{color:var(--text2);font-size:13px;font-weight:500}.header-right{align-items:center;gap:12px;display:flex}.user-pill{background:var(--bg);border:1px solid var(--border);border-radius:40px;align-items:center;gap:9px;padding:5px 14px 5px 5px;display:flex}.user-avatar{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:flex}.user-name{color:#374151;font-size:13px;font-weight:600}.role-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:3px 9px;font-size:10px;font-weight:700}.role-admin{color:#7c3aed;background:#f3e8ff}.role-formateur{color:#2563eb;background:#eff4ff}.btn-logout{border:1.5px solid var(--border);cursor:pointer;color:var(--text2);background:0 0;border-radius:8px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s}.btn-logout:hover{color:#ef4444;background:#fef2f2;border-color:#ef4444}.app-body{min-height:calc(100vh - 64px);display:flex}.sidebar{border-right:1px solid var(--border);background:#fff;flex-shrink:0;width:224px;height:calc(100vh - 64px);padding:20px 0;position:sticky;top:64px;overflow-y:auto}.nav-section{margin-bottom:24px;padding:0 12px}.nav-label{color:var(--text3);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px;padding:0 10px;font-size:10px;font-weight:700}.nav-item{cursor:pointer;color:var(--text2);-webkit-user-select:none;user-select:none;border-radius:9px;align-items:center;gap:10px;margin-bottom:2px;padding:9px 12px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg);color:var(--text)}.nav-item.active{color:#2563eb;background:#eff4ff;font-weight:600}.nav-icon{flex-shrink:0;font-size:17px}.nav-badge{color:#fff;background:#ef4444;border-radius:20px;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:700}.content{flex:1;padding:32px;overflow-y:auto}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.page-title{color:var(--navy);letter-spacing:-.6px;font-size:24px;font-weight:700}.page-sub{color:var(--text2);margin-top:4px;font-size:14px}.card{border:1px solid var(--border);background:#fff;border-radius:14px;padding:24px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}.stat-card{border:1px solid var(--border);background:#fff;border-radius:14px;padding:20px}.stat-label{color:var(--text3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px;font-size:11px;font-weight:700}.stat-value{color:var(--navy);letter-spacing:-1.5px;font-size:34px;font-weight:700;line-height:1}.stat-sub{color:var(--text2);margin-top:6px;font-size:12px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{text-align:left;color:var(--text3);letter-spacing:.7px;text-transform:uppercase;border-bottom:1px solid #f0f0f8;padding:12px 16px;font-size:11px;font-weight:700}tbody td{color:#374151;vertical-align:middle;border-bottom:1px solid #f9fafb;padding:14px 16px;font-size:14px}tbody tr:hover td{background:#fafbff}tbody tr:last-child td{border-bottom:none}.badge{white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge:before{content:"";background:currentColor;border-radius:50%;flex-shrink:0;width:6px;height:6px}.doc-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.doc-card{border:1.5px solid var(--border);background:#fff;border-radius:14px;padding:20px;transition:box-shadow .2s,border-color .2s;animation:.3s both fadeIn}.doc-card:hover{border-color:#c7d2e8;box-shadow:0 4px 20px #00000012}.doc-card.expire{background:#fff8f8;border-color:#fca5a5}.doc-card.manquant{background:#fffdf0;border-color:#fde68a}.doc-card.en_attente{background:#f0f7ff;border-color:#bfdbfe}.doc-head{align-items:flex-start;gap:10px;margin-bottom:14px;display:flex}.doc-icon{flex-shrink:0;margin-top:1px;font-size:22px}.doc-title{color:var(--navy);flex:1;font-size:13px;font-weight:600;line-height:1.4}.doc-info{color:var(--text2);flex-direction:column;gap:5px;margin-bottom:14px;font-size:13px;display:flex}.doc-row{align-items:baseline;gap:8px;display:flex}.doc-lbl{color:var(--text3);text-transform:uppercase;letter-spacing:.3px;min-width:68px;font-size:11px;font-weight:700}.doc-actions{gap:8px;display:flex}.btn-upload{color:#2563eb;cursor:pointer;background:#eff4ff;border:1.5px solid #dde8ff;border-radius:8px;flex:1;padding:9px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.btn-upload:hover{background:#dde8ff}.btn-icon{color:var(--text2);border:1.5px solid var(--border);cursor:pointer;background:#f4f6fb;border-radius:8px;align-items:center;padding:9px 13px;font-family:inherit;font-size:14px;text-decoration:none;transition:all .2s;display:inline-flex}.btn-icon:hover{background:var(--border)}.expiry-warn{color:#92400e;background:#fff7ed;border:1px solid #fed7aa;border-radius:8px;align-items:center;gap:7px;margin-bottom:12px;padding:8px 12px;font-size:12px;font-weight:500;display:flex}.alert{border-radius:10px;align-items:center;gap:12px;margin-bottom:10px;padding:14px 18px;font-size:14px;font-weight:500;animation:.3s fadeIn;display:flex}.alert-error{color:#991b1b;background:#fef2f2;border:1px solid #fca5a5}.alert-warn{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.alert-info{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe}.alert-success{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0}.overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:18px;width:100%;max-width:520px;margin:16px;animation:.25s fadeIn;overflow:hidden;box-shadow:0 24px 64px #0000002e}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:22px 28px;display:flex}.modal-title{color:var(--navy);font-size:18px;font-weight:700}.modal-close{cursor:pointer;width:32px;height:32px;color:var(--text2);background:#f4f6fb;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:18px;transition:background .2s;display:flex}.modal-close:hover{background:var(--border)}.modal-body{padding:24px 28px}.modal-foot{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:18px 28px;display:flex}.dropzone{text-align:center;cursor:pointer;background:#f8fafd;border:2px dashed #c7d2e8;border-radius:12px;margin-bottom:18px;padding:36px 20px;transition:all .2s}.dropzone:hover,.dropzone.drag{border-color:var(--accent);background:#eff4ff}.dz-icon{margin-bottom:12px;font-size:38px}.dz-text{color:#374151;font-size:14px;font-weight:600}.dz-sub{color:var(--text3);margin-top:5px;font-size:12px}.file-selected{background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:10px;align-items:center;gap:10px;margin-bottom:18px;padding:12px 16px;display:flex}.file-selected span{color:#15803d;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;font-weight:600;overflow:hidden}.file-clear{cursor:pointer;color:var(--text2);background:0 0;border:none;flex-shrink:0;font-size:16px}.loader-wrap{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:300px;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}.loader-text{color:var(--text2);font-size:14px}.notif-list{flex-direction:column;gap:10px;display:flex}.notif-item{border:1px solid var(--border);background:#fff;border-radius:12px;align-items:flex-start;gap:14px;padding:16px;transition:box-shadow .2s;animation:.3s fadeIn;display:flex}.notif-item:hover{box-shadow:0 2px 12px #0000000f}.notif-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.notif-body{flex:1}.notif-title{color:var(--navy);font-size:14px;font-weight:600}.notif-sub{color:var(--text2);margin-top:3px;font-size:13px}.email-preview{border:1px solid var(--border);color:#374151;background:#f8fafd;border-radius:12px;padding:20px;font-size:13px;line-height:1.8}.email-meta{border-bottom:1px solid var(--border);flex-direction:column;gap:4px;margin-bottom:14px;padding-bottom:12px;display:flex}.email-field{color:var(--text2);font-size:12px}.email-field b{color:#374151}.toolbar{align-items:center;gap:12px;margin-bottom:20px;display:flex}.search-input{border:1.5px solid var(--border);background:#fff;border-radius:9px;outline:none;flex:1;padding:10px 16px;font-family:inherit;font-size:14px}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4f8ef71a}.empty{text-align:center;color:var(--text3);padding:60px 20px}.empty-icon{margin-bottom:14px;font-size:48px}.empty-text{color:var(--text2);font-size:15px;font-weight:600}.empty-sub{color:var(--text3);margin-top:6px;font-size:13px}.setup-banner{background:linear-gradient(135deg,#fef3c7,#fff7ed);border:2px solid #fde68a;border-radius:14px;margin-bottom:28px;padding:28px}.setup-banner h3{color:#92400e;margin-bottom:12px;font-size:16px;font-weight:700}.setup-banner p{color:#78350f;margin-bottom:8px;font-size:13px;line-height:1.7}.setup-banner code{background:#00000014;border-radius:5px;padding:2px 7px;font-family:DM Mono,monospace;font-size:12px}.setup-banner pre{color:#e2e8f0;white-space:pre-wrap;background:#1a1d2e;border-radius:10px;margin:12px 0;padding:16px;font-family:DM Mono,monospace;font-size:11px;line-height:1.8;overflow-x:auto}@media (width<=900px){.login-wrap{grid-template-columns:1fr}.login-left{display:none}.stats-grid{grid-template-columns:repeat(2,1fr)}.sidebar{display:none}}
