.layout{background-color:var(--color-background-default);display:flex;flex-direction:column;height:100vh}.header{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fffc;border-bottom:1px solid var(--color-gray-200);position:sticky;top:0;transition:var(--transition-normal);z-index:1000}.header:after{background:var(--gradient-swoosh);bottom:0;content:"";height:2px;left:0;opacity:.8;position:absolute;right:0}.header-content{height:72px;justify-content:space-between;margin:0 auto;max-width:1600px;padding:0 var(--spacing-md)}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:var(--spacing-md)}.header-logo{height:36px;object-fit:contain}.nav{gap:var(--spacing-xs)}.nav,.nav-link{align-items:center;display:flex}.nav-link{border-radius:var(--border-radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;gap:4px;padding:var(--spacing-xs) var(--spacing-sm);text-decoration:none;transition:var(--transition-fast);white-space:nowrap}.nav-link:hover{background:#76b82a0d;color:var(--color-primary-main)}.nav-link-active{background:#76b82a1a;color:var(--color-primary-main)}.header-right{align-items:center;display:flex;gap:var(--spacing-lg)}.lang-select{background:#0000;border:1px solid var(--color-gray-300);border-radius:var(--border-radius-md);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-xs);font-weight:600;padding:var(--spacing-xs) var(--spacing-sm);transition:var(--transition-fast)}.lang-select:hover{border-color:var(--color-primary-main);color:var(--color-primary-main)}.notif-btn,.notif-wrapper{position:relative}.notif-btn{align-items:center;background:#0000;border:1px solid var(--color-gray-300);border-radius:var(--border-radius-md);color:var(--color-text-secondary);cursor:pointer;display:inline-flex;justify-content:center;padding:var(--spacing-xs) var(--spacing-sm);transition:var(--transition-fast)}.notif-btn:hover{border-color:var(--color-primary-main);color:var(--color-primary-main)}.notif-badge{align-items:center;background:var(--color-error-main);border-radius:999px;color:#fff;display:flex;font-size:11px;font-weight:700;height:18px;justify-content:center;min-width:18px;padding:0 5px;position:absolute;right:-6px;top:-6px}.notif-dropdown{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;position:absolute;right:0;top:calc(100% + 10px);width:360px;z-index:2000}.notif-dropdown-header{align-items:center;border-bottom:1px solid var(--color-gray-200);display:flex;justify-content:space-between;padding:var(--spacing-md)}.notif-title{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:800}.notif-markall{background:#0000;border:none;color:var(--color-primary-main);cursor:pointer;font-size:var(--font-size-xs);font-weight:700}.notif-list{max-height:360px;overflow:auto}.notif-empty{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;padding:var(--spacing-lg)}.notif-item{background:#fff;border:none;border-bottom:1px solid var(--color-gray-100);cursor:pointer;padding:var(--spacing-md);text-align:left;width:100%}.notif-item:hover{background:#76b82a0d}.notif-item-unread{background:#76b82a14}.notif-item-title{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:800;margin-bottom:4px}.notif-item-msg{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:600}.user-menu-wrapper{position:relative}.user-profile{align-items:center;background:var(--color-gray-100);border:none;border-radius:var(--border-radius-md);cursor:pointer;display:flex;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);transition:var(--transition-fast)}.user-profile:hover{background:var(--color-gray-200)}.user-avatar{align-items:center;background:var(--color-primary-main);border-radius:50%;color:#fff;display:flex;font-size:var(--font-size-xs);font-weight:700;height:32px;justify-content:center;width:32px}.user-details{display:flex;flex-direction:column;text-align:left}.user-name{color:var(--color-text-primary);font-size:var(--font-size-xs);font-weight:700;line-height:1.2}.user-role{font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.user-menu-icon,.user-role{color:var(--color-text-secondary)}.user-menu-icon{transition:var(--transition-fast)}.user-profile:hover .user-menu-icon{color:var(--color-text-primary)}.user-dropdown{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);min-width:200px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}.user-dropdown-item{align-items:center;background:#0000;border:none;color:var(--color-text-primary);cursor:pointer;display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);text-align:left;transition:var(--transition-fast);width:100%}.user-dropdown-item:hover{background:var(--color-gray-100)}.user-dropdown-item svg{color:var(--color-text-secondary)}.user-dropdown-logout{border-top:1px solid var(--color-gray-200)}.user-dropdown-logout,.user-dropdown-logout svg{color:var(--color-error-main)}.user-dropdown-logout:hover{background:var(--color-error-light)}.main-content{display:flex;flex-direction:column;margin:0 auto;max-width:1400px;width:100%}.footer,.main-content{padding:var(--spacing-xl)}.footer{border-top:1px solid var(--color-gray-200);color:var(--color-text-secondary);font-size:var(--font-size-xs);text-align:center}.menu-toggle{display:none}@media (max-width:768px){.header-content{padding:0 var(--spacing-md)}.header-left{gap:var(--spacing-md);min-width:0}.header-logo{height:32px}.user-profile{background:#0000;padding:0}.user-details{display:none}.main-content{padding:var(--spacing-lg)}.menu-toggle{background:#0000;border:none;color:var(--color-text-primary);cursor:pointer;display:block;font-size:24px}.nav{display:none}.nav-open{background:#fff;border-bottom:1px solid var(--color-gray-200);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;left:0;max-height:calc(100vh - 72px);overflow:auto;padding:var(--spacing-md);position:absolute;right:0;top:72px}.header-right{gap:var(--spacing-md)}.notif-dropdown{left:var(--spacing-sm);max-width:calc(100vw - var(--spacing-sm)*2);position:fixed;right:var(--spacing-sm);top:80px;width:auto}.notif-list{max-height:calc(100vh - 200px)}}@media (max-width:420px){.header-content{padding:0 var(--spacing-sm)}.main-content{padding:var(--spacing-sm)}.header-right{gap:var(--spacing-sm)}.nav-link{font-size:var(--font-size-xs);padding:var(--spacing-xs) var(--spacing-sm)}.notif-dropdown{border-radius:0;left:0;max-width:100vw;right:0;top:72px}.notif-dropdown-header,.notif-item{padding:var(--spacing-sm)}.notif-item-title{font-size:.8125rem}.lang-select,.notif-item-msg{font-size:.75rem}.lang-select{padding:.25rem .375rem}}.login-page{background-color:#fff;display:flex;font-family:Outfit,sans-serif;min-height:100vh;overflow:hidden}.login-side-decoration{align-items:center;background-image:url(https://images.unsplash.com/photo-1581091226825-a6a2a5aee158?auto=format&fit=crop&q=80&w=2070);background-position:50%;background-size:cover;color:#fff;display:flex;flex:1.2;justify-content:center;padding:var(--spacing-3xl);position:relative}.deco-overlay{background:linear-gradient(135deg,#1c1c1bf2,#76b82a66);bottom:0;left:0;position:absolute;right:0;top:0;z-index:1}.deco-content{animation:slideInLeft .8s cubic-bezier(.16,1,.3,1);max-width:500px;position:relative;z-index:2}.form-logo{height:60px;margin-bottom:var(--spacing-xl);object-fit:contain}.deco-title{font-size:3.5rem;font-weight:800;letter-spacing:-.04em;line-height:1.1;margin-bottom:var(--spacing-lg)}.deco-subtitle{font-size:var(--font-size-lg);line-height:1.6;margin-bottom:var(--spacing-2xl);opacity:.9}.deco-features{display:flex;flex-direction:column;gap:var(--spacing-md)}.feature-item{align-items:center;backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #ffffff1a;border-radius:var(--border-radius-lg);display:flex;font-size:var(--font-size-base);font-weight:600;gap:12px;padding:12px 20px;transition:transform .3s ease;width:fit-content}.feature-item:hover{background:#fff3;transform:translateX(10px)}.login-side-form{align-items:center;background:#fbfbfb;display:flex;flex:1;justify-content:center;padding:var(--spacing-2xl)}.login-card-refined{animation:fadeIn 1s ease-out;max-width:440px;width:100%}.form-header{margin-bottom:var(--spacing-3xl);text-align:center}.form-title{color:var(--color-text-primary);font-size:var(--font-size-4xl);font-weight:800;letter-spacing:-.02em;margin-bottom:8px}.form-subtitle{color:var(--color-text-secondary);font-weight:500}.error-alert{animation:shake .5s ease-in-out;background:#fef2f2;border:1px solid #fee2e2;border-radius:var(--border-radius-lg);color:var(--color-error-main);font-size:var(--font-size-sm);font-weight:600;gap:12px;margin-bottom:var(--spacing-xl);padding:var(--spacing-md)}.error-alert,.error-icon{align-items:center;display:flex}.error-icon{background:var(--color-error-main);border-radius:50%;color:#fff;font-weight:800;height:20px;justify-content:center;width:20px}.refined-form{display:flex;flex-direction:column;gap:var(--spacing-xl)}.input-field label{color:var(--color-text-secondary);display:block;font-size:var(--font-size-xs);font-weight:700;letter-spacing:.05em;margin-bottom:8px;text-transform:uppercase}.input-container{position:relative}.field-icon{color:var(--color-gray-400);left:16px;position:absolute;top:50%;transform:translateY(-50%);transition:color .3s ease}.input-container input{background:#fff;border:2px solid var(--color-gray-100);border-radius:var(--border-radius-xl);font-size:var(--font-size-base);font-weight:500;padding:16px 16px 16px 48px;transition:all .3s ease;width:100%}.input-container input:focus{border-color:var(--color-primary-main);box-shadow:0 0 0 4px #76b82a1a;outline:none}.input-container input:focus+.field-icon{color:var(--color-primary-main)}.refined-submit-btn{align-items:center;background:var(--color-text-primary);border:none;border-radius:var(--border-radius-xl);color:#fff;cursor:pointer;display:flex;font-size:var(--font-size-base);font-weight:700;gap:12px;justify-content:center;margin-top:var(--spacing-md);padding:18px;transition:all .3s ease}.refined-submit-btn:hover:not(:disabled){background:var(--color-primary-main);box-shadow:0 10px 20px #76b82a33;transform:translateY(-2px)}.login-forgot{margin-top:10px;text-align:right}.login-forgot-link{color:var(--color-primary-main);font-size:var(--font-size-sm);font-weight:700;text-decoration:none}.login-forgot-link:hover{text-decoration:underline}.button-loader{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.demo-hint-refined{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--spacing-3xl);text-align:center}.demo-hint-refined span{color:var(--color-text-primary);font-weight:700}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)}}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}@media (max-width:1024px){.login-side-decoration{display:none}.login-side-form{background:#fff}}.forgot-page{align-items:center;background:#fbfbfb;display:flex;font-family:Outfit,sans-serif;justify-content:center;min-height:100vh;padding:24px}.forgot-card{background:#fff;border:1px solid var(--color-gray-100);border-radius:var(--border-radius-xl);max-width:520px;padding:28px;width:100%}.forgot-title{color:var(--color-text-primary);font-size:var(--font-size-3xl);font-weight:800;margin:0}.forgot-subtitle{color:var(--color-text-secondary);font-weight:500;margin-bottom:20px;margin-top:8px}.forgot-alert{border-radius:var(--border-radius-lg);font-size:var(--font-size-sm);font-weight:600;margin-bottom:14px;padding:12px 14px}.forgot-alert--error{background:#fef2f2;border:1px solid #fee2e2;color:var(--color-error-main)}.forgot-alert--success{background:#f0fdf4;border:1px solid #dcfce7;color:#166534}.forgot-form{display:flex;flex-direction:column;gap:12px}.forgot-label{color:var(--color-text-secondary);display:block;font-size:var(--font-size-xs);font-weight:700;letter-spacing:.05em;text-transform:uppercase}.forgot-input{position:relative}.forgot-icon{color:var(--color-gray-400);left:14px;position:absolute;top:50%;transform:translateY(-50%)}.forgot-input input{border:2px solid var(--color-gray-100);border-radius:var(--border-radius-xl);font-size:var(--font-size-base);font-weight:500;padding:14px 14px 14px 44px;width:100%}.forgot-input input:focus{border-color:var(--color-primary-main);box-shadow:0 0 0 4px #76b82a1a;outline:none}.forgot-submit{background:var(--color-text-primary);border:none;border-radius:var(--border-radius-xl);color:#fff;cursor:pointer;font-weight:700;margin-top:8px;padding:14px}.forgot-submit:disabled{cursor:not-allowed;opacity:.7}.forgot-footer{margin-top:16px;text-align:center}.forgot-link{color:var(--color-primary-main);font-weight:700;text-decoration:none}.forgot-link:hover{text-decoration:underline}.reset-page{align-items:center;background:#fbfbfb;display:flex;font-family:Outfit,sans-serif;justify-content:center;min-height:100vh;padding:24px}.reset-card{background:#fff;border:1px solid var(--color-gray-100);border-radius:var(--border-radius-xl);max-width:520px;padding:28px;width:100%}.reset-title{color:var(--color-text-primary);font-size:var(--font-size-3xl);font-weight:800;margin:0}.reset-subtitle{color:var(--color-text-secondary);font-weight:500;margin-bottom:20px;margin-top:8px}.reset-alert{border-radius:var(--border-radius-lg);font-size:var(--font-size-sm);font-weight:600;margin-bottom:14px;padding:12px 14px}.reset-alert--error{background:#fef2f2;border:1px solid #fee2e2;color:var(--color-error-main)}.reset-alert--success{background:#f0fdf4;border:1px solid #dcfce7;color:#166534}.reset-form{display:flex;flex-direction:column;gap:12px}.reset-label{color:var(--color-text-secondary);display:block;font-size:var(--font-size-xs);font-weight:700;letter-spacing:.05em;text-transform:uppercase}.reset-input{position:relative}.reset-icon{color:var(--color-gray-400);left:14px;position:absolute;top:50%;transform:translateY(-50%)}.reset-input input{border:2px solid var(--color-gray-100);border-radius:var(--border-radius-xl);font-size:var(--font-size-base);font-weight:500;padding:14px 14px 14px 44px;width:100%}.reset-input input:focus{border-color:var(--color-primary-main);box-shadow:0 0 0 4px #76b82a1a;outline:none}.reset-submit{background:var(--color-text-primary);border:none;border-radius:var(--border-radius-xl);color:#fff;cursor:pointer;font-weight:700;margin-top:8px;padding:14px}.reset-submit:disabled{cursor:not-allowed;opacity:.7}.reset-footer{margin-top:16px;text-align:center}.reset-link{color:var(--color-primary-main);font-weight:700;text-decoration:none}.reset-link:hover{text-decoration:underline}.dialog-form .ui-label{align-items:center;display:inline-flex;gap:8px}.dialog-form .ui-label svg{flex-shrink:0}.dashboard-page{animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-header{align-items:flex-end;display:flex;justify-content:space-between;margin-bottom:var(--spacing-2xl)}.welcome-text{color:var(--color-text-secondary)}.user-highlight{color:var(--color-primary-main);font-weight:700}.dashboard-header-actions{align-items:center;display:flex;gap:var(--spacing-md)}.dashboard-header-profile-btn{align-items:center;background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-full);color:var(--color-text-secondary);cursor:pointer;display:none;font-size:var(--font-size-sm);font-weight:600;gap:8px;padding:var(--spacing-sm) var(--spacing-md)}.dashboard-header-profile-btn:hover{border-color:var(--color-primary-main);color:var(--color-primary-main)}.header-date{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-full);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600;padding:var(--spacing-sm) var(--spacing-md)}.dashboard-layout{align-items:start;display:grid;gap:var(--spacing-2xl);grid-template-columns:1fr 320px;max-width:100%}.dashboard-main{min-width:0}.stats-grid{display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(4,1fr);margin-bottom:var(--spacing-3xl)}.stat-card{align-items:center;background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-xl);display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);transition:var(--transition-normal)}.stat-card:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.stat-icon-wrapper{align-items:center;border-radius:16px;display:flex;height:56px;justify-content:center;transition:var(--transition-normal);width:56px}.stat-value{color:var(--color-text-primary);font-size:var(--font-size-3xl);font-weight:800;line-height:1;margin-bottom:4px}.stat-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600}.stat-card-primary .stat-icon-wrapper{background:#76b82a1a;color:var(--color-primary-main)}.stat-card-info .stat-icon-wrapper{background:#0061a81a;color:var(--color-info-main)}.stat-card-warning .stat-icon-wrapper{background:#f7941e1a;color:var(--color-warning-main)}.stat-card-success .stat-icon-wrapper{background:#76b82a1a;color:var(--color-primary-main)}.section-title{font-size:var(--font-size-xl)}.pending-count{background:var(--color-warning-main);border-radius:var(--border-radius-full);color:#fff;font-size:var(--font-size-xs);font-weight:700;padding:4px 12px}.pending-approvals{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;margin-bottom:var(--spacing-2xl);max-height:calc(100vh - 400px);min-height:500px;padding:var(--spacing-xl)}.approvals-list{display:flex;flex:1;flex-direction:column;gap:var(--spacing-sm);overflow-y:auto;padding-right:var(--spacing-xs)}.approvals-list::-webkit-scrollbar{width:6px}.approvals-list::-webkit-scrollbar-track{background:var(--color-gray-100);border-radius:var(--border-radius-full)}.approvals-list::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:var(--border-radius-full)}.approvals-list::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}.approval-item{align-items:center;background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);display:flex;gap:var(--spacing-lg);padding:var(--spacing-md);text-decoration:none;transition:var(--transition-fast)}.approval-item:hover{background:#76b82a05;border-color:var(--color-primary-main);transform:translateX(4px)}.approval-info{flex:1;min-width:0}.approval-title{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:700;margin-bottom:6px}.approval-meta{color:var(--color-text-secondary);display:flex;font-size:var(--font-size-xs);gap:var(--spacing-md)}.approval-students,.approval-trainer{align-items:center;display:flex;gap:4px}.approval-budget{align-items:center;color:var(--color-primary-main);display:flex;font-size:var(--font-size-lg);font-weight:700;gap:6px}.approval-arrow{color:var(--color-gray-300);transition:var(--transition-fast)}.approval-item:hover .approval-arrow{color:var(--color-primary-main);transform:translateX(4px)}.view-all-link{border-radius:var(--border-radius-md);color:var(--color-primary-main);display:block;font-size:var(--font-size-sm);font-weight:600;margin-top:var(--spacing-md);padding:var(--spacing-sm);text-align:center;text-decoration:none;transition:var(--transition-fast)}.view-all-link:hover{background:#76b82a1a}.empty-approvals{color:var(--color-text-secondary);padding:var(--spacing-3xl) var(--spacing-xl);text-align:center}.empty-approvals .empty-icon{color:var(--color-success-main);margin-bottom:var(--spacing-lg);opacity:.3}.empty-approvals h4{color:var(--color-text-primary);font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs)}.empty-approvals p{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.quick-actions-sidebar{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-lg);padding:var(--spacing-xl)}.sidebar-section-title{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:700;margin-bottom:var(--spacing-md)}.quick-actions-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.quick-action-item{align-items:center;border:1px solid #0000;border-radius:var(--border-radius-lg);color:var(--color-text-primary);display:flex;font-size:var(--font-size-sm);font-weight:600;gap:var(--spacing-sm);padding:var(--spacing-md);text-decoration:none;transition:var(--transition-fast)}.quick-action-item:hover{background:var(--color-gray-50);border-color:var(--color-gray-200)}.quick-action-highlight{background:#76b82a1a;color:var(--color-primary-main)}.quick-action-highlight:hover{background:#76b82a26;border-color:var(--color-primary-light)}.dashboard-sidebar{position:relative}.profile-card{border-radius:var(--border-radius-2xl);overflow:hidden}.profile-header{background:linear-gradient(135deg,var(--color-primary-main) 0,var(--color-primary-dark) 100%);color:#fff;padding:var(--spacing-2xl);text-align:center}.profile-avatar{align-items:center;background:#fff3;border:3px solid #ffffff4d;border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto var(--spacing-lg);width:80px}.profile-name{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-xs)}.profile-role{align-items:center;background:#fff3;border-radius:var(--border-radius-full);display:inline-flex;font-size:var(--font-size-sm);font-weight:600;gap:6px;padding:6px 12px}.profile-info{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-xl)}.info-row{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-sm);gap:var(--spacing-sm)}.info-row svg{color:var(--color-gray-400)}.profile-actions{flex-direction:column;padding:var(--spacing-xl);padding-top:0}.profile-actions,.profile-btn{display:flex;gap:var(--spacing-sm)}.profile-btn{align-items:center;border:none;border-radius:var(--border-radius-lg);cursor:pointer;font-size:var(--font-size-sm);font-weight:600;justify-content:center;padding:var(--spacing-md);transition:var(--transition-fast);width:100%}.profile-btn-primary{background:var(--color-primary-main);color:#fff}.profile-btn-primary:hover{background:var(--color-primary-dark);box-shadow:0 4px 12px #76b82a4d;transform:translateY(-2px)}.profile-btn-secondary{background:var(--color-gray-100);color:var(--color-text-primary)}.profile-btn-secondary:hover{background:var(--color-gray-200)}.page-loading{gap:var(--spacing-md)}.recent-sessions{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-xl);padding:var(--spacing-xl)}.view-all-link-small{color:var(--color-primary-main);font-size:var(--font-size-sm);font-weight:600;text-decoration:none;transition:var(--transition-fast)}.view-all-link-small:hover{text-decoration:underline}.recent-sessions-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.recent-session-item{align-items:center;background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);display:flex;gap:var(--spacing-lg);padding:var(--spacing-md);text-decoration:none;transition:var(--transition-fast)}.recent-session-item:hover{background:#76b82a05;border-color:var(--color-primary-main);transform:translateX(4px)}.session-info{flex:1;min-width:0}.session-title{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:700;margin-bottom:6px}.session-meta{color:var(--color-text-secondary);display:flex;font-size:var(--font-size-xs);gap:var(--spacing-md)}.session-date,.session-students{align-items:center;display:flex;gap:4px}.session-status-badge{border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:700;padding:4px 12px;text-transform:uppercase}.session-status-badge.status-en_attente{background:#f7941e1a;color:var(--color-warning-main)}.session-status-badge.status-validee{background:#76b82a1a;color:var(--color-success-main)}.session-status-badge.status-refusee{background:#ef44441a;color:var(--color-error-main)}.session-arrow{color:var(--color-gray-300);transition:var(--transition-fast)}.recent-session-item:hover .session-arrow{color:var(--color-primary-main);transform:translateX(4px)}@media (max-width:1024px){.dashboard-layout{grid-template-columns:1fr}.dashboard-sidebar{position:static}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.page-header{align-items:flex-start;flex-direction:column;gap:var(--spacing-md)}.dashboard-header-actions{flex-wrap:nowrap;justify-content:flex-start;width:100%}.dashboard-header-profile-btn{display:inline-flex;margin-left:auto;white-space:nowrap}.header-date{margin-left:0;margin-right:auto;max-width:calc(100% - 120px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-grid{grid-template-columns:repeat(2,1fr)}.page-title{font-size:var(--font-size-2xl)}.header-date{border-radius:var(--border-radius-lg)}.pending-approvals,.quick-actions-sidebar,.recent-sessions{padding:var(--spacing-lg)}.pending-approvals{max-height:none;min-height:auto}.approval-meta,.session-meta{flex-wrap:wrap;row-gap:6px}.approval-budget{font-size:var(--font-size-base)}}@media (max-width:480px){.stats-grid{gap:var(--spacing-sm);grid-template-columns:repeat(2,1fr)}.page-header{margin-bottom:var(--spacing-lg)}.page-title{font-size:var(--font-size-xl)}.stat-card{padding:var(--spacing-sm)}.stat-icon-wrapper{border-radius:12px;height:40px;width:40px}.stat-value{font-size:var(--font-size-xl)}.stat-label{font-size:var(--font-size-xs)}.approval-item,.recent-session-item{align-items:stretch;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-sm)}.approval-item:hover,.recent-session-item:hover{transform:none}.approval-budget{font-size:var(--font-size-base);justify-content:flex-start}.approval-arrow,.session-arrow{display:none}.pending-approvals,.quick-actions-sidebar,.recent-sessions{padding:var(--spacing-md)}.section-title{font-size:var(--font-size-lg)}}.toast-container{display:flex;flex-direction:column;gap:10px;position:fixed;right:16px;top:16px;width:min(380px,calc(100vw - 32px));z-index:9999}.toast{align-items:flex-start;background:#111827;border:1px solid #ffffff1a;border-radius:12px;box-shadow:0 10px 30px #00000040;color:#fff;display:flex;gap:12px;justify-content:space-between;padding:12px}.toast-message{flex:1;font-size:14px;line-height:1.35}.toast-message .toast-title{font-weight:700;margin-bottom:8px}.toast-message .toast-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:10px}.toast-message textarea{background:#ffffff14;border:1px solid #fff3;border-radius:10px;color:#fff;margin-top:6px;min-height:74px;padding:10px 12px;resize:vertical;width:100%}.toast-message textarea:focus{border-color:#ffffff73;outline:none}.toast-message .toast-btn{appearance:none;background:#ffffff14;border:1px solid #fff3;border-radius:10px;color:#fff;cursor:pointer;font-weight:700;padding:8px 10px}.toast-message .toast-btn:disabled{cursor:not-allowed;opacity:.6}.toast-message .toast-btn-primary{background:#34d3992e;border-color:#34d399a6}.toast-message .toast-btn-danger{background:#f871712e;border-color:#f87171a6}.toast-close{appearance:none;background:#0000;border:0;color:#ffffffd9;cursor:pointer;font-size:18px;line-height:1;padding:0 4px}.toast-info{border-left:4px solid #60a5fa}.toast-success{border-left:4px solid #34d399}.toast-error{border-left:4px solid #f87171}.form-group textarea{min-height:80px}.dialog-error{margin-bottom:var(--spacing-lg)}.wizard-container{max-width:600px}.btn-remove,.consommable-select,.quantity-input{border:1px solid var(--color-gray-300)}.actions-right{display:flex;gap:var(--spacing-md)}.btn-skip{background:#0000;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm);font-weight:600;padding:var(--spacing-md) var(--spacing-lg);text-decoration:underline;transition:var(--transition-fast)}.btn-skip:hover:not(:disabled){color:var(--color-text-primary)}.btn-skip:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.dialog-container{margin:var(--spacing-md);max-width:calc(100% - var(--spacing-xl))}.form-row{grid-template-columns:1fr}.dialog-actions{flex-direction:column-reverse}.dialog-actions button{width:100%}.actions-right{flex-direction:column}.consommable-row{grid-template-columns:1fr}.wizard-steps span{display:none}}.formations-page{animation:fadeIn .5s ease-out;display:flex;flex-direction:column;height:100%;min-height:0}.formations-page .ui-fixed-list{display:flex;flex:1;flex-direction:column;height:auto;min-height:0}.formations-page .ui-fixed-list-scroll{flex:1;min-height:0;overflow-y:auto;position:relative}.formations-page .ui-fixed-list>.table-container{flex-shrink:0}.formations-page .data-table{table-layout:fixed;width:100%}.formations-page .data-table td,.formations-page .data-table th{width:auto}.formations-page .data-table td:first-child,.formations-page .data-table th:first-child{width:15%}.formations-page .data-table td:nth-child(2),.formations-page .data-table th:nth-child(2){width:20%}.formations-page .data-table td:nth-child(3),.formations-page .data-table th:nth-child(3){width:12%}.formations-page .data-table td:nth-child(4),.formations-page .data-table td:nth-child(5),.formations-page .data-table th:nth-child(4),.formations-page .data-table th:nth-child(5){width:15%}.formations-page .data-table td:nth-child(6),.formations-page .data-table th:nth-child(6){width:10%}.formations-page .data-table td:nth-child(7),.formations-page .data-table th:nth-child(7){width:13%}.table-container{overflow:visible}.data-table{border-collapse:initial;border-spacing:0}.data-table thead{position:sticky;top:0;z-index:2}.ui-fixed-list-scroll .data-table thead th{background:var(--color-gray-50);position:sticky;top:0;z-index:3}.description-cell{color:var(--color-text-secondary);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.consommables-cell,.duration-cell{font-weight:500;white-space:nowrap}.consommables-cell svg,.duration-cell svg{color:var(--color-primary-main);margin-right:var(--spacing-xs);vertical-align:middle}.status-badge{display:inline-block}.status-active{background:#76b82a1a;color:var(--color-primary-main)}.status-inactive{background:#9ca3af1a;color:var(--color-gray-600)}@media (max-width:768px){.page-header-section{flex-direction:column}.page-title{font-size:var(--font-size-2xl)}.btn-add{justify-content:center;width:100%}.filters-section{align-items:stretch;flex-direction:column}.filter-group{width:100%}.filter-select{min-width:0;width:100%}.table-container{overflow-x:visible}.formations-page .data-table{table-layout:auto}.formations-page .data-table td,.formations-page .data-table th{width:auto!important}.data-table{font-size:var(--font-size-xs)}.data-table thead{display:none}.table-footer{align-items:stretch;flex-direction:column;gap:var(--spacing-md)}.pagination{justify-content:space-between}.page-numbers,.pagination{flex-wrap:wrap}}.dialog-container.history-dialog{max-width:900px}.history-content{padding:var(--spacing-xl)}.history-empty,.history-error,.history-loading{color:var(--color-text-secondary);padding:var(--spacing-lg)}.history-list{gap:var(--spacing-md)}.history-item{background:var(--color-background-paper);border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);padding:var(--spacing-lg)}.history-item-header{gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.history-action{color:var(--color-text-primary);display:inline-flex;font-weight:800;gap:var(--spacing-sm)}.history-action-text,.history-timestamp{font-size:var(--font-size-sm)}.history-timestamp{color:var(--color-text-secondary)}.history-item-sub{display:grid;gap:var(--spacing-sm);grid-template-columns:1fr;margin-bottom:var(--spacing-sm)}@media (min-width:768px){.history-item-sub{grid-template-columns:1fr 2fr}}.history-actor,.history-request{align-items:center;color:var(--color-text-secondary);display:inline-flex;font-size:var(--font-size-sm);gap:var(--spacing-sm)}.history-changes{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--border-radius-md);font-size:12px;margin:0;margin-top:var(--spacing-sm);max-height:260px;overflow:auto;padding:var(--spacing-md)}.dialog-actions.history-actions{align-items:center;display:flex;gap:var(--spacing-md);justify-content:space-between}.history-pagination{display:inline-flex;gap:var(--spacing-sm)}.history-changes-list{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--border-radius-md);display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-sm);padding:var(--spacing-md)}.history-change-item{background:#fff;border-radius:var(--border-radius-sm);flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-sm)}@media (min-width:768px){.history-change-item{align-items:center;flex-direction:row;gap:var(--spacing-md)}}.history-change-field{color:var(--color-text-primary);font-size:var(--font-size-sm)}.history-change-values{display:inline-flex;flex-wrap:wrap;font-size:var(--font-size-sm);gap:var(--spacing-sm)}.history-old-value{color:var(--color-error);opacity:.8;text-decoration:line-through}.history-arrow{color:var(--color-text-secondary);font-weight:700}.history-new-value{color:var(--color-success);font-weight:600}.formation-detail-wrapper{animation:fadeIn .5s ease-out}.back-link{font-weight:600;gap:8px;margin-bottom:var(--spacing-xl)}.formation-detail-container{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-lg);overflow:hidden}.detail-header{align-items:center;background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-100);display:flex;justify-content:space-between;padding:var(--spacing-2xl)}.detail-title{color:var(--color-text-primary);font-size:var(--font-size-3xl);font-weight:800;margin-bottom:var(--spacing-xs)}.btn-launch{align-items:center;background:var(--color-primary-main);border-radius:var(--border-radius-lg);box-shadow:0 4px 12px #76b82a33;color:#fff;display:flex;font-weight:700;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);text-decoration:none;transition:var(--transition-normal)}.btn-launch:hover{background:var(--color-primary-dark);box-shadow:0 6px 16px #76b82a4d;transform:translateY(-2px)}.btn-edit{align-items:center;background:#fff;border:1px solid var(--color-gray-300);border-radius:var(--border-radius-lg);color:var(--color-text-primary);display:flex;font-weight:700;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);text-decoration:none;transition:var(--transition-normal)}.btn-edit:hover{background:var(--color-gray-50);border-color:var(--color-gray-400);transform:translateY(-2px)}.header-main{display:flex}.header-actions,.header-main{align-items:center;gap:var(--spacing-md)}.detail-grid{background-color:var(--color-gray-100);display:grid;gap:1px;grid-template-columns:1fr 350px}.detail-main-info{background:#fff;padding:var(--spacing-2xl)}.detail-resources{background:var(--color-gray-50);border-left:1px solid var(--color-gray-200);padding:var(--spacing-2xl)}.info-cards{display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:var(--spacing-3xl)}.info-card{align-items:center;background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--border-radius-xl);gap:var(--spacing-md)}.info-card-content-lines{display:flex;flex-direction:column;gap:8px}.info-line label{color:var(--color-text-secondary);display:block;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.info-line span{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:700}.info-card-icon{align-items:center;background:#fff;border-radius:10px;box-shadow:var(--shadow-sm);color:var(--color-primary-main);display:flex;height:40px;justify-content:center;width:40px}.info-card-content label{color:var(--color-text-secondary);display:block;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.info-card-content span{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:700}.trainers-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.trainer-badge{align-items:center;background:#76b82a1f;border:1px solid #76b82a59;border-radius:var(--border-radius-full);color:var(--color-primary-main);display:inline-flex;font-size:var(--font-size-xs);font-weight:700;line-height:1.2;padding:4px 10px}.section-title{font-size:var(--font-size-lg);gap:10px;margin-bottom:var(--spacing-lg)}.description-content{color:var(--color-text-secondary);font-size:var(--font-size-base);line-height:1.7}.resource-group{margin-bottom:var(--spacing-xl)}.resource-group h3{align-items:center;color:var(--color-text-primary);display:flex;font-size:var(--font-size-sm);justify-content:space-between;margin-bottom:var(--spacing-md)}.type-label{background:var(--color-gray-200);border-radius:var(--border-radius-full);color:var(--color-text-secondary);font-size:10px;padding:2px 8px}.resource-item{align-items:center;background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);display:flex;justify-content:space-between;margin-bottom:var(--spacing-sm);padding:var(--spacing-md)}.resource-name{color:var(--color-text-primary);display:block;font-size:var(--font-size-sm);font-weight:700}.resource-supplier{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.resource-math{text-align:right}.qty{color:var(--color-text-secondary);display:block;font-size:var(--font-size-xs);font-weight:600}.price{color:var(--color-primary-main);font-size:var(--font-size-sm);font-weight:700}.empty-resources{color:var(--color-text-secondary);opacity:.6;padding:var(--spacing-xl);text-align:center}@media (max-width:1024px){.detail-grid{grid-template-columns:1fr}.detail-resources{border-left:none;border-top:1px solid var(--color-gray-200)}}@media (max-width:640px){.detail-header{align-items:flex-start;flex-direction:column;gap:var(--spacing-lg)}.header-actions{flex-direction:column;width:100%}.btn-edit,.btn-launch{justify-content:center;width:100%}}.formation-edit-page{margin:0 auto;max-width:800px;padding:var(--spacing-xl)}.edit-header{margin-bottom:var(--spacing-xl)}.back-link{color:var(--color-text-secondary);font-size:var(--font-size-sm);gap:var(--spacing-sm);margin-bottom:var(--spacing-md);transition:var(--transition-fast)}.back-link:hover{color:var(--color-primary-main)}.edit-title{align-items:center;color:var(--color-text-primary);display:flex;font-size:var(--font-size-2xl);font-weight:700;gap:var(--spacing-md);margin:0}.edit-title svg{color:var(--color-primary-main)}.edit-container{background:#fff;border-radius:var(--border-radius-xl);box-shadow:0 4px 20px #00000014;overflow:hidden}.wizard-steps{background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200);gap:var(--spacing-md);justify-content:center;padding:var(--spacing-lg) var(--spacing-xl)}.step-indicator,.wizard-steps{align-items:center;display:flex}.step-indicator{color:var(--color-gray-400);font-size:var(--font-size-sm);font-weight:600;gap:var(--spacing-sm)}.step-indicator.active{color:var(--color-primary-main)}.step-indicator.completed{color:var(--color-success-main)}.step-number{align-items:center;background:var(--color-gray-200);border-radius:50%;color:var(--color-gray-500);display:flex;font-size:var(--font-size-sm);font-weight:700;height:32px;justify-content:center;width:32px}.step-indicator.active .step-number{background:var(--color-primary-main);color:#fff}.step-indicator.completed .step-number{background:var(--color-success-main);color:#fff}.step-line{background:var(--color-gray-200);border-radius:1px;flex:1;height:2px;max-width:60px}.edit-form{padding:var(--spacing-xl)}.form-group textarea{min-height:100px;resize:vertical}.checkbox-group{align-items:flex-end;display:flex;padding-bottom:var(--spacing-md)}.checkbox-label{align-items:center!important;display:flex!important;gap:var(--spacing-sm)!important;margin:0!important}.checkbox-label input[type=checkbox]{accent-color:var(--color-primary-main);cursor:pointer;height:20px;width:auto;width:20px}.checkbox-label span{color:var(--color-text-primary)!important;font-weight:500!important}.edit-error{background:#ef44441a;border-radius:var(--border-radius-lg);color:var(--color-error-main);font-size:var(--font-size-sm);font-weight:500;margin:var(--spacing-lg) var(--spacing-xl) 0;padding:var(--spacing-md)}.edit-actions{border-top:1px solid var(--color-gray-200);display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-xl);padding-top:var(--spacing-lg)}.btn-secondary{align-items:center;border:1px solid var(--color-gray-500);display:inline-flex;gap:var(--spacing-sm)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-400)}.btn-primary{background:var(--color-primary-main)!important;color:#fff!important;display:inline-flex}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)!important}.consommables-section{margin-bottom:var(--spacing-xl)}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg)}.section-header h3{align-items:center;color:var(--color-text-primary);display:flex;font-size:var(--font-size-lg);gap:var(--spacing-sm);margin:0}.section-hint{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-style:italic}.empty-consommables{background:var(--color-gray-50);border:2px dashed var(--color-gray-200);border-radius:var(--border-radius-lg);color:var(--color-text-secondary);padding:var(--spacing-2xl);text-align:center}.empty-consommables svg{color:var(--color-gray-300);margin-bottom:var(--spacing-md)}.empty-consommables p{margin-bottom:var(--spacing-lg)}.btn-add-item{align-items:center;background:#0000;border:2px dashed var(--color-primary-main);border-radius:var(--border-radius-lg);color:var(--color-primary-main);cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);font-weight:600;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);transition:var(--transition-fast)}.btn-add-item:hover{background:#76b82a0d}.consommables-list{display:flex;flex-direction:column;gap:var(--spacing-md);max-height:400px;overflow-y:auto;padding-right:var(--spacing-sm)}.consommable-row{align-items:center;background:var(--color-gray-50);border-radius:var(--border-radius-lg);display:grid;gap:var(--spacing-sm);grid-template-columns:1fr 100px 40px;padding:var(--spacing-md)}.consommable-select{background:#fff;border:2px solid #9ca3af;border-radius:var(--border-radius-lg);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md)}.consommable-select:disabled{background:var(--color-gray-100);color:var(--color-text-primary);cursor:not-allowed}.quantity-input{background:#fff;border:2px solid #9ca3af;border-radius:var(--border-radius-lg);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md);text-align:center}.btn-remove{align-items:center;background:#0000;border:1px solid var(--color-gray-500);border-radius:var(--border-radius-md);color:var(--color-gray-500);cursor:pointer;display:flex;justify-content:center;padding:var(--spacing-sm);transition:var(--transition-fast)}.btn-remove:hover{background:#ef44440d;border-color:var(--color-error-main);color:var(--color-error-main)}.page-loading{color:var(--color-text-secondary);padding:var(--spacing-3xl)}.loader{border:3px solid var(--color-gray-200);margin-bottom:var(--spacing-md)}.empty-state{padding:var(--spacing-3xl)}.empty-state h3{margin-bottom:var(--spacing-lg)}@media (max-width:768px){.formation-edit-page{padding:var(--spacing-md)}.form-row{grid-template-columns:1fr}.edit-actions{flex-direction:column-reverse}.edit-actions button{justify-content:center;width:100%}.consommable-row{gap:var(--spacing-md);grid-template-columns:1fr}.wizard-steps span{display:none}.section-header{align-items:flex-start;flex-direction:column;gap:var(--spacing-sm)}}.sessions-page{animation:fadeIn .5s ease-out;display:flex;flex-direction:column;height:100%;min-height:0}.view-toggle{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);flex-shrink:0;gap:0;overflow:hidden}.view-toggle,.view-toggle-btn{align-items:center;display:inline-flex}.view-toggle-btn{background:#0000;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-xs);font-weight:700;gap:var(--spacing-xs);padding:10px 12px;transition:var(--transition-fast)}.view-toggle-btn+.view-toggle-btn{border-left:1px solid var(--color-gray-200)}.view-toggle-btn:hover{background:var(--color-gray-50);color:var(--color-text-primary)}.view-toggle-btn.active{background:#76b82a14;color:var(--color-primary-main)}.filter-select{background:#fff;border:2px solid var(--color-gray-300);color:var(--color-text-primary);padding:var(--spacing-sm) var(--spacing-md)}@media (max-width:768px){.sessions-page .kanban-board,.sessions-page .table-container,.sessions-page .view-toggle{display:none!important}}.budget-cell,.participants-cell,.trainer-cell{align-items:center;display:flex;font-weight:600;gap:var(--spacing-xs)}.status-badge{align-items:center;border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:600;gap:4px;text-transform:uppercase}.status-pending{background:#f7941e1a;color:var(--color-warning-main)}.status-approved{background:#76b82a1a;color:var(--color-primary-main)}.status-rejected{background:#ef44441a;color:var(--color-error-main)}.status-completed{background:#0061a81a;color:var(--color-info-main)}.actions-column{width:80px}.kanban-board{display:flex;flex:1;gap:var(--spacing-lg);min-height:0;overflow-x:auto;padding-bottom:var(--spacing-md)}.kanban-column{background:var(--color-gray-50);border-radius:var(--border-radius-xl);display:flex;flex:0 0 280px;flex-direction:column;height:100%;overflow:hidden}.kanban-column-header{background:#fff;border-bottom:2px solid;border-left:4px solid;display:flex;font-weight:700;padding:var(--spacing-md) var(--spacing-lg)}.column-title,.kanban-column-header{align-items:center;gap:var(--spacing-sm)}.column-title{color:var(--color-text-primary);display:inline-flex;flex:1;font-size:var(--font-size-sm)}.column-count{background:var(--color-gray-200);border-radius:var(--border-radius-full);color:var(--color-text-secondary);flex-shrink:0;font-size:var(--font-size-xs);font-weight:700;min-width:24px;padding:2px 10px;text-align:center}.column-content,.kanban-cards{display:flex;flex:1;flex-direction:column;gap:var(--spacing-md);min-height:0;overflow-y:auto;padding:var(--spacing-md)}.session-card{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-lg);transition:var(--transition-fast)}.session-card:hover{border-color:var(--color-primary-main);box-shadow:var(--shadow-md);transform:translateY(-2px)}.session-card.dragging{box-shadow:var(--shadow-lg);cursor:grabbing;opacity:.9;transform:rotate(2deg) scale(1.02);z-index:1000}.kanban-column.dragging-over{background:#76b82a1a;border:2px dashed var(--color-primary-main)}.kanban-column.dragging-over .kanban-column-header{background:#76b82a0d}.card-header{align-items:flex-start;display:flex;gap:var(--spacing-sm);justify-content:space-between;margin-bottom:var(--spacing-sm)}.formation-title{line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--color-primary-main);display:-webkit-box;flex:1;font-weight:700;line-height:1.3;overflow:hidden;text-overflow:ellipsis}.card-menu{align-items:center;background:#0000;border:none;border-radius:var(--border-radius-md);color:var(--color-gray-400);cursor:pointer;display:flex;justify-content:center;padding:var(--spacing-xs);transition:var(--transition-fast)}.card-menu:hover{background:var(--color-gray-100);color:var(--color-text-primary)}.card-trainer{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-xs);gap:var(--spacing-xs)}.card-meta,.card-trainer{margin-bottom:var(--spacing-md)}.card-meta{background:var(--color-gray-50);border-radius:var(--border-radius-md);display:grid;gap:var(--spacing-sm);grid-template-columns:1fr 1fr;padding:var(--spacing-sm)}.meta-item{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-xs);gap:var(--spacing-xs)}.meta-item.budget{color:var(--color-primary-main);font-weight:700}.card-date{align-items:center;border-bottom:1px dashed var(--color-gray-200);color:var(--color-gray-500);font-size:var(--font-size-xs);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md)}.card-actions,.card-date{display:flex;gap:var(--spacing-xs)}.card-actions{justify-content:flex-end}.card-action-btn{align-items:center;background:#0000;border:1px solid var(--color-gray-300);border-radius:var(--border-radius-md);color:var(--color-text-secondary);cursor:pointer;display:flex;height:28px;justify-content:center;text-decoration:none;transition:var(--transition-fast);width:28px}.card-action-btn:hover{transform:translateY(-1px)}.card-action-btn.view:hover{background:#0061a80d;border-color:var(--color-info-main);color:var(--color-info-main)}.card-action-btn.edit:hover{background:#76b82a0d;border-color:var(--color-primary-main);color:var(--color-primary-main)}.card-action-btn.delete:hover{background:#ef44440d;border-color:var(--color-error-main);color:var(--color-error-main)}.kanban-empty{color:var(--color-gray-400);font-size:var(--font-size-xs);font-style:italic;padding:var(--spacing-xl);text-align:center}.kanban-footer{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);display:flex;flex-shrink:0;justify-content:center;margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.mobile-status-view,.sessions-mobile{display:none}@media (max-width:1200px){.kanban-board{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.page-header-section{flex-direction:column}.page-title{font-size:var(--font-size-2xl)}.btn-add{justify-content:center;width:100%}.filters-section{align-items:stretch;flex-direction:column}.filter-group{width:100%}.filter-select{min-width:0;width:100%}.sessions-mobile{display:block}.kanban-desktop,.kanban-footer,.table-footer{display:none}.sessions-status-tabs{display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(2,1fr);margin-bottom:var(--spacing-md);margin-top:var(--spacing-md)}.sessions-status-tab{align-items:center;background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);cursor:pointer;display:flex;gap:8px;min-width:0;padding:var(--spacing-sm) var(--spacing-sm)}.sessions-status-tab.active{border-color:var(--color-primary-main);box-shadow:0 0 0 3px #76b82a1a}.sessions-status-tab .tab-label{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sessions-status-tab .tab-count{background:var(--color-gray-100);border:1px solid var(--color-gray-200);border-radius:var(--border-radius-full);color:var(--color-text-secondary);flex-shrink:0;font-size:var(--font-size-xs);font-weight:800;margin-left:auto;padding:2px 8px}.sessions-mobile-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.sessions-mobile-list .session-card{padding:var(--spacing-md)}.kanban-board,.sessions-mobile-list .card-meta{grid-template-columns:1fr}.kanban-column{min-height:auto}.data-table{font-size:var(--font-size-xs)}.data-table td,.data-table th{padding:var(--spacing-sm)}}.session-detail-page{padding:var(--spacing-md) 0}.back-link{align-items:center;color:#6b7280;display:inline-flex;font-size:.9375rem;font-weight:500;gap:.5rem;margin-bottom:1.5rem;text-decoration:none;transition:all .2s ease}.back-link:hover{color:#10b981;transform:translateX(-4px)}.session-header{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}@media (min-width:768px){.session-header{align-items:center;flex-direction:row;justify-content:space-between}}.status-badge-large{align-items:center;align-self:flex-start;border-radius:var(--border-radius-lg);display:inline-flex;font-size:var(--font-size-sm);font-weight:600;padding:var(--spacing-sm) var(--spacing-md)}.status-pending{background-color:#f973161a;border:1px solid #f9731633;color:#ea580c}.status-validated{background-color:#10b9811a;border:1px solid #10b98133;color:#059669}.status-rejected{background-color:#ef44441a;border:1px solid #ef444433;color:#dc2626}.status-cancelled{background-color:#6b72801a;border:1px solid #6b728033;color:#4b5563}.session-info-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(2,1fr);margin-bottom:var(--spacing-lg)}@media (min-width:768px){.session-info-grid{grid-template-columns:repeat(4,1fr)}}.info-card{background-color:var(--color-background-paper);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-md)}.info-label{align-items:center;display:inline-flex;gap:8px}.info-card.highlight{background-color:#10b9811a;border:1px solid var(--color-success-light)}.info-card.highlight-error{background-color:#ef44441a;border:1px solid var(--color-error-light)}.budget-section{margin-bottom:var(--spacing-xl);margin-top:var(--spacing-xl)}.budget-section h2{border-bottom:1px solid var(--color-gray-200);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm)}.budget-total-header{align-items:center;background-color:var(--color-primary-main);border-radius:var(--border-radius-lg);color:var(--color-primary-contrast);display:flex;justify-content:space-between;margin-bottom:var(--spacing-lg);padding:var(--spacing-lg)}.budget-amount{font-size:var(--font-size-2xl);font-weight:700}.supplier-group{background-color:var(--color-background-paper);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-lg);overflow:hidden}.supplier-header{align-items:center;background-color:var(--color-gray-100);display:flex;font-weight:600;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.supplier-name{color:var(--color-text-primary)}.supplier-total{color:var(--color-primary-main)}.budget-lines{list-style:none;margin:0;padding:0}.budget-line{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:1.25rem 1.5rem;transition:background-color .2s ease}.budget-line:hover{background-color:#f9fafb}.budget-line:last-child{border-bottom:none}.line-name{color:#111827;flex:1;font-size:1rem;font-weight:600}.line-calc{color:#6b7280;font-size:.875rem;margin-right:1rem}.line-total{color:#10b981;font-size:1.125rem;font-weight:700;min-width:100px;text-align:right}.rejection-reason{background-color:#fee2e2;border-left:4px solid #ef4444;border-radius:8px;color:#991b1b;font-size:.875rem;margin-top:.75rem;padding:1rem}.session-content-layout{display:grid;gap:2rem;grid-template-columns:1fr;margin-bottom:2rem}@media (min-width:1024px){.session-content-layout{grid-template-columns:350px 1fr}}.session-info-card{background:#fff;border:1px solid #f3f4f6;border-radius:16px;box-shadow:0 1px 3px #0000000d;height:fit-content;padding:2rem}@media (min-width:1024px){.session-info-card{position:sticky;top:2rem}}.session-info-card h1{color:#111827;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.session-info-item{margin-bottom:1.5rem}.session-info-item:last-child{margin-bottom:0}.session-info-label{color:#6b7280;display:block;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.session-info-value{color:#111827;font-size:1rem;font-weight:500}.budget-hero-card{background:linear-gradient(135deg,#84cc16,#65a30d);border-radius:20px;box-shadow:0 8px 24px #84cc1640;color:#fff;margin-bottom:2rem;overflow:hidden;padding:2.5rem;position:relative}.budget-hero-card:before{background:#ffffff1a;border-radius:50%;content:"";height:300px;position:absolute;right:-20%;top:-50%;width:300px}.budget-hero-label{font-size:.875rem;font-weight:500;margin-bottom:.5rem;opacity:.9;position:relative;z-index:1}.budget-hero-amount{align-items:baseline;display:flex;gap:.5rem;position:relative;z-index:1}.budget-hero-amount .amount{font-size:3.5rem;font-weight:800;letter-spacing:-.02em;line-height:1}.budget-hero-amount .currency{font-size:2.5rem;font-weight:700;opacity:.9}.budget-hero-tva{font-size:.875rem;margin-top:.5rem;opacity:.85;position:relative;z-index:1}.session-tabs{border-bottom:2px solid #f3f4f6;display:flex;gap:.5rem;margin-bottom:2rem}.session-tab{background:none;border:none;border-bottom:3px solid #0000;bottom:-2px;color:#6b7280;cursor:pointer;font-size:.9375rem;font-weight:600;padding:.75rem 1.5rem;position:relative;transition:all .2s ease}.session-tab:hover{color:#111827}.session-tab.active{border-bottom-color:#10b981;color:#111827}.items-list{background:#fff;border:1px solid #f3f4f6;border-radius:16px;box-shadow:0 1px 3px #0000000d;overflow:hidden}.item-row{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:1.25rem 1.5rem;transition:background-color .15s ease}.item-row:hover{background-color:#f9fafb}.item-row:last-child{border-bottom:none}.item-info{flex:1}.item-name{color:#111827;font-size:1rem;font-weight:600;margin-bottom:.25rem}.item-details{color:#10b981;font-size:.875rem;font-weight:500}.item-price{color:#10b981;font-size:1.125rem;font-weight:700;text-align:right}.item-calculation{color:#9ca3af;font-size:.75rem;margin-top:.25rem;text-align:right}.validation-actions{background-color:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);bottom:0;box-shadow:0 -4px 20px #0000001a;margin-left:auto;margin-top:var(--spacing-lg);max-width:600px;padding:var(--spacing-md);position:sticky;z-index:100}.validation-actions h3{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--spacing-sm)}.validation-actions p{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.action-buttons{display:flex;gap:var(--spacing-md)}.action-buttons .btn{align-items:center;border:none;border-radius:var(--border-radius-md);cursor:pointer;display:inline-flex;flex:1;font-size:var(--font-size-sm);font-weight:600;gap:var(--spacing-xs);justify-content:center;min-height:40px;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.action-buttons .btn-success{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d;color:#fff}.action-buttons .btn-success:hover{box-shadow:0 6px 20px #10b98166;transform:translateY(-2px)}.action-buttons .btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 12px #ef44444d;color:#fff}.action-buttons .btn-danger:hover{box-shadow:0 6px 20px #ef444466;transform:translateY(-2px)}.reject-form{border-top:1px solid var(--color-gray-200);flex-direction:column;margin-top:var(--spacing-lg);padding-top:var(--spacing-lg)}.reject-actions,.reject-form{display:flex;gap:var(--spacing-md)}.confirm-dialog{background-color:var(--color-background-paper);border:2px solid var(--color-gray-300);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);margin-top:var(--spacing-lg);padding:var(--spacing-lg)}.confirm-dialog p{color:var(--color-text-primary);font-size:var(--font-size-base);margin-bottom:var(--spacing-lg);text-align:center}.confirm-actions{display:flex;gap:var(--spacing-md);justify-content:center}.confirm-actions .btn{border:none;border-radius:var(--border-radius-md);cursor:pointer;font-weight:600;padding:var(--spacing-sm) var(--spacing-lg);transition:all .2s ease}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 12px #f59e0b4d;color:#fff}.btn-warning:hover{box-shadow:0 6px 20px #f59e0b66;transform:translateY(-2px)}.btn-secondary{background-color:var(--color-gray-200)}.btn-secondary:hover{background-color:var(--color-gray-300)}.history-tab-content{background:#fff;border:1px solid #f3f4f6;border-radius:16px;box-shadow:0 1px 3px #0000000d;padding:2rem}.history-empty,.history-loading{color:#6b7280;font-size:1rem;padding:3rem;text-align:center}.history-list{display:flex;flex-direction:column;gap:1rem}.history-item{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:1.25rem;transition:all .2s ease}.history-item:hover{border-color:#d1fae5;box-shadow:0 2px 8px #10b9811a}.history-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.history-action{align-items:center;color:#10b981;display:flex;font-weight:600;gap:.5rem}.history-action-text{font-size:.9375rem}.history-meta{align-items:center;display:flex;gap:.75rem}.history-timestamp{color:#6b7280;font-size:.875rem}.history-item-sub{align-items:center;display:flex;gap:1rem;margin-bottom:.75rem}.history-actor{align-items:center;color:#4b5563;display:flex;font-size:.875rem;gap:.375rem}.history-changes-list{border-top:1px solid #e5e7eb;margin-top:.75rem;padding-top:.75rem}.history-change-item{display:flex;flex-wrap:wrap;font-size:.875rem;gap:.5rem;padding:.5rem 0}.history-change-field{color:#374151;font-weight:600;min-width:120px}.history-change-values{align-items:center;display:flex;flex:1;gap:.5rem}.history-old-value{background:#fee2e2;color:#ef4444}.history-new-value,.history-old-value{border-radius:4px;padding:.125rem .5rem}.history-new-value{background:#d1fae5;color:#10b981}.history-arrow{color:#9ca3af;font-weight:600}.history-deleted{text-decoration:line-through}.history-pagination{align-items:center;border-top:1px solid #f3f4f6;display:flex;gap:1rem;justify-content:center;margin-top:2rem;padding-top:1.5rem}.history-page-info{color:#6b7280;font-size:.875rem;font-weight:500}.new-session-wrapper{animation:fadeIn .5s ease-out}.wizard-header{margin-bottom:var(--spacing-2xl)}.wizard-title{color:var(--color-text-primary);font-size:var(--font-size-3xl);margin-bottom:var(--spacing-xs)}.wizard-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.new-session-grid{align-items:start;display:grid;gap:var(--spacing-2xl);grid-template-columns:450px 1fr;margin:0 auto;max-width:1600px}.form-card{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-sm);margin-bottom:var(--spacing-xl);padding:var(--spacing-2xl)}.form-card input,.form-card select,.form-card textarea{background:#fff;border:2px solid var(--color-gray-400);border-radius:var(--border-radius-lg);color:var(--color-text-primary);font-size:var(--font-size-base);min-height:48px;padding:var(--spacing-md);transition:var(--transition-fast);width:100%}.form-card input:hover,.form-card select:hover,.form-card textarea:hover{border-color:var(--color-gray-500)}.form-card input:focus,.form-card select:focus,.form-card textarea:focus{background:#fff;border-color:var(--color-primary-main);box-shadow:0 0 0 4px #76b82a26;outline:none}.form-card input::placeholder{color:var(--color-gray-400)}.form-card select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23666' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;cursor:pointer;padding-right:36px}.form-card select option{padding:var(--spacing-md)}.form-card input[type=number]{font-variant-numeric:tabular-nums}.form-card input[type=date]{font-family:inherit}.form-card input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:0}.form-card input[type=date]::-webkit-inner-spin-button{display:none}.card-title{align-items:center;color:var(--color-text-primary);display:flex;font-size:var(--font-size-lg);gap:8px;margin-bottom:var(--spacing-xl)}.input-with-icon{position:relative}.input-icon{color:var(--color-gray-400);left:12px;position:absolute;top:50%;transform:translateY(-50%)}.input-with-icon .form-input{padding-left:40px}.field-hint{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-style:italic;margin-top:8px}.btn-submit-session{align-items:center;background:var(--color-primary-main);border:none;border-radius:var(--border-radius-xl);box-shadow:0 4px 12px #76b82a33;color:#fff;cursor:pointer;display:flex;font-size:var(--font-size-base);font-weight:700;gap:var(--spacing-md);justify-content:center;padding:var(--spacing-lg);transition:var(--transition-normal);width:100%}.btn-submit-session:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:0 8px 20px #76b82a4d;transform:translateY(-2px)}.btn-submit-session:disabled{background:var(--color-gray-300);box-shadow:none;cursor:not-allowed}.security-notice{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-xs);gap:6px;justify-content:center;margin-top:var(--spacing-md)}.budget-invoice{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-lg);padding:var(--spacing-2xl)}.invoice-header{align-items:center;border-bottom:2px solid var(--color-gray-100);color:var(--color-primary-main);display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md)}.invoice-header h2{color:var(--color-text-primary);font-size:var(--font-size-lg)}.invoice-program{margin-bottom:var(--spacing-xl)}.invoice-program label{color:var(--color-text-secondary);font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.invoice-program h3{color:var(--color-primary-main);font-size:var(--font-size-base)}.invoice-items{margin-bottom:var(--spacing-xl)}.invoice-item{border-bottom:1px dashed var(--color-gray-200);display:flex;justify-content:space-between;padding:var(--spacing-sm) 0}.item-main{display:flex;flex-direction:column}.item-name{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:700}.item-type{color:var(--color-text-secondary);font-size:10px}.item-details{display:flex;flex-direction:column;text-align:right}.item-math{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.item-total{color:var(--color-text-primary);font-weight:700}.invoice-footer{background:var(--color-gray-50);border-radius:var(--border-radius-lg);padding:var(--spacing-lg)}.total-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.total-row span:first-child{color:var(--color-text-secondary);font-weight:700}.total-amount{color:var(--color-primary-main);font-size:var(--font-size-xl);font-weight:800}.total-row-secondary{align-items:center;color:var(--color-success-dark);display:flex;font-size:11px;font-weight:700;gap:6px}.preview-placeholder{align-items:center;background:var(--color-gray-50);border:2px dashed var(--color-gray-300);border-radius:var(--border-radius-2xl);color:var(--color-gray-400);display:flex;flex-direction:column;height:300px;justify-content:center;padding:var(--spacing-2xl);text-align:center}.preview-placeholder h3{color:var(--color-gray-500);margin:var(--spacing-md) 0 8px}.checkbox-group .checkbox-label{align-items:center;background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--border-radius-md);cursor:pointer;display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm);transition:var(--transition-fast)}.checkbox-group .checkbox-label:hover{background:var(--color-gray-100)}.checkbox-group input[type=checkbox]{accent-color:var(--color-primary-main);height:18px;width:18px}.date-preview{background:#76b82a0d;border:1px solid #76b82a33;border-radius:var(--border-radius-lg);padding:var(--spacing-md)}.date-preview label{color:var(--color-primary-main);font-weight:700}.date-range-display{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.date-range-display .end-date,.date-range-display .start-date{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-md);color:var(--color-text-primary);font-weight:600;padding:var(--spacing-xs) var(--spacing-sm)}.date-range-display .arrow{color:var(--color-primary-main);font-weight:700}.duration-badge{background:var(--color-primary-main);border-radius:var(--border-radius-full);color:#fff;font-size:var(--font-size-xs);font-weight:700;padding:2px 8px}@media (max-width:1024px){.new-session-grid{grid-template-columns:1fr}.budget-invoice{position:static}}.multi-select-dropdown{position:relative;width:100%}.dropdown-label{color:#374151;font-weight:500;gap:8px;margin-bottom:6px}.dropdown-label,.dropdown-trigger{align-items:center;display:flex;font-size:14px}.dropdown-trigger{background:#fff;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;justify-content:space-between;padding:10px 14px;transition:all .2s}.dropdown-trigger:hover{border-color:#9ca3af}.dropdown-trigger.open{border-color:#76b82a;box-shadow:0 0 0 3px #76b82a1a}.dropdown-trigger .placeholder{color:#9ca3af}.dropdown-trigger svg{color:#6b7280;transition:transform .2s}.dropdown-trigger.open svg{transform:rotate(180deg)}.dropdown-menu{background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 10px 25px #00000026;display:flex;flex-direction:column;left:0;max-height:300px;position:absolute;right:auto;top:calc(100% + 4px);width:100%;z-index:1000}.dropdown-search{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;gap:10px;padding:10px 14px}.dropdown-search svg{color:#9ca3af;flex-shrink:0}.dropdown-search input{background:#0000;border:none;flex:1;font-size:14px;outline:none}.clear-search{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;justify-content:center;padding:2px}.clear-search:hover{background:#f3f4f6;color:#6b7280}.dropdown-actions{border-bottom:1px solid #e5e7eb;padding:8px 14px}.select-all-btn{color:#76b82a;font-size:13px;font-weight:500}.select-all-btn:hover{text-decoration:underline}.dropdown-options{flex:1;max-height:200px;overflow-y:auto}.no-results{color:#9ca3af;font-size:14px;padding:20px;text-align:center}.dropdown-option{align-items:center;cursor:pointer;display:flex;gap:10px;padding:10px 14px;transition:background .15s}.dropdown-option:hover{background:#f9fafb}.dropdown-option.selected{background:#76b82a1a}.option-checkbox{align-items:center;border:2px solid #d1d5db;border-radius:4px;color:#fff;display:flex;flex-shrink:0;height:18px;justify-content:center;transition:all .15s;width:18px}.dropdown-option.selected .option-checkbox{background:#76b82a;border-color:#76b82a}.option-label{color:#374151;font-size:14px}.dropdown-option.selected .option-label{color:#1f2937;font-weight:500}.dropdown-footer{background:#f9fafb;border-top:1px solid #e5e7eb;color:#6b7280;font-size:13px;padding:10px 14px;text-align:center}.form-group input,.form-group select,.form-group textarea{font-size:var(--font-size-sm)}.form-select{cursor:pointer}.dialog-error{font-weight:500;margin:0 var(--spacing-xl)}.dialog-actions{margin-top:var(--spacing-xl)}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #76b82a4d;transform:translateY(-2px)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-200);color:var(--color-text-primary)}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.dialog-container{margin:var(--spacing-md);max-width:calc(100% - var(--spacing-xl))}.form-row{grid-template-columns:1fr}.dialog-actions{flex-direction:column-reverse}.dialog-actions button{width:100%}}.dialog-overlay{animation:fadeIn .2s ease-out}.dialog-container{animation:slideUp .3s ease-out;border-radius:var(--border-radius-xl);box-shadow:0 20px 60px #0000004d;max-width:500px}.dialog-container.view-dialog{max-width:600px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dialog-close{border-radius:var(--border-radius-md);color:var(--color-gray-500)}.dialog-content{padding:var(--spacing-xl)}.dialog-container.view-dialog .dialog-content{background:#0000;border-radius:0;box-shadow:none;margin-left:auto;margin-right:auto;padding-bottom:0;width:90%}.detail-section{border-bottom:1px solid var(--color-gray-200);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);text-align:center}.consommable-name{color:var(--color-text-primary);font-size:var(--font-size-xl);font-weight:700;margin:0 0 var(--spacing-md) 0}.type-badge{align-items:center;display:inline-flex}.type-fixe{background:#76b82a1a;color:var(--color-primary-main)}.type-variable{background:#0061a81a;color:var(--color-info-main)}.type-formateur{background:#8b5cf61a;color:#7c3aed}.type-etudiant_formateur{background:#f7941e1f;color:#d97706}.details-grid{gap:var(--spacing-lg)}.detail-item,.detail-label{gap:var(--spacing-xs)}.detail-label{align-items:center;color:var(--color-text-secondary);display:flex;font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase}.detail-value{background:var(--color-gray-50);border-radius:var(--border-radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:600;padding:var(--spacing-sm)}.detail-value.price{color:var(--color-primary-main);font-size:var(--font-size-lg)}.btn-primary{justify-content:center;min-width:120px}@media (max-width:768px){.dialog-container{margin:var(--spacing-md);max-width:calc(100% - var(--spacing-xl))}.details-grid{grid-template-columns:1fr}}.assign-dialog{display:flex;flex-direction:column;max-height:80vh;max-width:500px}.dialog-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm);padding:0 var(--spacing-xl) var(--spacing-md)}.dialog-subtitle strong{color:var(--color-primary-main);font-weight:600}.search-bar{align-items:center;border-bottom:1px solid var(--color-gray-200);display:flex;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl)}.search-bar svg{color:var(--color-gray-400)}.search-bar input{background:#0000;border:none;flex:1;font-size:var(--font-size-sm);outline:none}.selection-info{align-items:center;background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200);color:var(--color-text-secondary);display:flex;font-size:var(--font-size-xs);justify-content:space-between;padding:var(--spacing-sm) var(--spacing-xl)}.select-all-btn{background:none;border:none;color:var(--color-primary-main);cursor:pointer;font-size:var(--font-size-xs);text-decoration:underline}.select-all-btn:hover{color:var(--color-primary-dark)}.formations-list{flex:1;max-height:400px;overflow-y:auto;padding:var(--spacing-sm)}.empty-formations{color:var(--color-gray-400);font-size:var(--font-size-sm);padding:var(--spacing-xl);text-align:center}.formation-item{align-items:center;border:1px solid #0000;border-radius:var(--border-radius-md);cursor:pointer;display:flex;gap:var(--spacing-md);padding:var(--spacing-md);transition:var(--transition-fast)}.formation-item:hover{background:var(--color-gray-50)}.formation-item.selected{background:#76b82a1a;border-color:var(--color-primary-main)}.formation-checkbox{align-items:center;border:2px solid var(--color-gray-300);border-radius:var(--border-radius-sm);color:#fff;display:flex;flex-shrink:0;height:20px;justify-content:center;transition:var(--transition-fast);width:20px}.formation-item.selected .formation-checkbox{background:var(--color-primary-main);border-color:var(--color-primary-main)}.formation-info{display:flex;flex-direction:column;gap:2px}.formation-title{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:600}.formation-duration{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.dialog-actions{padding:var(--spacing-lg) var(--spacing-xl)}.btn-secondary{border:1px solid var(--color-gray-300);border-radius:var(--border-radius-md);color:var(--color-text-secondary);padding:var(--spacing-md) var(--spacing-lg)}.btn-secondary:hover{background:var(--color-gray-50)}.btn-primary{border-radius:var(--border-radius-md);padding:var(--spacing-md) var(--spacing-lg)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.consommables-page{animation:fadeIn .5s ease-out;display:flex;flex-direction:column;height:100%;min-height:0}.consommables-page .ui-fixed-list{display:flex;flex:1;flex-direction:column;height:auto;min-height:0}.consommables-page .ui-fixed-list-scroll{flex:1;min-height:0;overflow-y:auto;position:relative}.consommables-page .ui-fixed-list>.table-container{flex-shrink:0}.consommables-page .data-table{table-layout:fixed;width:100%}.consommables-page .data-table td:first-child,.consommables-page .data-table th:first-child{width:18%}.consommables-page .data-table td:nth-child(2),.consommables-page .data-table td:nth-child(3),.consommables-page .data-table td:nth-child(4),.consommables-page .data-table th:nth-child(2),.consommables-page .data-table th:nth-child(3),.consommables-page .data-table th:nth-child(4){width:12%}.consommables-page .data-table td:nth-child(5),.consommables-page .data-table th:nth-child(5){width:20%}.consommables-page .data-table td:nth-child(6),.consommables-page .data-table th:nth-child(6){width:14%}.consommables-page .data-table td:nth-child(7),.consommables-page .data-table th:nth-child(7){width:12%}.filter-select{min-width:180px}.reference-cell{color:var(--color-primary-main);font-family:Courier New,monospace;font-weight:700}.name-cell{font-weight:600}.category-badge{border-radius:var(--border-radius-full);display:inline-block;font-size:var(--font-size-xs);font-weight:600;padding:4px 12px;text-transform:uppercase}.category-materiel{background:#0061a81a;color:var(--color-info-main)}.category-fourniture{background:#76b82a1a;color:var(--color-primary-main)}.category-equipement{background:#f7941e1a;color:var(--color-warning-main)}.category-consommable{background:#9ca3af1a;color:var(--color-gray-600)}.price-cell{align-items:center;color:var(--color-text-primary);display:flex;font-weight:600;gap:4px}.stock-cell{text-align:center}.stock-badge{background:#76b82a1a;border-radius:var(--border-radius-full);color:var(--color-primary-main);display:inline-block;font-weight:700;padding:4px 12px}.stock-badge.stock-low{background:#ef44441a;color:var(--color-error-main)}.action-assign:hover{background:#0061a80d;border-color:var(--color-info-main);color:var(--color-info-main)}.unassigned{color:var(--color-gray-400);font-style:italic}@media (max-width:768px){.filters-section,.page-header-section{flex-direction:column}.filters-section{align-items:stretch}.table-container{overflow-x:visible}.data-table{font-size:var(--font-size-xs);min-width:0;table-layout:auto}.data-table td,.data-table th{padding:var(--spacing-sm);width:auto!important}.name-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-add{justify-content:center;width:100%}}.dialog-overlay{overflow:hidden;padding:var(--spacing-lg)}.dialog-container{animation:dialogSlideIn .3s ease-out;background:#fff;border-radius:var(--border-radius-2xl);box-shadow:var(--shadow-xl);max-height:90vh;max-width:600px;overflow-x:hidden;overflow-y:auto;width:100%}@keyframes dialogSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dialog-header{padding:var(--spacing-xl)}.dialog-title{align-items:center;color:var(--color-primary-main);display:flex;gap:var(--spacing-md)}.dialog-title h2{color:var(--color-text-primary);font-size:var(--font-size-xl);font-weight:700;margin:0}.dialog-close{align-items:center;background:#0000;border:none;border-radius:var(--border-radius-lg);color:var(--color-gray-400);cursor:pointer;display:flex;justify-content:center;padding:var(--spacing-sm);transition:var(--transition-fast)}.dialog-close:hover{background:var(--color-gray-100);color:var(--color-text-primary)}.dialog-error{background:#ef44441a;border:1px solid #ef444433;border-radius:var(--border-radius-lg);color:var(--color-error-main);font-size:var(--font-size-sm);margin:var(--spacing-lg) var(--spacing-xl) 0;padding:var(--spacing-md)}.dialog-form{padding:var(--spacing-xl)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{color:var(--color-text-secondary);display:inline-flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);white-space:nowrap}.form-group label svg{flex-shrink:0}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #9ca3af;border-radius:var(--border-radius-lg);font-family:inherit;font-size:var(--font-size-base);padding:var(--spacing-md);transition:var(--transition-fast);width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary-main);box-shadow:0 0 0 3px #76b82a1a;outline:none}.form-row{gap:var(--spacing-lg)}.dialog-actions{border-top:1px solid var(--color-gray-200);gap:var(--spacing-md);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg)}.dialog-actions.single{justify-content:center}.btn-secondary{background:var(--color-gray-100);border:none;border-radius:var(--border-radius-lg);font-size:var(--font-size-sm);font-weight:600;padding:var(--spacing-md) var(--spacing-xl);transition:var(--transition-fast)}.btn-secondary:hover{background:var(--color-gray-200)}.btn-primary{align-items:center;border-radius:var(--border-radius-lg);display:flex;font-size:var(--font-size-sm);font-weight:600;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);transition:var(--transition-fast)}.btn-primary:hover{background:var(--color-primary-dark);box-shadow:0 4px 12px #76b82a4d;transform:translateY(-2px)}.btn-primary:disabled,.btn-secondary:disabled{transform:none}.view-dialog .dialog-content{padding:var(--spacing-xl)}.view-section{margin-bottom:var(--spacing-xl)}.view-grid{display:grid;gap:var(--spacing-sm);grid-template-columns:1fr 1fr}.view-item-full{grid-column:1/-1}.view-header{gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.view-header,.view-icon{align-items:center;display:flex}.view-icon{background:linear-gradient(135deg,var(--color-primary-main) 0,var(--color-primary-dark) 100%);border-radius:var(--border-radius-xl);color:#fff;height:64px;justify-content:center;width:64px}.view-title h3{color:var(--color-text-primary);font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-xs)}.view-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.section-title{align-items:center;color:var(--color-text-primary);display:flex;font-size:var(--font-size-base);font-weight:700;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.view-item{align-items:flex-start;background:var(--color-gray-50);border-radius:var(--border-radius-lg);display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);padding:var(--spacing-md)}.view-grid .view-item{margin-bottom:0}.view-icon-small{color:var(--color-primary-main);margin-top:2px}.view-item-content{flex:1;min-width:0}.view-label{color:var(--color-text-secondary);display:block;font-size:var(--font-size-xs);letter-spacing:.05em;margin-bottom:2px;text-transform:uppercase}.view-value{color:var(--color-text-primary);font-size:var(--font-size-base);font-weight:600;overflow-wrap:anywhere;word-break:break-all}.view-value.link{color:var(--color-primary-main);text-decoration:none}.view-value.link:hover{text-decoration:underline}.view-notes{background:var(--color-gray-50);border-radius:var(--border-radius-lg);font-size:var(--font-size-sm);line-height:1.5;padding:var(--spacing-md)}.view-meta,.view-notes{color:var(--color-text-secondary)}.view-meta{display:flex;flex-direction:column;font-size:var(--font-size-xs);gap:var(--spacing-xs)}@media (max-width:768px){.dialog-overlay{padding:var(--spacing-sm)}.dialog-container{max-height:95vh}.form-row{grid-template-columns:1fr}.dialog-form,.dialog-header,.view-dialog .dialog-content{padding:var(--spacing-lg)}.view-header{flex-direction:column;text-align:center}.view-grid{grid-template-columns:1fr}}.dialog-container.view-dialog{display:flex!important;flex-direction:column!important;max-height:90vh!important;max-width:95vw!important;overflow:hidden!important;width:95vw!important}.dialog-container.view-dialog .dialog-header{flex-shrink:0}.dialog-container.view-dialog .dialog-content{box-sizing:border-box;flex:1 1 auto;overflow-x:hidden;overflow-y:auto;padding:var(--spacing-xl) var(--spacing-2xl);width:100%}.dialog-container.view-dialog .dialog-content .view-grid,.dialog-container.view-dialog .dialog-content .view-section{width:100%}.dialog-container.view-dialog .dialog-actions{border-top:1px solid var(--color-gray-200);flex-shrink:0;margin-top:0;padding:var(--spacing-lg) var(--spacing-xl)}.fournisseurs-page{animation:fadeIn .5s ease-out;display:flex;flex-direction:column;height:100%;min-height:0}.fournisseurs-page .ui-fixed-list{display:flex;flex:1;flex-direction:column;height:auto;min-height:0}.fournisseurs-page .ui-fixed-list-scroll{flex:1;min-height:0;overflow-y:auto;position:relative}.fournisseurs-page .ui-fixed-list>.table-container{flex-shrink:0}.fournisseurs-page .data-table{table-layout:fixed;width:100%}.fournisseurs-page .data-table td:first-child,.fournisseurs-page .data-table th:first-child{width:20%}.fournisseurs-page .data-table td:nth-child(2),.fournisseurs-page .data-table th:nth-child(2){width:22%}.fournisseurs-page .data-table td:nth-child(3),.fournisseurs-page .data-table th:nth-child(3){width:15%}.fournisseurs-page .data-table td:nth-child(4),.fournisseurs-page .data-table th:nth-child(4){width:20%}.fournisseurs-page .data-table td:nth-child(5),.fournisseurs-page .data-table th:nth-child(5){width:11%}.fournisseurs-page .data-table td:nth-child(6),.fournisseurs-page .data-table th:nth-child(6){width:12%}.page-header-section{gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.page-title{font-size:var(--font-size-3xl);gap:var(--spacing-md);margin-bottom:var(--spacing-xs)}.page-subtitle{font-size:var(--font-size-base)}.btn-add{background:#5a8a1f!important;border-radius:var(--border-radius-lg);box-shadow:0 2px 4px #00000026;color:#fff!important;font-size:var(--font-size-sm);font-weight:600;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);text-decoration:none;transition:var(--transition-fast);white-space:nowrap}.btn-add:hover{background:#4a7a15!important;box-shadow:0 4px 12px #5a8a1f66;transform:translateY(-2px)}.btn-add:focus{background:#4a7a15!important;box-shadow:0 0 0 3px #5a8a1f4d;outline:none}.search-icon{pointer-events:none}.filter-select{border:1px solid var(--color-gray-300);border-radius:var(--border-radius-lg);cursor:pointer;font-size:var(--font-size-sm);font-weight:600;padding:var(--spacing-md);transition:var(--transition-fast)}@media (max-width:480px){.filter-select{min-width:auto;width:100%}.filters-section{flex-direction:column;gap:var(--spacing-sm)}.filter-group,.search-bar{width:100%}}.filter-select:focus{border-color:var(--color-primary-main);outline:none}.table-container{border:1px solid var(--color-gray-200);border-radius:var(--border-radius-xl)}.data-table thead{background:var(--color-gray-50);border-bottom:2px solid var(--color-gray-200)}.data-table th{color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:700;letter-spacing:.05em;padding:var(--spacing-md) var(--spacing-lg)}.data-table tbody tr{border-bottom:1px solid var(--color-gray-100);transition:var(--transition-fast)}.data-table tbody tr:hover{background:#76b82a05}.data-table td{color:var(--color-text-primary);font-size:var(--font-size-sm);padding:var(--spacing-lg)}.name-cell{color:var(--color-primary-main);font-weight:700}.type-badge{border-radius:var(--border-radius-full);display:inline-block;font-size:var(--font-size-xs);font-weight:600;padding:4px 12px;text-transform:uppercase}.type-materiel{background:#0061a81a;color:var(--color-info-main)}.type-fourniture{background:#76b82a1a;color:var(--color-primary-main)}.type-service{background:#f7941e1a;color:var(--color-warning-main)}.address-cell,.contact-cell,.phone-cell{color:var(--color-text-secondary)}.address-text,.phone-link{align-items:center;display:inline-flex;gap:var(--spacing-xs)}.products-cell,.products-link{color:var(--color-primary-main);font-weight:600}.products-link{background:none;border:none;cursor:pointer;font-size:var(--font-size-sm);padding:0;text-decoration:underline}.products-link:hover{color:var(--color-primary-dark)}.no-products{color:var(--color-gray-400);font-style:italic}.actions-column{width:150px}.actions-cell{gap:var(--spacing-xs)}.action-btn{border:1px solid var(--color-gray-300);border-radius:var(--border-radius-md);color:var(--color-text-secondary);padding:var(--spacing-xs);text-decoration:none;transition:var(--transition-fast)}.action-btn:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.action-view:hover{background:#0061a80d;border-color:var(--color-info-main);color:var(--color-info-main)}.action-edit:hover{background:#76b82a0d;border-color:var(--color-primary-main);color:var(--color-primary-main)}.action-delete:hover{background:#ef44440d;border-color:var(--color-error-main);color:var(--color-error-main)}.empty-state{color:var(--color-text-secondary);padding:var(--spacing-3xl) var(--spacing-xl)}.empty-state .empty-icon{color:var(--color-gray-300);margin-bottom:var(--spacing-lg)}.empty-state h3{color:var(--color-text-primary);font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs)}.empty-state p{font-size:var(--font-size-sm)}.table-footer{margin-top:var(--spacing-lg)}.results-count{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:600}.pagination{gap:var(--spacing-sm)}.pagination-btn{border:1px solid var(--color-gray-300);border-radius:var(--border-radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-md);transition:var(--transition-fast)}.page-numbers{gap:4px}.page-number{border:1px solid var(--color-gray-300);border-radius:var(--border-radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);transition:var(--transition-fast)}.page-number.active{background:#76b82a1f;border-color:#76b82a73;box-shadow:0 1px 0 #76b82a26;color:var(--color-primary-main);font-weight:700}@media (max-width:768px){.page-header-section{flex-direction:column}.page-title{font-size:var(--font-size-2xl)}.btn-add{justify-content:center;width:100%}.filters-section{align-items:stretch;flex-direction:column}.filter-group{margin-left:0;width:100%}.filter-select{min-width:0;width:100%}.table-container{overflow-x:visible}.data-table{font-size:var(--font-size-xs);table-layout:auto}.data-table td,.data-table th{padding:var(--spacing-sm);width:auto!important}.table-footer{align-items:stretch;flex-direction:column;gap:var(--spacing-md)}.pagination{justify-content:space-between}.page-numbers,.pagination{flex-wrap:wrap}}.dialog-content{border-radius:var(--border-radius-xl);max-height:80vh;overflow:hidden;width:90%}.dialog-header{border-bottom:1px solid var(--color-gray-200);padding:var(--spacing-lg)}.dialog-header h2{color:var(--color-text-primary);font-size:var(--font-size-lg)}.dialog-close-btn{color:var(--color-gray-400);padding:var(--spacing-xs);transition:var(--transition-fast)}.dialog-close-btn:hover{color:var(--color-gray-600)}.dialog-body{max-height:60vh;overflow-y:auto;padding:var(--spacing-lg)}.no-products-message{color:var(--color-gray-500);padding:var(--spacing-xl);text-align:center}.products-list{list-style:none;margin:0;padding:0}.product-item{align-items:center;border-bottom:1px solid var(--color-gray-100);display:flex;justify-content:space-between;padding:var(--spacing-md)}.product-item:last-child{border-bottom:none}.product-name{color:var(--color-text-primary);font-weight:500}.product-price{color:var(--color-primary-main);font-weight:600}.users-page{display:flex;flex-direction:column;height:100%;min-height:0;padding:0}.users-page .ui-fixed-list{display:flex;flex:1;flex-direction:column;height:auto;min-height:0}.users-page .ui-fixed-list-scroll{flex:1;min-height:0;overflow-y:auto;position:relative}.users-page .ui-fixed-list>.table-container{flex-shrink:0}.users-page .data-table{table-layout:fixed;width:100%}.users-page .data-table td:first-child,.users-page .data-table th:first-child{padding-left:16px;width:20%}.users-page .data-table td:nth-child(2),.users-page .data-table th:nth-child(2){width:25%}.users-page .data-table td:nth-child(3),.users-page .data-table th:nth-child(3){width:15%}.users-page .data-table td:nth-child(4),.users-page .data-table th:nth-child(4){width:18%}.users-page .data-table td:nth-child(5),.users-page .data-table th:nth-child(5){width:10%}.users-page .data-table td:nth-child(6),.users-page .data-table th:nth-child(6){width:12%}.page-header-section{margin-bottom:24px;padding:0 4px}.page-title{color:var(--gray-900);font-size:28px;font-weight:600;gap:12px;margin:0 0 8px}.page-title svg{color:var(--primary-blue)}.page-subtitle{color:var(--gray-500);font-size:14px}.btn-add{align-items:center;background:var(--gradient-primary);border:none;border-radius:8px;box-shadow:var(--shadow-sm);color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:12px 20px;transition:all .2s ease}.btn-add:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.tabs{border-bottom:2px solid var(--gray-200);margin-bottom:20px;padding-bottom:0}.tab,.tabs{display:flex;gap:8px}.tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:var(--gray-600);cursor:pointer;font-size:14px;font-weight:500;margin-bottom:-2px;padding:12px 20px;transition:all .2s ease}.tab:hover{background:var(--gray-50)}.tab.active,.tab:hover{color:var(--primary-blue)}.tab.active{background:var(--primary-light);border-bottom-color:var(--primary-blue)}.filters-section{align-items:center;background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-xl);display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding:var(--spacing-md)}.search-bar{flex:1;position:relative}.search-icon{color:var(--color-gray-400);left:16px;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:#fff;border:1px solid var(--color-gray-300);border-radius:var(--border-radius-lg);font-size:var(--font-size-sm);padding:var(--spacing-md) var(--spacing-xl) var(--spacing-md) 48px;transition:var(--transition-fast);width:100%}.search-input:focus{border-color:var(--color-primary-main);box-shadow:0 0 0 3px #76b82a1a;outline:none}.search-clear-btn{align-items:center;background:var(--color-gray-200);border:none;border-radius:50%;color:var(--color-gray-500);cursor:pointer;display:flex;height:20px;justify-content:center;padding:0;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:var(--transition-fast);width:20px}.search-clear-btn:hover{background:var(--color-gray-300);color:var(--color-gray-700)}.filter-group{display:flex;flex-shrink:0;margin-left:auto}.btn-search,.filter-group{align-items:center;color:var(--color-text-secondary);gap:var(--spacing-sm)}.btn-search{background:#fff;border:1px solid var(--color-gray-300);border-radius:var(--border-radius-lg);cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);font-weight:600;padding:var(--spacing-md) var(--spacing-xl);transition:var(--transition-fast);white-space:nowrap}.btn-search:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-400)}.table-container{background:#fff;border-radius:12px;box-shadow:var(--shadow-sm);overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table th{background:var(--gray-50);border-bottom:1px solid var(--gray-200);color:var(--gray-600);font-size:12px;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase}.data-table td{border-bottom:1px solid var(--gray-100);color:var(--gray-700);font-size:14px;padding:14px 16px}.data-table tr:hover{background:var(--gray-50)}.actions-column{text-align:center;width:100px}.actions-cell{gap:8px}.action-btn,.actions-cell{display:flex;justify-content:center}.action-btn{align-items:center;background:#0000;border:none;border-radius:6px;cursor:pointer;height:32px;transition:all .2s ease;width:32px}.action-view{background:var(--primary-light);color:var(--primary-blue)}.action-view:hover{background:var(--primary-blue);color:#fff}.action-edit{background:#ede9fe;color:#7c3aed}.action-btn.action-edit:hover{background:#3b82f61a;color:#3b82f6}.action-btn.action-delete{color:#ef4444}.action-btn.action-delete:hover{background:#ef44441a;color:#dc2626}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:.625rem 1.25rem;transition:all .2s ease}.btn-danger:hover{box-shadow:0 4px 12px #ef44444d;transform:translateY(-2px)}.confirm-dialog{max-width:500px}.toggle-inactive-label{align-items:center;border-radius:8px;cursor:pointer;display:flex;gap:.5rem;padding:.5rem 1rem;transition:background-color .2s ease;user-select:none}.toggle-inactive-label:hover{background-color:#f3f4f6}.toggle-inactive-checkbox{accent-color:#10b981;cursor:pointer;height:18px;width:18px}.toggle-inactive-text{color:#374151;font-size:.875rem;font-weight:500}.name-cell{font-weight:500;padding-left:16px}.user-name{gap:12px}.user-avatar-small,.user-name{align-items:center;display:flex}.user-avatar-small{background:var(--gradient-primary);border-radius:50%;color:#fff;font-size:12px;font-weight:600;height:36px;justify-content:center;width:36px}.email-cell a{align-items:center;color:var(--primary-blue);display:flex;gap:6px;text-decoration:none}.email-cell a:hover{text-decoration:underline}.role-cell{text-align:center}.role-badge{align-items:center;display:inline-flex;font-size:12px;font-weight:500;gap:6px;padding:6px 12px}.role-badge.admin{background:#fef3c7;color:#92400e}.role-badge.responsable{background:#dbeafe;color:#1e40af}.role-badge.formateur{background:#d1fae5;color:#065f46}.role-icon{flex-shrink:0}.centre-cell{color:var(--gray-600)}.empty-state{color:var(--gray-500);padding:60px 20px;text-align:center}.empty-state svg{color:var(--gray-300);margin-bottom:16px}.empty-state h3{color:var(--gray-700);font-size:16px;margin:0 0 8px}.empty-state p{font-size:14px;margin:0}.table-footer{align-items:center;color:var(--gray-500);display:flex;font-size:14px;justify-content:space-between;padding:16px}.results-count{margin:0}.pagination{align-items:center;display:flex;gap:12px}.pagination-btn{background:#fff;border:1px solid var(--gray-200);border-radius:8px;color:var(--gray-700);cursor:pointer;font-size:14px;padding:8px 12px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){border-color:var(--color-primary-main);color:var(--color-primary-main)}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.page-numbers{display:flex;gap:6px}.page-number{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:8px;color:var(--gray-700);cursor:pointer;display:flex;font-size:14px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.page-number:hover{border-color:var(--color-primary-main);color:var(--color-primary-main)}.page-number.active{background:var(--color-primary-main);border-color:var(--color-primary-main);color:#fff}.page-loading{color:var(--gray-500);gap:16px}.loader{border:3px solid var(--gray-200);border-top-color:var(--primary-blue);height:40px;width:40px}.dialog-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.dialog-content{background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.dialog-header{align-items:center;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:20px 24px}.dialog-header h2{align-items:center;color:var(--gray-900);display:flex;font-size:18px;font-weight:600;gap:10px;margin:0}.dialog-close-btn{align-items:center;background:none;border:none;border-radius:6px;color:var(--gray-400);cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.dialog-close-btn:hover{background:var(--gray-100);color:var(--gray-600)}.dialog-form{padding:24px}.form-row{gap:16px}.form-group{margin-bottom:20px}.form-group label{color:var(--gray-700);display:block;font-size:13px;font-weight:500;margin-bottom:6px}.form-group input,.form-group select{background:#fff;border:1px solid var(--gray-200);border-radius:8px;font-size:14px;padding:10px 14px;transition:all .2s ease;width:100%}.form-group input.disabled-input,.form-group input:disabled{background:var(--gray-100);color:var(--gray-600);cursor:not-allowed}.error-message{align-items:center;background:#fef2f2;border-radius:8px;color:#dc2626;display:flex;font-size:14px;gap:8px;margin-bottom:20px;padding:12px 16px}.dialog-actions{background:var(--gray-50);border-radius:0 0 12px 12px;border-top:1px solid var(--gray-200);display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.btn-secondary{background:#fff;border:1px solid var(--gray-200);border-radius:8px;color:var(--gray-700);cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s ease}.btn-secondary:hover{background:var(--gray-50);border-color:var(--gray-300)}.btn-primary{background:var(--gradient-primary);border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s ease}.btn-primary:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.user-details{padding:24px}.user-header{align-items:center;border-bottom:1px solid var(--gray-200);display:flex;gap:16px;margin-bottom:24px;padding-bottom:20px}.user-avatar-large{align-items:center;background:var(--gradient-primary);border-radius:50%;color:#fff;display:flex;font-size:24px;font-weight:600;height:64px;justify-content:center;width:64px}.user-info h3{color:var(--gray-900);font-size:20px;font-weight:600;margin:0 0 8px}.details-grid{display:grid;gap:20px;grid-template-columns:1fr 1fr}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item.full-width{grid-column:1/-1}.detail-item label{color:var(--gray-500);font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.detail-item p{align-items:center;color:var(--gray-700);display:flex;font-size:14px;gap:8px;margin:0}.centres-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.centre-tag{background:var(--primary-light);color:var(--primary-blue);padding:4px 10px}.centre-tag,.status-badge{border-radius:16px;font-size:12px;font-weight:500}.status-badge{display:inline-flex;padding:4px 12px}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}@media (max-width:768px){.page-header-section{flex-direction:column;gap:16px}.details-grid,.form-row{grid-template-columns:1fr}.tabs{overflow-x:auto}.table-container{overflow-x:visible}.data-table{table-layout:auto}.data-table td,.data-table th{font-size:13px;padding:10px 8px;width:auto!important}}.msd-container{position:relative;width:100%}.msd-control{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:8px;cursor:pointer;display:flex;font-size:14px;gap:10px;justify-content:space-between;padding:10px 14px;transition:all .2s ease;width:100%}.msd-container.disabled .msd-control,.msd-control:disabled{background:var(--gray-100);color:var(--gray-600);cursor:not-allowed}.msd-control:focus{outline:none}.msd-value{flex:1;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.msd-value.placeholder{color:var(--gray-400)}.msd-arrow{border-left:5px solid #0000;border-right:5px solid #0000;border-top:6px solid var(--gray-500);flex-shrink:0;height:0;width:0}.msd-menu{background:#fff;border:1px solid var(--gray-200);border-radius:10px;box-shadow:var(--shadow-md);left:0;margin-top:6px;max-height:240px;overflow:auto;padding:6px;position:absolute;right:0;z-index:1100}.msd-option{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--gray-700);cursor:pointer;display:flex;gap:10px;padding:10px;width:100%}.msd-selected-arrow{align-items:center;color:#0000;display:inline-flex;flex-shrink:0;height:16px;justify-content:center;width:16px}.msd-selected-arrow.on{color:var(--color-primary-main)}.msd-selected-arrow.on:before{content:"›";font-weight:900;line-height:1}.msd-option:hover{background:var(--gray-50)}.msd-option.selected{background:var(--primary-light);color:var(--primary-blue)}.msd-label{flex:1;text-align:left}.ui-dialog-container.assign-responsables-dialog{max-height:95vh}@media (max-width:768px){.ui-dialog-container.assign-responsables-dialog{max-height:95vh}}.centres-page .centre-name{align-items:center;display:flex;gap:8px}.centres-page .centre-inactive{font-size:.9em;margin-left:6px;opacity:.7}.centres-page .no-actions{opacity:.6}.permissions-admin-page{margin:0 auto;max-width:100%;padding:2rem;width:100%}.page-header-section{align-items:flex-start;display:flex;gap:2rem;justify-content:space-between;margin-bottom:2rem}.header-titles{flex:1}.page-title{align-items:center;color:var(--color-text-primary);display:flex;font-size:2rem;font-weight:700;gap:1rem;margin:0 0 .5rem}.page-subtitle{color:var(--color-text-secondary);font-size:1rem;margin:0}.header-actions{display:flex;flex-wrap:wrap;gap:.75rem}.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s;white-space:nowrap}.btn-primary{background:var(--color-primary-main);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px)}.btn-secondary{background:var(--color-background-secondary);border:1px solid var(--color-border);color:var(--color-text-primary)}.btn-secondary:hover:not(:disabled){background:var(--color-background-tertiary)}.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.changes-banner{background:var(--color-warning-light);border:1px solid var(--color-warning-main);border-radius:8px;color:var(--color-warning-dark);font-weight:600;margin-bottom:2rem;padding:1rem 1.5rem;text-align:center}.permissions-table-container{align-items:start;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.resource-table-section{background:#fff;border:1px solid var(--color-border);border-radius:12px;box-shadow:0 2px 8px #0000000d;transition:all .3s ease}.resource-table-header{align-items:center;background:var(--color-primary-main);border-radius:12px 12px 0 0;color:#fff;cursor:pointer;display:flex;justify-content:space-between;padding:1rem 1.5rem;transition:background-color .2s;user-select:none}.resource-table-header:hover{background:var(--color-primary-dark)}.resource-table-title{color:#fff;font-size:1.25rem;font-weight:700;margin:0}.dropdown-toggle{align-items:center;background:#0000;border:none;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:.25rem;transition:transform .2s}.dropdown-toggle:hover{transform:scale(1.1)}.permissions-table{border-collapse:collapse;width:100%}.permissions-table thead{background:var(--color-background-secondary)}.permissions-table th{border-bottom:2px solid var(--color-border);color:var(--color-text-primary);font-weight:700;padding:1rem;text-align:left}.permissions-table th.action-column{width:200px}.permissions-table th.role-column{min-width:180px;text-align:center}.role-header-cell{align-items:center;display:flex;flex-direction:column;gap:.5rem}.role-name{font-size:1rem;font-weight:700}.role-badge{background:var(--color-primary-main);border-radius:20px;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.permissions-table tbody tr{border-bottom:1px solid var(--color-border);transition:background-color .2s}.permissions-table tbody tr:hover{background:var(--color-background-secondary)}.permissions-table tbody tr:last-child{border-bottom:none}.action-cell{color:var(--color-text-primary);font-weight:600;padding:1rem 1.5rem}.checkbox-cell{padding:1rem;text-align:center;transition:background-color .2s}.checkbox-cell.has-change{background:var(--color-warning-light);border-left:3px solid var(--color-warning-main);border-right:3px solid var(--color-warning-main)}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:.75rem;justify-content:center;user-select:none}.permission-checkbox{cursor:pointer;opacity:0;position:absolute}.checkbox-custom{background:#fff;border:2px solid var(--color-border);border-radius:6px;height:24px;position:relative;transition:all .2s;width:24px}.permission-checkbox:checked~.checkbox-custom{background:var(--color-success-main);border-color:var(--color-success-main)}.permission-checkbox:checked~.checkbox-custom:after{color:#fff;content:"✓";font-size:16px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.permission-checkbox:not(:checked)~.checkbox-custom{background:var(--color-error-light);border-color:var(--color-error-main)}.permission-checkbox:not(:checked)~.checkbox-custom:after{color:var(--color-error-main);content:"✗";font-size:16px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.checkbox-label:hover .checkbox-custom{box-shadow:0 2px 8px #00000026;transform:scale(1.1)}.permission-status{font-size:.875rem;font-weight:600}.permission-checkbox:checked~.permission-status{color:var(--color-success-dark)}.permission-checkbox:not(:checked)~.permission-status{color:var(--color-error-dark)}.page-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:400px}.loader{animation:spin 1s linear infinite;border:4px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary-main);height:48px;width:48px}@media (max-width:1200px){.permissions-table-container{grid-template-columns:1fr}}@media (max-width:768px){.permissions-admin-page{padding:1rem}.page-header-section{flex-direction:column;gap:1rem}.header-actions{justify-content:flex-end;width:100%}.permissions-table-container{grid-template-columns:1fr}.resource-table-title{font-size:1rem}.permissions-table td,.permissions-table th{font-size:.875rem;padding:.75rem}.role-header-cell{gap:.25rem}.role-name{font-size:.875rem}.role-badge{font-size:.625rem;padding:.125rem .5rem}.checkbox-label{flex-direction:column;gap:.5rem}.permission-status{font-size:.75rem}}.profile-page{margin:0 auto;max-width:1200px}.profile-header{margin-bottom:var(--spacing-xl)}.profile-title{align-items:center;color:#fff;display:flex;font-size:var(--font-size-2xl);font-weight:700;gap:var(--spacing-md);margin:0 0 var(--spacing-xs) 0}.profile-subtitle{color:#fff;font-size:var(--font-size-md);margin:0}.profile-content{display:grid;gap:var(--spacing-xl);grid-template-columns:1fr 1fr}.profile-card{background:#fff;border:1px solid var(--color-gray-200);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);padding:var(--spacing-xl)}.profile-card-header{align-items:center;border-bottom:2px solid var(--color-gray-200);display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md)}.profile-card-header h2{color:var(--color-text-primary);font-size:var(--font-size-lg);font-weight:700;margin:0}.profile-card-header svg{color:var(--color-primary-main)}.profile-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-row{display:grid;gap:var(--spacing-md);grid-template-columns:1fr 1fr}.form-group{flex-direction:column}.form-group,.form-group label{display:flex;gap:var(--spacing-xs)}.form-group label{align-items:center;color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:600}.form-group label svg{color:var(--color-text-secondary)}.form-input{background:#fff!important;border:2px solid #d1d5db!important;border-radius:var(--border-radius-md);box-sizing:border-box;font-size:var(--font-size-sm);outline:none;padding:var(--spacing-sm) var(--spacing-md);transition:var(--transition-fast);width:100%}.form-input:focus{border-color:var(--color-primary-main);box-shadow:0 0 0 3px #76b82a1a;outline:none}.form-input:disabled{background:var(--color-gray-100);cursor:not-allowed}.btn-save{align-items:center;align-self:flex-start;background:var(--color-primary-main);border:none;border-radius:var(--border-radius-md);color:#fff;cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);font-weight:600;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);transition:var(--transition-fast)}.btn-save:hover:not(:disabled){background:var(--color-primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-save:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.profile-page{padding:var(--spacing-md)}.profile-title{font-size:var(--font-size-xl)}.profile-card{padding:var(--spacing-lg)}.form-row{grid-template-columns:1fr}.btn-save{justify-content:center;width:100%}}:root{--color-primary-main:#76b82a;--color-primary-light:#95d64a;--color-primary-dark:#5c9021;--color-primary-contrast:#fff;--color-secondary-main:#f7941e;--color-secondary-light:#f9ad55;--color-secondary-dark:#c67618;--color-secondary-contrast:#fff;--color-success-main:#76b82a;--color-success-light:#95d64a;--color-success-dark:#5c9021;--color-success-contrast:#fff;--color-warning-main:#f7941e;--color-warning-light:#f9ad55;--color-warning-dark:#c67618;--color-warning-contrast:#fff;--color-error-main:#e30613;--color-error-light:#ef5350;--color-error-dark:#c62828;--color-error-contrast:#fff;--color-info-main:#0061a8;--color-info-light:#3381b9;--color-info-dark:#004375;--color-info-contrast:#fff;--color-gray-50:#f8fafc;--color-gray-100:#f1f5f9;--color-gray-200:#e2e8f0;--color-gray-300:#cbd5e1;--color-gray-400:#94a3b8;--color-gray-500:#64748b;--color-gray-600:#475569;--color-gray-700:#334155;--color-gray-800:#1e293b;--color-gray-900:#1c1c1b;--color-background-default:#f4f6f8;--color-background-paper:#fff;--color-background-elevated:#fff;--color-text-primary:#1c1c1b;--color-text-secondary:#64748b;--color-text-disabled:#94a3b8;--color-text-hint:#cbd5e1;--color-status-pending:#f7941e;--color-status-validated:#76b82a;--color-status-rejected:#e30613;--color-status-cancelled:#64748b;--gradient-swoosh:linear-gradient(90deg,#f7941e,#e30613);--font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--spacing-3xl:4rem;--border-radius-sm:0.25rem;--border-radius-md:0.375rem;--border-radius-lg:0.5rem;--border-radius-xl:0.75rem;--border-radius-2xl:1rem;--border-radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--transition-fast:150ms ease-in-out;--transition-normal:200ms ease-in-out;--transition-slow:300ms ease-in-out;--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px}*{margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background-color:var(--color-background-default);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.5}h1{font-size:var(--font-size-2xl);font-weight:700;line-height:1.25}h2{font-size:var(--font-size-xl);font-weight:600;line-height:1.3}h3{font-size:var(--font-size-lg)}h3,h4{font-weight:600;line-height:1.4}h4{font-size:var(--font-size-base)}@media (min-width:768px){h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}}@media (min-width:1024px){h1{font-size:var(--font-size-4xl)}}@tailwind base;@tailwind components;@tailwind utilities;*{box-sizing:border-box}:focus{color:inherit!important}body,html{max-width:100vw;overflow-x:hidden}body{position:relative}@layer components{.ui-btn,.ui-btn-primary,.ui-btn-primary:hover:not(:disabled),.ui-btn-secondary,.ui-dialog-container,.ui-dialog-overlay,.ui-input,.ui-input:focus,.ui-input:hover,.ui-label,.ui-select,.ui-select:focus,.ui-select:hover,.ui-textarea,.ui-textarea:focus,.ui-textarea:hover{@apply bg-white rounded-2xl w-full max-w-2xl max-h-[90vh] overflow-y-auto shadow-xl}@media (max-width:768px){.ui-dialog-container,.ui-dialog-header{@apply px-4 py-4}}.ui-dialog-actions,.ui-dialog-header,.ui-dialog-title{@apply flex gap-3 justify-end mt-6 pt-5 border-t border-gray-200}}.ui-input,.ui-select,.ui-textarea{background-color:#fff!important;border:2px solid #d1d5db!important}.ui-input:hover,.ui-select:hover,.ui-textarea:hover{border-color:#9ca3af!important}.ui-input:focus,.ui-select:focus,.ui-textarea:focus{border-color:var(--color-primary-main)!important}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding:var(--spacing-md)}.ui-fixed-list{display:flex;flex-direction:column;height:calc(100vh - 320px);min-height:360px}.ui-fixed-list-scroll{background:#fff;flex:1;min-height:0;overflow:auto}.ui-fixed-list-scroll>.table-container{min-height:100%}.ui-fixed-list-footer{flex-shrink:0}@media (min-width:768px){.main-content{padding:var(--spacing-lg)}}@media (min-width:1024px){.main-content{margin:0 auto;max-width:1280px;padding:var(--spacing-xl);width:100%}}.container{margin:0 auto;padding:0 var(--spacing-md);width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px;padding:0 var(--spacing-lg)}}@media (min-width:1024px){.container{max-width:1024px;padding:0 var(--spacing-xl)}}@media (min-width:1280px){.container{max-width:1280px}}
/*# sourceMappingURL=main.e60d2ccd.css.map*/