:root{--ci-orange: #F57C00;--ci-orange-dark: #E65100;--ci-green: #43A047;--ci-green-dark: #388E3C;--ci-white: #FFFFFF;--ci-light: #FFF8F0;--ci-success: #43A047;--ci-warning: #F57C00;--ci-danger: #C62828;--ci-blue: #1565C0;--ci-blue-dark: #1976D2;--ci-purple: #7B1FA2;--bg-color: var(--ci-light);--card-bg: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--sidebar-width: 260px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,system-ui,sans-serif;background:var(--bg-color);color:var(--text-primary);line-height:1.6}.app-container{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:linear-gradient(180deg,var(--ci-green-dark) 0%,var(--ci-green) 100%);color:#fff;position:fixed;height:100vh;overflow-y:auto;transition:transform .3s;z-index:100;display:flex;flex-direction:column}.sidebar-brand{padding:1.5rem 1.2rem;border-bottom:1px solid rgba(255,255,255,.1);text-align:center}.sidebar-brand h5{color:#fff;margin:0;font-weight:700;font-size:1.1rem}.sidebar-brand small{color:#fff9;font-size:.75rem}.sidebar-user{background:#ffffff1a;border-radius:8px;padding:.6rem 1rem;margin:.5rem 1rem}.sidebar-user small{color:#fff9}.sidebar-user .user-name{color:#fff;font-weight:600;font-size:.85rem}.sidebar-user .user-role{display:inline-block;margin-top:.25rem;background:#ffffffe6;color:#333;font-size:.7rem;padding:.15em .5em;border-radius:4px}.sidebar-nav{padding:.5rem 0;flex:1}.nav-item{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.2rem;color:#ffffffbf;text-decoration:none;font-size:.9rem;border-left:3px solid transparent;transition:all .2s}.nav-item:hover,.nav-item.active{color:#fff;background:#ffffff14;border-left-color:var(--ci-orange)}.nav-item i{width:24px;text-align:center;margin-right:.5rem}.nav-item .nav-label{flex:1}.nav-item .nav-count{font-size:.7rem;padding:.15em .5em;border-radius:10px;background:#fff3;color:#fff}.sidebar-footer{padding:1rem 1.2rem;border-top:1px solid rgba(255,255,255,.1)}.main-content{flex:1;margin-left:var(--sidebar-width);padding:0;min-height:100vh}.top-bar{background:#fff;border-bottom:1px solid #e2e8f0;padding:.8rem 1.5rem;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:50}.top-bar .breadcrumb{margin:0;font-size:.85rem;display:flex;gap:.5rem;list-style:none}.top-bar .breadcrumb a{color:var(--ci-green-dark);text-decoration:none}.top-bar .breadcrumb a:hover{text-decoration:underline}.top-bar .breadcrumb .separator{color:#999}.top-bar-user{display:flex;align-items:center;gap:.5rem}.top-bar-user .user-avatar{width:32px;height:32px;border-radius:50%;background:var(--ci-green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600}.page-content{padding:1.5rem}.card{background:var(--card-bg);border-radius:12px;box-shadow:0 1px 3px #00000014;margin-bottom:1rem;border:none;overflow:hidden}.card-header-bar{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:#fff;border-bottom:1px solid #edf2f7;font-weight:600}.card-body{padding:1.25rem}.card-body-flush{padding:0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden}.stat-card .stat-body{display:flex;align-items:center;gap:.75rem;padding:1.25rem}.stat-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.stat-icon.bg-primary{background:#0d6efd1a;color:#0d6efd}.stat-icon.bg-success{background:#43a0471a;color:#43a047}.stat-icon.bg-info{background:#0dcaf01a;color:#0dcaf0}.stat-icon.bg-warning{background:#f57c001a;color:#f57c00}.stat-card .stat-value{font-size:1.8rem;font-weight:700;line-height:1.2}.stat-card .stat-label{font-size:.8rem;color:#718096;text-transform:uppercase;letter-spacing:.5px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1.2rem;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;gap:.4rem;border:none;font-size:.9rem;text-decoration:none}.btn-dfrc{background:var(--ci-orange);color:#fff}.btn-dfrc:hover{background:var(--ci-orange-dark);color:#fff}.btn-primary{background:var(--ci-orange);color:#fff}.btn-primary:hover{background:var(--ci-orange-dark);color:#fff}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268;color:#fff}.btn-success{background:var(--ci-success);color:#fff}.btn-success:hover{background:var(--ci-green-dark);color:#fff}.btn-danger{background:var(--ci-danger);color:#fff}.btn-danger:hover{background:#b71c1c;color:#fff}.btn-warning{background:var(--ci-warning);color:#fff}.btn-outline-primary{background:transparent;color:#0d6efd;border:1px solid #0d6efd}.btn-outline-primary:hover{background:#0d6efd;color:#fff}.btn-outline-secondary{background:transparent;color:#6c757d;border:1px solid #6c757d}.btn-outline-secondary:hover{background:#6c757d;color:#fff}.btn-outline-success{background:transparent;color:var(--ci-green);border:1px solid var(--ci-green)}.btn-outline-success:hover{background:var(--ci-green);color:#fff}.btn-outline-danger{background:transparent;color:var(--ci-danger);border:1px solid var(--ci-danger)}.btn-outline-danger:hover{background:var(--ci-danger);color:#fff}.btn-outline-warning{background:transparent;color:var(--ci-warning);border:1px solid var(--ci-warning)}.btn-outline-warning:hover{background:var(--ci-warning);color:#fff}.btn-sm{padding:.375rem .75rem;font-size:.8rem}.btn-lg{padding:.7rem 1.5rem;font-size:1rem}.btn-group{display:flex;gap:.25rem}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.25rem;font-weight:500;font-size:.9rem}.form-control,.form-input,.form-select,.form-textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.form-control-sm{padding:.35rem .6rem;font-size:.85rem}.form-control:focus,.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--ci-orange);box-shadow:0 0 0 .2rem #f57c0040}.input-group{display:flex}.input-group .input-group-text{padding:.5rem .75rem;background:#f8f9fa;border:1px solid var(--border-color);border-right:none;border-radius:8px 0 0 8px;display:flex;align-items:center}.input-group .form-control{border-radius:0 8px 8px 0}.text-danger{color:var(--ci-danger)}.table-container{overflow-x:auto}.table{width:100%;border-collapse:separate;border-spacing:0}.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #edf2f7;vertical-align:middle}.table th{background:var(--ci-green-dark);color:#fff;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;font-weight:600;border:none}.table th:first-child{border-radius:8px 0 0}.table th:last-child{border-radius:0 8px 0 0}.table tbody tr:hover{background:#edf2f7}.badge{display:inline-block;padding:.3em .7em;border-radius:6px;font-size:.75rem;font-weight:600}.badge-planifiee{background:#ebf4ff;color:#2b6cb0}.badge-en-cours{background:#f0fff4;color:#276749}.badge-suspendue{background:#fff3e0;color:#e65100}.badge-terminee{background:#f7fafc;color:#718096}.badge-en-salle{background:#fefcbf;color:#975a16}.badge-absent{background:#fff5f5;color:#c53030}.badge-present,.badge-success{background:#f0fff4;color:#276749}.badge-warning{background:#fff3e0;color:#e65100}.badge-danger{background:#fff5f5;color:#c53030}.badge-info{background:#ebf4ff;color:#2b6cb0}.badge-secondary{background:#f7fafc;color:#718096}.badge-bg-secondary{background:#6c757d;color:#fff;padding:.25em .5em;border-radius:6px;font-size:.75rem}.badge-bg-success{background:var(--ci-green);color:#fff;padding:.25em .5em;border-radius:6px;font-size:.75rem}.badge-bg-primary{background:#0d6efd;color:#fff;padding:.25em .5em;border-radius:6px;font-size:.75rem}.badge-bg-info{background:#0dcaf0;color:#fff;padding:.25em .5em;border-radius:6px;font-size:.75rem}.badge-direction{background:#fa5f5f;color:#fff}.badge-dfrc{background:#ef5ce3;color:#fff}.badge-secretariat{background:#388e3c;color:#fff}.badge-superviseur,.badge-encadrant{background:#f57c00;color:#fff}.badge-participant{background:#43a047;color:#fff}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#388e3c,#43a047 40%,#f57c00)}.login-card{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 20px 60px #0000004d;width:100%;max-width:420px}.login-brand{text-align:center;margin-bottom:2rem}.login-brand h3{color:#388e3c;font-weight:700;margin-top:.5rem}.login-brand p{color:#718096;font-size:.9rem}.login-brand .subtitle{color:#f57c00;font-weight:600;font-size:.8rem}.btn-login{background:linear-gradient(135deg,#f57c00,#e65100);border:none;padding:.7rem;font-weight:600;border-radius:10px;color:#fff;width:100%;cursor:pointer;font-size:1rem}.btn-login:hover{background:linear-gradient(135deg,#e65100,#bf360c)}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:1rem;padding:1rem}.pagination-btn{padding:.5rem .75rem;border:1px solid var(--border-color);background:#fff;border-radius:8px;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--ci-light);border-color:var(--ci-orange)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #edf2f7}.modal-header h5{font-weight:600;margin:0}.modal-body{padding:1.25rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid #edf2f7}.btn-close{background:none;border:none;font-size:1.25rem;cursor:pointer;color:#666;padding:.25rem}.alert{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;display:flex;align-items:flex-start;gap:.5rem}.alert-success{background:#f0fff4;color:#276749;border-left:4px solid var(--ci-success)}.alert-danger{background:#fff5f5;color:#c53030;border-left:4px solid var(--ci-danger)}.alert-warning{background:#fff3e0;color:#e65100;border-left:4px solid var(--ci-warning)}.alert-info{background:#ebf4ff;color:#2b6cb0;border-left:4px solid #2b6cb0}.error-message{background:#fff5f5;color:#c53030;padding:1rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid var(--ci-danger)}.success-message{background:#f0fff4;color:#276749;padding:1rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid var(--ci-success)}.loading{display:flex;justify-content:center;align-items:center;padding:2rem}.spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--ci-orange);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.row{display:flex;flex-wrap:wrap;margin:-.5rem}.row>*{padding:.5rem}.col-md-3{flex:0 0 25%;max-width:25%}.col-md-4{flex:0 0 33.333%;max-width:33.333%}.col-md-6{flex:0 0 50%;max-width:50%}.col-lg-4{flex:0 0 33.333%;max-width:33.333%}.col-lg-8{flex:0 0 66.666%;max-width:66.666%}.col-12{flex:0 0 100%;max-width:100%}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.text-muted{color:#718096}.text-center{text-align:center}.text-end{text-align:right}.text-success{color:#276749}.text-danger{color:#c53030}.fw-semibold{font-weight:600}.small{font-size:.85rem}.d-flex{display:flex}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.mb-0{margin-bottom:0}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.me-1{margin-right:.25rem}.me-2{margin-right:.5rem}.ms-1{margin-left:.25rem}.ms-2{margin-left:.5rem}.ms-3{margin-left:.75rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-4{padding-top:1.5rem;padding-bottom:1.5rem}.d-inline-block{display:inline-block}.table-sm td,.table-sm th{padding:.35rem .75rem}.p-3{padding:.75rem}.w-100{width:100%}.session-card{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.session-card.active{border-color:var(--ci-green)}.session-card.planned{border-color:#0dcaf0}.session-card-header{padding:.5rem .75rem;font-size:.85rem}.session-card-body{padding:.75rem;text-align:center}.import-card-header{padding:.75rem 1rem;color:#fff;font-weight:600}.sidebar-toggle{display:none}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar.show{transform:translate(0)}.main-content{margin-left:0}.sidebar-toggle{display:inline-flex!important}.stats-grid{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.row>.col-md-3,.row>.col-md-4,.row>.col-md-6,.row>.col-lg-4,.row>.col-lg-8{flex:0 0 100%;max-width:100%}}
