.notification-center{display:inline-block;position:relative}.notification-bell{background:none;border:none;border-radius:8px;cursor:pointer;font-size:24px;padding:8px 12px;position:relative;transition:background-color .2s}.notification-bell:hover{background-color:#0000000d}.notification-badge{background-color:#e74c3c;border-radius:10px;color:#fff;font-size:11px;font-weight:700;min-width:18px;padding:2px 6px;position:absolute;right:4px;text-align:center;top:4px}.notification-dropdown{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;max-height:500px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:380px;z-index:1000}.notification-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px 20px}.notification-header h4{color:#333;font-size:18px;font-weight:600;margin:0}.mark-all-read{background:none;border:none;border-radius:4px;color:#3498db;cursor:pointer;font-size:13px;padding:4px 8px;transition:background-color .2s}.mark-all-read:hover{background-color:#3498db1a}.notification-list{max-height:400px;overflow-y:auto}.notification-empty,.notification-loading{color:#999;font-size:14px;padding:40px 20px;text-align:center}.notification-item{align-items:flex-start;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;padding:16px 20px;position:relative;transition:background-color .2s}.notification-item:hover{background-color:#f8f9fa}.notification-item.unread{background-color:#e3f2fd}.notification-item.unread:hover{background-color:#d0e7f8}.notification-icon{flex-shrink:0;font-size:24px;margin-right:12px}.notification-content{flex:1 1;min-width:0}.notification-title{color:#333;font-size:14px;font-weight:600;margin-bottom:4px}.notification-message{color:#666;font-size:13px;line-height:1.4;margin-bottom:6px;white-space:pre-line}.notification-time{color:#999;font-size:12px}.unread-dot{background-color:#3498db;border-radius:50%;height:8px;position:absolute;right:20px;top:20px;width:8px}.notification-footer{border-top:1px solid #e0e0e0;padding:12px 20px;text-align:center}.notification-footer button{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:14px;padding:6px 12px;transition:background-color .2s}.notification-footer button:hover{background-color:#0000000d}.notification-list::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track{background:#f1f1f1}.notification-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.notification-list::-webkit-scrollbar-thumb:hover{background:#999}@media (max-width:480px){.notification-dropdown{right:-20px;width:90vw}}.chef-zone-layout{display:flex;min-height:100vh}.chef-zone-sidebar{background-color:#007bff;color:#fff;display:flex;flex-direction:column;padding:20px;width:250px}.chef-zone-sidebar .sidebar-header h3{border-bottom:1px solid #fff3;margin-top:0;padding-bottom:20px;text-align:center}.chef-zone-sidebar .nav-list{flex-grow:1;list-style:none;margin-top:30px;padding:0}.chef-zone-sidebar .nav-list a{border-radius:5px;color:#e9ecef;display:block;margin-bottom:5px;padding:12px 15px;text-decoration:none;transition:background-color .2s}.chef-zone-sidebar .nav-list a.active{background-color:#0056b3;color:#fff;font-weight:700}.chef-zone-sidebar .nav-list a:hover{background-color:#0069d9}.chef-zone-content{background-color:#f8f9fa;display:flex;flex-direction:column;flex-grow:1}.chef-zone-sidebar .sidebar-logout-button{background-color:#fff3;border:1px solid #fff;border-radius:5px;color:#fff;cursor:pointer;font-weight:700;margin-top:40px;padding:10px;width:100%}.chef-zone-sidebar .sidebar-logout-button:hover{background-color:#ffffff4d}.responsable-layout{display:flex;min-height:100vh}.responsable-sidebar{background-color:#28a745;color:#fff;display:flex;flex-direction:column;padding:20px;width:250px}.responsable-sidebar .sidebar-header h3{border-bottom:1px solid #fff3;margin-top:0;padding-bottom:20px;text-align:center}.responsable-sidebar .nav-list{flex-grow:1;list-style:none;margin-top:30px;padding:0}.responsable-sidebar .nav-list a{border-radius:5px;color:#e9ecef;display:block;margin-bottom:5px;padding:12px 15px;text-decoration:none;transition:background-color .2s}.responsable-sidebar .nav-list a.active{background-color:#1e7e34;color:#fff;font-weight:700}.responsable-sidebar .nav-list a:hover{background-color:#218838}.responsable-content{background-color:#f8f9fa;display:flex;flex-direction:column;flex-grow:1}.responsable-content .top-navbar{align-items:center;background-color:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d;display:flex;justify-content:space-between;padding:12px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.responsable-content .navbar-spacer{flex:1 1}.responsable-sidebar .sidebar-logout-button{background-color:#fff3;border:1px solid #fff;border-radius:5px;color:#fff;cursor:pointer;font-weight:700;margin-top:40px;padding:10px;width:100%}.responsable-sidebar .sidebar-logout-button:hover{background-color:#ffffff4d}.superviseur-en-chef-layout{display:flex;min-height:100vh}.superviseur-en-chef-sidebar{background-color:#007ac1;color:#fff;display:flex;flex-direction:column;padding:20px;width:250px}.superviseur-en-chef-sidebar .sidebar-header h3{border-bottom:1px solid #fff3;margin-top:0;padding-bottom:20px;text-align:center}.superviseur-en-chef-sidebar .nav-list{flex-grow:1;list-style:none;margin-top:30px;padding:0}.superviseur-en-chef-sidebar .nav-list a{border-radius:5px;color:#e9ecef;display:block;margin-bottom:5px;padding:12px 15px;text-decoration:none;transition:background-color .2s}.superviseur-en-chef-sidebar .nav-list a.active{background-color:#0056b3;color:#fff;font-weight:700}.superviseur-en-chef-sidebar .nav-list a:hover{background-color:#4a90e2}.superviseur-en-chef-content{background-color:#f8f9fa;display:flex;flex-direction:column;flex-grow:1}.top-navbar{align-items:center;background-color:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d;display:flex;justify-content:space-between;padding:12px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.navbar-spacer{flex:1 1}.superviseur-en-chef-sidebar .sidebar-logout-button{background-color:#fff3;border:1px solid #fff;border-radius:5px;color:#fff;cursor:pointer;font-weight:700;margin-top:40px;padding:10px;width:100%}.superviseur-en-chef-sidebar .sidebar-logout-button:hover{background-color:#ffffff4d}.admin-layout{display:flex;min-height:100vh}.admin-sidebar{background:#282c34;color:#fff;padding:20px;width:250px}.admin-sidebar h3{text-align:center}.admin-sidebar ul{list-style:none;margin-top:30px;padding:0}.admin-sidebar li a{border-radius:4px;color:#ccc;display:block;padding:10px 15px;text-decoration:none}.admin-sidebar li a.active,.admin-sidebar li a:hover{background-color:#444;color:#fff}.admin-content{background-color:#f0f2f5;flex-grow:1;padding:30px}.admin-sidebar .logout-button{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:40px;padding:10px;width:100%}.dashboard-container{background-color:#f0f2f5;display:flex;flex-direction:column;font-family:sans-serif;min-height:100vh}.dashboard-header{background-color:#fff;border-bottom:1px solid #dee2e6;box-shadow:0 2px 4px #0000000d;padding:15px 30px}.dashboard-header h1{font-size:1.6em;margin:0}.header-user-info{align-items:center;display:flex}.header-user-info span{color:#333;font-size:1em;margin-right:20px}.logout-button{transition:background-color .2s}.logout-button:hover{background-color:#c82333}.dashboard-content{flex-grow:1;padding:30px}.kpi-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.kpi-card,.kpi-card-alert{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 12px #00000014;padding:25px}.kpi-card h2,.kpi-card-alert h2{color:#007bff;font-size:2.8em;font-weight:700;margin:0 0 10px}.kpi-card p,.kpi-card-alert p{color:#6c757d;font-size:1.1em;margin:0}.kpi-card-alert{background:linear-gradient(135deg,#fff3cd,#ffeeba);border-color:#ffeeba;cursor:pointer;transition:transform .2s ease-in-out,box-shadow .2s ease-in-out}.kpi-card-alert:hover{box-shadow:0 8px 16px #0000001a;transform:translateY(-5px)}.kpi-card-alert h2,.kpi-card-alert p{color:#856404}.kpi-card-action{color:#856404;display:block;font-weight:700;margin-top:15px;text-decoration:underline}.dashboard-widgets{grid-gap:25px;display:grid;gap:25px;grid-template-columns:1fr 1fr;margin-top:40px}.widget{border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:20px}.chart-widget{align-items:center;display:flex;flex-direction:column;justify-content:center}.chart-widget h3{border-bottom:1px solid #eee;margin-bottom:20px;padding-bottom:10px;text-align:center;width:100%}.dashboard-header{align-items:center;display:flex;justify-content:space-between}.header-actions{align-items:center;display:flex;gap:15px}.export-button{background-color:#17a2b8;font-weight:500;padding:8px 15px}.export-button:hover{background-color:#138496}.logout-button{background-color:#dc3545;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:500;padding:8px 15px}.page-container{background-color:#f8f9fa;font-family:sans-serif;min-height:100vh}.page-header{align-items:center;background-color:#fff;border-bottom:1px solid #dee2e6;box-shadow:0 2px 4px #0000000d;display:flex;justify-content:space-between;padding:20px 30px}.page-header h1{color:#343a40;font-size:1.5em}.back-button{font-weight:700;transition:background-color .2s}.back-button:hover{background-color:#5a6268}.page-content{padding:30px}.data-table th{color:#495057}.data-table tbody tr:hover{background-color:#f8f9fa}.status-badge{padding:5px 10px;text-transform:capitalize}.status-badge.pending{background-color:#fff3cd;color:#856404}.action-button{border-radius:4px;font-weight:500;padding:8px 12px;transition:opacity .2s}.action-button:hover{opacity:.8}.view-button{background-color:#007bff}.no-data-message{background-color:#fff;border-radius:8px;font-size:1.2em;padding:50px}.management-page{padding:20px}.management-page h1{margin-bottom:30px}.management-form-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:30px;padding:20px}.management-form{align-items:center;display:flex;gap:15px}.management-form input,.management-form select{border:1px solid #ccc;border-radius:4px;font-size:1em;padding:10px}.management-form button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:10px 20px}.management-table-container h3{margin-bottom:15px}.data-table{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d;overflow:hidden}.data-table td,.data-table th{border-bottom:1px solid #dee2e6;padding:12px 15px;text-align:left}.data-table th{background-color:#e9ecef}.table-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.table-header h3{margin:0}.search-input{border:1px solid #ccc;border-radius:6px;font-size:1em;max-width:350px;padding:8px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.search-input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff33;outline:none}.overlay{align-items:center;background-color:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:8px;box-shadow:0 5px 15px #0000004d;max-height:90vh;max-width:500px;outline:none;overflow-y:auto;padding:25px 30px;width:100%}.modal h2{border-bottom:1px solid #eee;color:#333;margin-bottom:25px;margin-top:0;padding-bottom:15px}.input-group{margin-bottom:20px}.input-group label{color:#555;display:block;font-weight:500;margin-bottom:8px}.input-group input,.input-group select{border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:1em;padding:10px;width:100%}.input-group-checkbox{align-items:center;display:flex;gap:10px;margin-bottom:20px}.modal-actions{border-top:1px solid #eee;margin-top:30px;padding-top:20px;text-align:right}.modal-actions button{border:none;border-radius:5px;cursor:pointer;font-weight:700;padding:10px 20px;transition:opacity .2s}.modal-actions button:hover{opacity:.8}.button-primary{background-color:#007bff;color:#fff}.button-secondary{background-color:#6c757d;color:#fff;margin-right:15px}.actions-cell{display:flex;gap:5px}.action-button.warning-button{background-color:#ffc107;color:#212529}.action-button.approve-button{background-color:#28a745}.checkbox-group{align-items:center;display:flex;padding:12px 0}.checkbox-group label{align-items:center;cursor:pointer;display:flex;gap:8px}.checkbox-group input[type=checkbox]{cursor:pointer;height:18px;width:18px}.checkbox-label{color:#333;font-size:14px;font-weight:500}.badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-align:center}.badge-gms{background-color:#3498db;color:#fff}.badge-petite{background-color:#95a5a6;color:#fff}.badge-superviseur{background-color:#e67e22;color:#fff}.badge-chef{background-color:#2ecc71;color:#fff}.zone-page-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:25px}.zone-page-title{color:#007ac1;font-size:1.8rem;font-weight:700;margin:0 0 8px}.zone-page-subtitle{color:#6c757d;font-size:1rem;margin:0}.zone-create-button{align-items:center;background:linear-gradient(135deg,#007ac1,#4a90e2);border:none;border-radius:10px;box-shadow:0 4px 12px #007ac14d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.zone-create-button:hover{box-shadow:0 6px 16px #007ac166;transform:translateY(-2px)}.zone-create-icon{font-size:1.4rem;font-weight:300}.zone-info-section{margin-bottom:25px}.zone-info-card{background:linear-gradient(135deg,#e3f2fd,#f5f9ff);border-left:4px solid #007ac1;border-radius:10px;padding:20px}.zone-info-title{color:#007ac1;font-size:1.1rem;margin:0 0 15px}.zone-info-content{display:flex;flex-direction:column;gap:10px}.zone-info-item{align-items:center;color:#495057;display:flex;gap:12px}.zone-info-number{align-items:center;background:#007ac1;border-radius:50%;color:#fff;display:flex;font-size:.9rem;font-weight:700;height:28px;justify-content:center;width:28px}.zone-info-tip{color:#007ac1;font-size:.95rem;font-style:italic;margin:15px 0 0}.zone-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:20px}.zone-table-header{margin-bottom:20px}.zone-table-title{color:#333;font-size:1.2rem;margin:0}.zone-empty-state{padding:60px 20px;text-align:center}.zone-empty-icon{font-size:4rem;margin-bottom:15px}.zone-empty-state p{color:#6c757d;font-size:1.1rem;margin-bottom:20px}.zone-empty-button{background:#007ac1;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 28px;transition:background .2s}.zone-empty-button:hover{background:#0056b3}.zone-table{border-collapse:collapse;width:100%}.zone-table th{background:linear-gradient(135deg,#007ac1,#4a90e2);color:#fff;font-weight:600;padding:14px 16px;text-align:left}.zone-table th:first-child{border-radius:8px 0 0 0}.zone-table th:last-child{border-radius:0 8px 0 0}.zone-table-row{transition:background .2s}.zone-table-row:hover{background:#f8f9fa}.zone-table td{border-bottom:1px solid #e9ecef;padding:14px 16px}.zone-table tr:last-child td{border-bottom:none}.zone-name-cell{color:#333;font-weight:600}.zone-base-badge{background:#e3f2fd;border-radius:12px;color:#007ac1;display:inline-block;font-size:.85rem;font-weight:600;padding:4px 12px}.zone-base-empty{color:#adb5bd}.zone-description-cell{color:#6c757d;font-size:.9rem}.zone-status-badge{border-radius:12px;display:inline-block;font-size:.85rem;font-weight:600;padding:4px 12px}.zone-status-badge.active{background:#d4edda;color:#155724}.zone-status-badge.inactive{background:#f8d7da;color:#721c24}.zone-actions-cell{display:flex;gap:6px}.zone-action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:1rem;height:36px;justify-content:center;transition:all .2s;width:36px}.zone-action-view{background:#e3f2fd}.zone-action-view:hover{background:#bbdefb;transform:scale(1.1)}.zone-action-edit{background:#fff3cd}.zone-action-edit:hover{background:#ffe69c;transform:scale(1.1)}.zone-action-delete{background:#f8d7da}.zone-action-delete:hover{background:#f5c6cb;transform:scale(1.1)}.zone-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.zone-modal{outline:none}.zone-modal-large .zone-modal-content{max-width:700px}.zone-modal-content{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:500px;overflow:hidden;width:100%}.zone-modal-header{align-items:flex-start;background:linear-gradient(135deg,#007ac1,#4a90e2);color:#fff;display:flex;justify-content:space-between;padding:24px 28px 20px}.zone-modal-title{font-size:1.4rem;font-weight:700;margin:0 0 6px}.zone-modal-subtitle{font-size:.9rem;margin:0;opacity:.9}.zone-modal-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:32px;justify-content:center;transition:background .2s;width:32px}.zone-modal-close:hover{background:#ffffff4d}.zone-modal-form{padding:28px}.zone-form-group{margin-bottom:20px}.zone-form-label{color:#495057;display:block;font-size:.95rem;font-weight:600;margin-bottom:8px}.zone-form-required{color:#dc3545}.zone-form-input,.zone-form-select,.zone-form-textarea{border:2px solid #e9ecef;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:border-color .2s,box-shadow .2s;width:100%}.zone-form-input:focus,.zone-form-select:focus,.zone-form-textarea:focus{border-color:#007ac1;box-shadow:0 0 0 3px #007ac11a;outline:none}.zone-form-textarea{min-height:80px;resize:vertical}.zone-form-checkbox{padding:12px 0}.zone-checkbox-label{align-items:center;color:#495057;cursor:pointer;display:flex;font-weight:500;gap:10px}.zone-checkbox{cursor:pointer;height:20px;width:20px}.zone-modal-actions{background:#f8f9fa;border-top:1px solid #e9ecef;display:flex;gap:12px;justify-content:flex-end;padding:20px 28px}.zone-modal-btn{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .2s}.zone-modal-btn-cancel{background:#6c757d;color:#fff}.zone-modal-btn-cancel:hover{background:#5a6268}.zone-modal-btn-confirm{background:#007ac1;color:#fff}.zone-modal-btn-confirm:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.zone-modal-btn-confirm:disabled{cursor:not-allowed;opacity:.6}.zone-details-content{max-height:60vh;overflow-y:auto;padding:28px}.zone-detail-section{margin-bottom:24px}.zone-detail-section:last-child{margin-bottom:0}.zone-detail-title{align-items:center;color:#007ac1;display:flex;font-size:1.1rem;gap:10px;margin:0 0 12px}.zone-detail-icon{font-size:1.3rem}.zone-detail-empty{color:#adb5bd;font-style:italic;margin:0}.zone-detail-list{list-style:none;margin:0;padding:0}.zone-detail-list-scrollable{background:#f8f9fa;border-radius:8px;max-height:150px;overflow-y:auto;padding:12px}.zone-detail-item{border-bottom:1px solid #e9ecef;color:#495057;padding:8px 0}.zone-detail-item:last-child{border-bottom:none}.zone-detail-id{color:#adb5bd;font-size:.85rem}.loading-container{align-items:center;color:#6c757d;display:flex;font-size:1.1rem;justify-content:center;padding:60px}.visit-detail-page{background-color:#f8f9fa;font-family:sans-serif;min-height:100vh;padding:20px}.detail-header{align-items:center;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:20px}.detail-header h1{margin:0}.back-button{background-color:#6c757d;border:none;border-radius:5px;color:#fff;cursor:pointer;padding:10px 15px}.form-content{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.detail-section{margin-bottom:30px}.detail-section h2{border-bottom:2px solid #007bff;color:#333;margin-bottom:15px;padding-bottom:10px}.detail-item{margin-bottom:10px}.detail-item p{margin:0}.detail-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:10px}.detail-grid .detail-item{background-color:#f8f9fa;border-left:3px solid #007bff;border-radius:5px;padding:12px}.observation-text{background-color:#e9ecef;border-radius:5px;margin-top:5px;padding:10px}.actions-section{text-align:center}.action-button{border-radius:5px;color:#fff;font-size:1em;font-weight:700;padding:12px 25px}.approve-button{background-color:#28a745;margin-right:15px}.reject-button{background-color:#dc3545}table{border-collapse:collapse;width:100%}td,th{border:1px solid #ddd;padding:8px;text-align:left}th{background-color:#f2f2f2}.error,.loading{font-size:1.2em;padding:50px;text-align:center}.error{color:red}.status-badge{border-radius:12px;font-size:.85em;font-weight:700;padding:4px 12px;text-transform:uppercase}.status-badge.soumis{background-color:#ffc107;color:#000}.status-badge.valide{background-color:#28a745;color:#fff}.status-badge.rejete{background-color:#dc3545;color:#fff}.actors-section,.client-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.stock-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));margin-top:15px}.stock-card{background-color:#fff;border:2px solid #dee2e6;border-radius:8px;padding:12px;transition:transform .2s,box-shadow .2s}.stock-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.stock-card.disponible{border-left:4px solid #28a745}.stock-card.rupture{background-color:#fff5f5;border-left:4px solid #dc3545}.stock-card-header{align-items:center;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;margin-bottom:10px;padding-bottom:8px}.rupture-badge{color:#dc3545;font-size:.75em;font-weight:700}.stock-card-body{font-size:.9em}.stock-info{display:flex;justify-content:space-between;margin-bottom:5px}.stock-label{color:#6c757d;font-size:.85em}.stock-value{color:#212529;font-weight:700}.details-container{margin-top:15px}.details-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.details-column h3{border-radius:5px;color:#fff;margin-bottom:15px;margin-top:0;padding:10px;text-align:center}.details-column.commandes h3{background-color:#007bff}.details-column.incidents h3{background-color:#dc3545}.detail-card{background-color:#f8f9fa;border-left:4px solid #007bff;border-radius:5px;margin-bottom:10px;padding:12px}.detail-card.incident{border-left-color:#dc3545}.detail-card-title{color:#212529;font-weight:700;margin-bottom:5px}.detail-card-qty{color:#6c757d;font-size:.9em;margin-bottom:5px}.detail-card-obs{border-top:1px solid #dee2e6;color:#495057;font-size:.85em;font-style:italic;margin-top:8px;padding-top:8px}.veille-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:15px}.veille-card{background-color:#fff;border:2px solid #6c757d;border-radius:8px;overflow:hidden;transition:transform .2s,box-shadow .2s}.veille-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.veille-header{background-color:#6c757d;color:#fff;font-size:1em;padding:12px}.veille-body{padding:15px}.veille-info{border-bottom:1px solid #dee2e6;margin-bottom:10px;padding-bottom:10px}.veille-info:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.veille-label{color:#6c757d;display:block;font-size:.85em;margin-bottom:3px}.veille-value{color:#212529;display:block;font-weight:500}.no-data-message{background-color:#f8f9fa;border-radius:5px;color:#6c757d;font-style:italic;padding:30px;text-align:center}.geolocation-section{background-color:#fff;border:2px solid #007bff;border-radius:8px;margin-bottom:20px;padding:15px 20px}.geolocation-status{display:flex;justify-content:center;margin-bottom:15px}.geo-badge{border-radius:25px;display:inline-block;font-size:1.2em;font-weight:700;padding:12px 30px;text-align:center}.geo-badge.on-site{background-color:#28a745;box-shadow:0 2px 8px #28a74566;color:#fff}.geo-badge.off-site{background-color:#dc3545;box-shadow:0 2px 8px #dc354566;color:#fff}.geo-badge.no-gps{background-color:#6c757d;color:#fff}.photos-rayon-grid{display:flex;flex-direction:column;gap:24px}.photos-rayon-type{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:16px}.photos-rayon-type h3{color:#495057;font-size:18px;font-weight:600;margin:0 0 16px}.photos-moment-container{display:flex;flex-direction:column;gap:20px}.photo-moment-section{background-color:#fff;border:1px solid #e9ecef;border-radius:6px;padding:12px}.photo-moment-label{color:#6c757d;font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.photos-moment-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.photo-moment-box{align-items:center;display:flex;flex-direction:column}.photos-grid{grid-gap:12px;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.photo-item{background-color:#fff;padding:8px;position:relative;text-decoration:none;transition:all .2s}.photo-item:hover{transform:translateY(-2px)}.photo-preview{border-radius:6px;cursor:pointer;height:auto;max-height:200px;object-fit:cover;transition:transform .2s;width:100%}.photo-preview:hover{transform:scale(1.02)}.photo-number{background-color:#007ac1e6;border-radius:12px;color:#fff;font-size:12px;font-weight:600;left:12px;padding:4px 8px;position:absolute;top:12px}.photo-placeholder{align-items:center;background-color:#e9ecef;border:2px dashed #adb5bd;border-radius:8px;color:#6c757d;display:flex;font-size:14px;font-style:italic;height:150px;justify-content:center;width:100%}.photos-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-top:15px}.photo-item{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;display:flex;flex-direction:column;padding:12px;transition:box-shadow .2s}.photo-item:hover{box-shadow:0 4px 12px #00000026}.photo-item-label{color:#495057;font-size:14px;font-weight:600;margin-bottom:10px;text-align:center}.photo-timestamp{color:#6c757d;font-size:12px;font-style:italic;margin-top:8px;text-align:center}.equipment-card{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;display:flex;flex-direction:column;gap:15px;padding:15px;transition:box-shadow .2s}.equipment-card:hover{box-shadow:0 2px 8px #0000001a}.equipment-info{flex:1 1}.equipment-photo{align-items:center;display:flex;justify-content:center;margin-top:10px}.equipment-photo-img{border:2px solid #007bff;border-radius:8px;height:150px;object-fit:cover;transition:transform .2s;width:150px}.equipment-photo-img:hover{transform:scale(1.05)}.incident-card{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;display:flex;flex-direction:column;gap:15px;padding:15px;transition:box-shadow .2s}.incident-card:hover{box-shadow:0 2px 8px #0000001a}.incident-info{flex:1 1}.incident-photos{border-top:1px solid #dee2e6;margin-top:10px;padding-top:10px}.incident-photos-label{color:#495057;font-size:13px;font-weight:600;margin-bottom:8px}.incident-photos-grid{display:flex;flex-wrap:wrap;gap:8px}.incident-photo-link{display:inline-block}.incident-photo-img{border:2px solid #dc3545;border-radius:6px;height:100px;object-fit:cover;transition:transform .2s;width:100px}.incident-photo-img:hover{transform:scale(1.1)}.actions-section{border-top:2px solid #dee2e6;display:flex;gap:15px;justify-content:center;margin-top:30px;padding-top:20px}.actions-section .action-button{border:none;border-radius:6px;cursor:pointer;font-size:1em;font-weight:600;padding:12px 30px;transition:all .2s}.actions-section .approve-button{background-color:#28a745;color:#fff}.actions-section .approve-button:hover{background-color:#218838}.actions-section .reject-button{background-color:#dc3545;color:#fff}.actions-section .reject-button:hover{background-color:#c82333}.status-section{border-top:2px solid #dee2e6;display:flex;justify-content:center;margin-top:30px;padding-top:20px}.status-message{align-items:center;border-radius:8px;display:flex;flex-direction:column;gap:10px;padding:20px 40px;text-align:center}.status-message.valide{background-color:#d4edda;border:2px solid #28a745;color:#155724}.status-message.rejete{background-color:#f8d7da;border:2px solid #dc3545;color:#721c24}.status-icon{font-size:2em;font-weight:700}.status-message p{font-size:1.1em;margin:0}.validator-info{font-size:.9em;opacity:.8}.admin-dashboard h1{color:#1a202c;font-size:2em;margin-bottom:30px}.admin-kpi-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.admin-kpi-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 5px 15px #0000000d;display:flex;padding:20px;transition:transform .2s,box-shadow .2s}.admin-kpi-card:hover{box-shadow:0 8px 20px #00000014;transform:translateY(-5px)}.kpi-icon{align-items:center;background-color:#edf2f7;border-radius:50%;display:flex;font-size:2.5em;height:60px;justify-content:center;margin-right:20px;width:60px}.kpi-text{display:flex;flex-direction:column}.kpi-value{color:#2d3748;font-size:1.8em;font-weight:700}.kpi-label{color:#718096;font-size:1em}.admin-widgets{grid-gap:25px;display:grid;gap:25px;grid-template-columns:1fr 1fr;margin-top:40px}.widget{background-color:#fff;border-radius:12px;box-shadow:0 5px 15px #0000000d;padding:25px}.widget h3{border-bottom:1px solid #e2e8f0;color:#1a202c;margin-bottom:20px;margin-top:0;padding-bottom:15px}.chart-container{height:300px;margin:0 auto;max-width:350px}.activity-list{list-style:none;margin:0;padding:0}.activity-list li{border-bottom:1px solid #f0f2f5;color:#4a5568;padding:10px 0}.activity-list li:last-child{border-bottom:none}.activity-list li span{color:#2d3748;font-weight:700;margin-right:10px}.loading{font-size:1.2em;padding:50px;text-align:center}.admin-page{margin:0 auto;max-width:1400px;padding:20px}.page-header{margin-bottom:30px}.page-header h1{color:#333;font-size:1.8rem;margin:0}.stats-section{margin-bottom:30px}.stats-title{color:#333;font-size:1.1rem;font-weight:600;margin-bottom:15px}.stats-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:20px;text-align:center}.stat-card.success{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.stat-card.warning{background:linear-gradient(135deg,#ffc107,#ff9800);color:#fff}.stat-value{font-size:2.5rem;font-weight:700;margin-bottom:5px}.stat-label{font-size:.9rem;opacity:.9}.stats-users{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:20px}.stats-users h3{color:#333;font-size:1.1rem;margin-bottom:15px}.users-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.user-stat-card{align-items:center;background:#f8f9fa;border-left:3px solid #007ac1;border-radius:8px;display:flex;justify-content:space-between;padding:15px}.user-stat-card strong{color:#333;font-size:.95rem}.user-stat-count{background:#007ac1;border-radius:12px;color:#fff;font-size:.85rem;font-weight:600;padding:4px 10px}.zones-stats-container{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:20px}.zones-stats-container h3{color:#333;font-size:1.1rem;margin-bottom:15px}.zones-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.zone-stat-card{background:#f8f9fa;border-left:3px solid #007ac1;border-radius:8px;padding:15px}.zone-stat-card strong{color:#333;display:block;font-size:1rem;margin-bottom:10px}.zone-stat-details{display:flex;flex-direction:column;gap:5px}.zone-stat-total{color:#666;font-size:.9rem}.zone-stat-with{color:#28a745;font-size:.9rem;font-weight:600}.zone-stat-without{color:#ffc107;font-size:.9rem;font-weight:600}.no-gps{color:#999;font-style:italic}.no-action{color:#ccc}.coords-cell.present,.coords-cell.present .coord-value{color:#28a745}.filters-container{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px;padding:20px}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{color:#333;font-size:.9rem;font-weight:600}.filter-group select{border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:.95rem;min-width:200px;padding:10px 15px}.filter-group select:focus{border-color:#007ac1;box-shadow:0 0 0 3px #007ac11a;outline:none}.table-container{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table thead{background:#007ac1;color:#fff}.data-table th{font-size:.9rem;font-weight:600;padding:15px 12px;text-align:left}.data-table td{border-bottom:1px solid #e0e0e0;padding:12px}.data-table tbody tr:hover{background:#f5f5f5}.date-cell{min-width:120px}.date-day{color:#333;font-weight:600;margin-bottom:2px}.date-time{color:#666;font-size:.85rem}.coords-cell{min-width:180px}.coord-value{color:#28a745;font-family:monospace;font-size:.85rem}.action-button{border:none;border-radius:6px;cursor:pointer;font-size:.85rem;margin-right:5px;padding:6px 10px;transition:all .2s}.view-button{background:#007ac1;color:#fff}.view-button:hover{background:#0056b3}.delete-button{background:#dc3545;color:#fff}.delete-button:hover{background:#c82333}.photo-link{align-items:center;background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:.85rem;gap:5px;padding:6px 12px;transition:all .2s}.photo-link:hover{background:#218838}.no-photo{color:#ccc}.photo-modal-overlay{align-items:center;background-color:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.photo-modal{background:#0000;border:none;max-width:900px;outline:none;position:relative;width:90%}.photo-modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;overflow:hidden}.photo-modal-header{align-items:center;background:#007ac1;border-bottom:1px solid #e0e0e0;color:#fff;display:flex;justify-content:space-between;padding:20px}.photo-modal-header h2{font-size:1.2rem;margin:0}.close-modal-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:36px;justify-content:center;transition:all .2s;width:36px}.close-modal-btn:hover{background:#ffffff4d}.photo-modal-body{align-items:center;background:#f5f5f5;display:flex;justify-content:center;min-height:400px;padding:20px}.photo-modal-image{border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:70vh;max-width:100%}.photo-modal-footer{border-top:1px solid #e0e0e0;display:flex;gap:10px;justify-content:flex-end;padding:15px 20px}.no-data{color:#999;font-style:italic;padding:40px;text-align:center}.export-container{padding:30px}.export-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:20px}.export-header h1{color:#333;font-size:28px;margin:0}.export-button{background-color:#28a745;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;font-weight:700;padding:12px 24px;transition:background-color .2s}.export-button:hover:not(:disabled){background-color:#218838}.export-button:disabled{background-color:#6c757d;cursor:not-allowed}.export-stats{background-color:#e7f3ff;border-radius:5px;display:flex;gap:30px;margin-bottom:20px;padding:15px 20px}.export-stats p{color:#333;font-size:16px;margin:0}.export-stats strong{color:#007bff}.empty-state{color:#6c757d;font-size:18px;padding:60px 20px;text-align:center}.visites-table{background-color:#fff;border-collapse:collapse;border-radius:5px;box-shadow:0 2px 4px #0000001a;overflow:hidden;width:100%}.visites-table thead{background-color:#007bff;color:#fff}.visites-table th{font-weight:700;padding:15px;text-align:left}.visites-table td{border-bottom:1px solid #e9ecef;padding:12px 15px}.visites-table tbody tr{transition:background-color .2s}.visites-table tbody tr:hover{background-color:#f8f9fa}.visites-table tbody tr.selected{background-color:#e7f3ff}.visites-table input[type=checkbox]{cursor:pointer;height:18px;width:18px}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.0c700d6b.css.map*/