.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:width var(--transition-normal);overflow:hidden}.sidebar-collapsed{width:var(--sidebar-collapsed)}.sidebar-collapsed .sidebar-item{justify-content:center;padding:var(--space-sm) 0}.sidebar-collapsed .sidebar-section{padding:0 var(--space-xs)}.sidebar-collapsed .sidebar-footer{align-items:center;padding:12px var(--space-xs)}.sidebar-collapsed .sidebar-parametrage-btn,.sidebar-collapsed .sidebar-logout-btn{justify-content:center;padding:var(--space-xs) 0}.sidebar-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-md);border-bottom:1px solid var(--border-color);min-height:var(--topbar-height)}.sidebar-collapsed .sidebar-header{justify-content:center;padding:var(--space-md) var(--space-xs);gap:0}.sidebar-toggle-btn{margin-left:auto;flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);color:var(--text-tertiary);cursor:pointer;transition:all var(--transition-fast);background:transparent;border:none;padding:0}.sidebar-toggle-btn:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.sidebar-collapsed .sidebar-toggle-btn{margin-left:0}.sidebar-tenant-logo{width:36px;height:36px;border-radius:var(--border-radius-md);object-fit:contain;flex-shrink:0}.sidebar-header-text{display:flex;flex-direction:column;gap:2px;min-width:0}.sidebar-logo{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-primary);letter-spacing:.05em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-sm) var(--space-sm)}.sidebar-section{margin-bottom:var(--space-sm)}.sidebar-section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);padding:12px 12px var(--space-xs)}.sidebar-item{display:flex;align-items:center;gap:12px;padding:var(--space-sm) 12px;border-radius:var(--border-radius-md);color:var(--text-secondary);font-size:var(--font-size-md);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;background:transparent;width:100%;text-align:left}.sidebar-item:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.sidebar-item-active{background:var(--color-primary-subtle);color:var(--color-primary)}.sidebar-item-active .material-symbols-outlined{font-variation-settings:"FILL" 1,"wght" 300,"GRAD" 0,"opsz" 24}.sidebar-footer{border-top:1px solid var(--border-color);padding:12px var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm)}.sidebar-user-info{display:flex;align-items:center;gap:var(--space-sm);min-width:0}.sidebar-user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-logout-btn{display:flex;align-items:center;gap:var(--space-xs);width:100%;padding:var(--space-xs) var(--space-sm);border-radius:var(--border-radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);transition:all var(--transition-fast)}.sidebar-logout-btn:hover{background:var(--color-danger-subtle);color:var(--color-danger)}.sidebar-parametrage-btn{display:flex;align-items:center;gap:var(--space-xs);width:100%;padding:var(--space-xs) var(--space-sm);border-radius:var(--border-radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);transition:all var(--transition-fast)}.sidebar-parametrage-btn:hover{background:var(--color-primary-subtle);color:var(--color-primary)}.sidebar-logout-label{font-size:var(--font-size-sm)}.badge-secondary{display:inline-block;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}.sidebar-tabs{display:flex;border-bottom:2px solid var(--border-color)}.sidebar-tab{flex:1;padding:var(--space-sm) var(--space-md);border-bottom:2px solid transparent;background:transparent;border-top:none;border-left:none;border-right:none;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.sidebar-tab:hover{color:var(--text-primary)}.sidebar-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;overflow-x:hidden;transition:margin-left var(--transition-normal)}.main-content-collapsed{margin-left:var(--sidebar-collapsed)}.topbar{height:var(--topbar-height);background:var(--bg-surface);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:50}.topbar-left{display:flex;align-items:center;gap:12px}.topbar-right{display:flex;align-items:center;gap:var(--space-sm)}.page-content{padding:20px;padding-right:calc(20px + var(--user-sidebar-offset, 42px));min-height:calc(100vh - var(--topbar-height));transition:padding-right .22s ease}body.user-sidebar-expanded .page-content{--user-sidebar-offset: 280px}body:not(.user-sidebar-expanded) .page-content{--user-sidebar-offset: 42px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.page-title{display:flex;align-items:center;gap:12px;font-size:var(--font-size-h1);font-weight:var(--font-weight-bold)}.page-actions{display:flex;align-items:center;gap:var(--space-sm)}.arm-tabs-bar{display:flex;gap:2px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:3px;overflow-x:auto;flex-wrap:wrap}.arm-tab-btn{padding:6px 14px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);cursor:pointer;transition:all var(--transition-fast)}.arm-tab-btn:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.arm-tab-btn.active{background:var(--color-primary);color:var(--text-on-primary);box-shadow:0 1px 4px #00000026}[data-theme=dark] .arm-tab-btn.active{color:#121212}.toolbar{display:flex;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-sm)}.toolbar-spacer{flex:1}.info-bar{display:flex;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-sm)}@media (max-width: 900px){.app-layout{flex-direction:column;height:auto}.sidebar{position:relative;width:100%!important;max-height:300px;border-right:none;border-bottom:1px solid var(--border-color)}.main-content{margin-left:0!important}.page-content{padding-right:16px}}@media (min-width: 1921px){.page-content{padding:var(--space-lg)}}@media print{.sidebar,.topbar,.no-print{display:none!important}.main-content{margin-left:0!important}body{background:#fff;color:#000}}.mv-view-switch{display:inline-flex;gap:1px;background:var(--color-border, rgba(128, 128, 128, .2));border-radius:6px;overflow:hidden}.mv-view-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:var(--color-surface, #fff);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.mv-view-btn:hover{background:var(--color-surface-hover, rgba(128, 128, 128, .08));color:var(--color-text)}.mv-view-btn.active{background:var(--color-primary);color:#fff}.mv-select-bar{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:color-mix(in srgb,var(--color-primary) 8%,var(--color-bg, #fff));border:1px solid color-mix(in srgb,var(--color-primary) 30%,transparent);border-radius:8px;font-size:.8rem;animation:mv-slide-in .2s ease}@keyframes mv-slide-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.mv-select-bar .mv-count{font-weight:600;color:var(--color-primary)}.mv-select-bar .mv-sep{width:1px;height:1.2rem;background:var(--color-border, rgba(128, 128, 128, .3))}.mv-select-bar .btn-danger,.mv-select-bar .btn-ghost{font-size:.75rem;padding:.25rem .5rem}.mv-checkbox{position:relative;width:18px;height:18px;flex-shrink:0}.mv-checkbox input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;border:2px solid var(--color-border, rgba(128, 128, 128, .4));border-radius:4px;background:transparent;cursor:pointer;transition:all .15s}.mv-checkbox input[type=checkbox]:checked{background:var(--color-primary);border-color:var(--color-primary)}.mv-checkbox input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:.7rem;font-weight:700}.mv-checkbox input[type=checkbox]:hover{border-color:var(--color-primary)}.mv-list{display:flex;flex-direction:column;gap:2px}.mv-list-row{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--color-surface, #fff);border-radius:6px;transition:background .15s;cursor:pointer}.mv-list-row:hover{background:var(--color-surface-hover, rgba(128, 128, 128, .05))}.mv-list-row.selected{background:color-mix(in srgb,var(--color-primary) 8%,var(--color-surface, #fff))}.mv-list-row .mv-list-main{flex:1;min-width:0;display:flex;align-items:center;gap:.5rem}.mv-list-row .mv-list-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mv-list-row .mv-list-meta{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--color-text-secondary);flex-shrink:0}.mv-list-row .mv-list-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .15s}.mv-list-row:hover .mv-list-actions{opacity:1}.mv-table-wrap{overflow-x:auto;border-radius:8px;border:1px solid var(--color-border, rgba(128, 128, 128, .2))}.mv-table{width:100%;border-collapse:collapse;font-size:.85rem}.mv-table th{padding:.5rem .75rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);background:var(--color-surface, rgba(128, 128, 128, .04));white-space:nowrap;border-bottom:1px solid var(--color-border, rgba(128, 128, 128, .2));-webkit-user-select:none;user-select:none}.mv-table td{padding:.5rem .75rem;vertical-align:middle;border-bottom:1px solid var(--color-border, rgba(128, 128, 128, .1))}.mv-table tr:hover td{background:var(--color-surface-hover, rgba(128, 128, 128, .03))}.mv-table tr.selected td{background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.mv-table th:first-child,.mv-table td:first-child{width:36px;text-align:center}.card.mv-selected{outline:2px solid var(--color-primary);outline-offset:-2px}.card .mv-card-check{position:absolute;top:6px;left:6px;z-index:2}.mv-grid-card{position:relative}.sfb-container{display:flex;flex-direction:column;gap:.4rem}.sfb-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.sfb-search{position:relative;display:flex;align-items:center;flex:1 1 200px;min-width:180px;max-width:400px}.sfb-search-icon{position:absolute;left:.5rem;font-size:1.1rem;color:var(--color-text-secondary);pointer-events:none}.sfb-search-input{width:100%;padding:.45rem 1.8rem .45rem 2rem;border:1.5px solid var(--color-border, rgba(128, 128, 128, .25));border-radius:.5rem;background:var(--color-surface, #fff);color:var(--color-text);font-size:.85rem;transition:border-color .15s,box-shadow .15s}.sfb-search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f626}.sfb-search-input::placeholder{color:var(--color-text-secondary);opacity:.7}.sfb-clear-btn{position:absolute;right:.3rem;display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;background:none;color:var(--color-text-secondary);cursor:pointer;border-radius:50%;transition:background .12s}.sfb-clear-btn:hover{background:var(--color-surface-hover, rgba(128, 128, 128, .1));color:var(--color-text)}.sfb-filter-toggle{display:flex;align-items:center;justify-content:center;gap:.2rem;width:36px;height:36px;border:1.5px solid var(--color-border, rgba(128, 128, 128, .25));border-radius:.5rem;background:var(--color-surface, #fff);color:var(--color-text-secondary);cursor:pointer;position:relative;transition:all .15s}.sfb-filter-toggle:hover{border-color:var(--color-primary);color:var(--color-primary)}.sfb-filter-toggle.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.sfb-filter-toggle.has-filters{border-color:var(--color-primary);color:var(--color-primary)}.sfb-filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:var(--color-primary);color:#fff;font-size:.6rem;font-weight:700;line-height:1}.sfb-filter-toggle.active .sfb-filter-badge{background:#fff;color:var(--color-primary)}.sfb-reset-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;color:var(--color-text-secondary);cursor:pointer;border-radius:.4rem;transition:all .12s}.sfb-reset-btn:hover{background:#ef44441a;color:var(--color-danger)}.sfb-count{font-size:.78rem;color:var(--color-text-secondary);white-space:nowrap;font-variant-numeric:tabular-nums}.sfb-chips{display:flex;flex-wrap:wrap;gap:.3rem;padding:.15rem 0}.sfb-chip{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .1rem .15rem .5rem;border-radius:1rem;background:var(--color-primary-alpha, rgba(59, 130, 246, .1));color:var(--color-primary);font-size:.7rem;font-weight:500;line-height:1.3;max-width:250px}.sfb-chip-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sfb-chip-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;background:none;color:var(--color-primary);cursor:pointer;border-radius:50%;flex-shrink:0;transition:background .12s}.sfb-chip-remove:hover{background:#3b82f633}.sfb-panel{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.6rem;padding:.75rem;background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:.5rem;animation:sfb-slide-in .15s ease}@keyframes sfb-slide-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sfb-control{display:flex;flex-direction:column;gap:.2rem;position:relative}.sfb-label{display:flex;align-items:center;gap:.25rem;font-size:.7rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em}.sfb-select,.sfb-text-input{padding:.35rem .5rem;border:1.5px solid var(--color-border, rgba(128, 128, 128, .25));border-radius:.4rem;background:var(--color-bg, #fff);color:var(--color-text);font-size:.8rem;transition:border-color .15s}.sfb-select:focus,.sfb-text-input:focus{outline:none;border-color:var(--color-primary)}.sfb-control--toggle{justify-content:center}.sfb-toggle-label{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none}.sfb-toggle-label input[type=checkbox]{accent-color:var(--color-primary)}.sfb-multi-trigger{display:flex;align-items:center;gap:.3rem;padding:.35rem .5rem;border:1.5px solid var(--color-border, rgba(128, 128, 128, .25));border-radius:.4rem;background:var(--color-bg, #fff);color:var(--color-text);font-size:.8rem;cursor:pointer;text-align:left;transition:border-color .15s}.sfb-multi-trigger:hover{border-color:var(--color-primary)}.sfb-multi-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:2px;background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .2));border-radius:.5rem;box-shadow:0 4px 16px #0000001f;z-index:100;display:flex;flex-direction:column;overflow:hidden;animation:sfb-slide-in .12s ease}.sfb-multi-search{padding:.4rem .5rem;border:none;border-bottom:1px solid var(--color-border, rgba(128, 128, 128, .15));background:transparent;color:var(--color-text);font-size:.8rem;outline:none}.sfb-multi-list{max-height:200px;overflow-y:auto;padding:.25rem 0}.sfb-multi-option{display:flex;align-items:center;gap:.4rem;padding:.3rem .5rem;font-size:.8rem;color:var(--color-text);cursor:pointer;transition:background .1s}.sfb-multi-option:hover{background:var(--color-surface-hover, rgba(128, 128, 128, .06))}.sfb-multi-option input[type=checkbox]{accent-color:var(--color-primary);flex-shrink:0}.sfb-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sfb-multi-empty{padding:.5rem;text-align:center;font-size:.75rem;color:var(--color-text-secondary)}.sfb-multi-clear{padding:.35rem;border:none;border-top:1px solid var(--color-border, rgba(128, 128, 128, .15));background:transparent;color:var(--color-primary);font-size:.75rem;cursor:pointer;text-align:center;transition:background .12s}.sfb-multi-clear:hover{background:var(--color-surface-hover, rgba(128, 128, 128, .06))}.ticket-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#00000073;display:flex;align-items:center;justify-content:center;animation:ticketFadeIn .2s ease-out}.ticket-modal{background:var(--color-bg-primary, #fff);border-radius:14px;width:480px;max-width:95vw;max-height:90vh;overflow-y:auto;padding:24px;box-shadow:0 20px 60px #0000004d;animation:ticketSlideIn .25s ease-out}.ticket-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.ticket-modal-title{font-size:1.1rem;font-weight:700;color:var(--color-text-primary)}.ticket-modal-close{background:none;border:none;cursor:pointer;padding:4px;color:var(--color-text-secondary);border-radius:6px;display:flex}.ticket-modal-close:hover{background:var(--color-bg-hover)}.ticket-context-bar{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:.78rem;color:var(--color-text-secondary)}.ticket-context-tag{background:var(--color-bg-tertiary, #f0f0f0);padding:2px 8px;border-radius:4px;font-family:monospace;font-size:.72rem}.ticket-context-user{margin-left:auto}.ticket-type-selector{display:flex;gap:8px;margin-bottom:16px}.ticket-type-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;border:2px solid var(--color-border, #ddd);border-radius:10px;background:var(--color-bg-primary);cursor:pointer;font-size:.82rem;font-weight:600;color:var(--color-text-secondary);transition:all .15s}.ticket-type-btn:hover{background:var(--color-bg-hover)}.ticket-type-btn.active{background:var(--color-bg-tertiary)}.ticket-type-btn .material-symbols-outlined{font-size:18px}.ticket-field{margin-bottom:16px}.ticket-field label{display:block;font-size:.78rem;font-weight:600;margin-bottom:6px;color:var(--color-text-secondary)}.ticket-field textarea{width:100%;border:1px solid var(--color-border);border-radius:8px;padding:10px 12px;font-size:.85rem;resize:vertical;background:var(--color-bg-primary);color:var(--color-text-primary);font-family:inherit;box-sizing:border-box}.ticket-field textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f626}.ticket-screenshot-section{margin-bottom:16px}.ticket-screenshot-section label{display:block;font-size:.78rem;font-weight:600;margin-bottom:6px;color:var(--color-text-secondary)}.ticket-screenshot-actions{display:flex;align-items:center;gap:10px;margin-bottom:8px}.ticket-attach-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg-primary);cursor:pointer;font-size:.78rem;color:var(--color-text-primary);transition:background .15s}.ticket-attach-btn:hover{background:var(--color-bg-hover)}.ticket-attach-btn .material-symbols-outlined{font-size:16px}.ticket-paste-hint{font-size:.72rem;color:var(--color-text-tertiary)}.ticket-screenshot-preview{position:relative;display:inline-block;margin-top:4px}.ticket-screenshot-preview img{max-height:160px;max-width:100%;border-radius:8px;border:1px solid var(--color-border)}.ticket-screenshot-remove{position:absolute;top:4px;right:4px;background:#0009;color:#fff;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer}.ticket-screenshot-remove .material-symbols-outlined{font-size:14px}.ticket-error{color:#ef4444;font-size:.78rem;margin-bottom:12px;padding:6px 10px;background:#ef444414;border-radius:6px}.ticket-submit-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:none;border-radius:10px;background:var(--color-primary, #3b82f6);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .15s}.ticket-submit-btn:hover:not(:disabled){opacity:.9}.ticket-submit-btn:disabled{opacity:.5;cursor:not-allowed}.ticket-submit-btn .material-symbols-outlined{font-size:18px}.ticket-sent{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;gap:12px}.ticket-sent-icon{font-size:56px;color:#22c55e;animation:ticketCheckPop .4s ease-out}.ticket-sent p{font-size:1rem;font-weight:600;color:var(--color-text-primary)}@keyframes ticketFadeIn{0%{opacity:0}to{opacity:1}}@keyframes ticketSlideIn{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes ticketCheckPop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}[data-theme=dark] .ticket-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border)}[data-theme=dark] .ticket-context-tag{background:var(--color-bg-tertiary)}.ticket-element-context{margin:8px 16px 0;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-tertiary, #f5f5f5);font-size:11px}.ticket-element-context summary{cursor:pointer;padding:6px 10px;display:flex;align-items:center;gap:6px;color:var(--color-text-secondary);-webkit-user-select:none;user-select:none}.ticket-element-context summary .material-symbols-outlined{font-size:14px}.ticket-element-context pre{margin:0;padding:8px 10px;border-top:1px solid var(--color-border);white-space:pre-wrap;word-break:break-all;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:10.5px;color:var(--color-text-primary);max-height:140px;overflow:auto}.help-btn-wrapper{display:inline-flex;align-items:center;gap:4px;position:relative}.help-btn-wrapper.help-btn-floating{position:fixed;right:18px;bottom:18px;z-index:9998}.help-btn-wrapper.help-btn-floating .help-bug-btn{width:48px;height:48px;box-shadow:0 4px 14px #00000040}.help-btn-wrapper.help-btn-floating .help-bug-btn .material-symbols-outlined{font-size:26px}.help-bug-btn{width:28px;height:28px;border-radius:50%;border:2px solid var(--color-danger, #ef4444);background:var(--color-bg-primary, #fff);color:var(--color-danger, #ef4444);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.help-bug-btn:hover{background:var(--color-danger, #ef4444);color:#fff}.help-bug-btn .material-symbols-outlined{font-size:16px}[data-theme=dark] .help-bug-btn{background:var(--color-bg-secondary)}[data-theme=dark] .help-bug-btn:hover{background:var(--color-danger, #ef4444)}.formation-chip{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-1) var(--sp-3);border-radius:var(--radius-full);font-size:.8rem;font-weight:500;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition);white-space:nowrap;position:relative;max-width:260px}.formation-chip:hover{border-color:var(--color-primary);color:var(--color-text);background:var(--color-surface-hover)}.formation-chip-active{border-color:var(--color-primary);background:var(--color-primary-subtle);color:var(--color-primary)}.formation-chip-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.formation-chip-arrow{font-size:16px;transition:transform var(--transition);flex-shrink:0}.formation-chip-arrow-open{transform:rotate(180deg)}.formation-chip-dropdown{position:fixed;z-index:9000;min-width:300px;max-width:380px;max-height:400px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;animation:fadeIn .15s ease}.formation-chip-search{padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--color-border);flex-shrink:0}.formation-chip-search input{width:100%;font-size:.8rem;padding:var(--sp-1) var(--sp-2)}.formation-chip-list{overflow-y:auto;flex:1}.formation-chip-all{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);font-size:.8rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;border-bottom:1px solid var(--color-border-subtle);transition:background var(--transition)}.formation-chip-all:hover{background:var(--color-surface-hover)}.formation-chip-all-active{color:var(--color-primary);background:var(--color-primary-subtle)}.formation-chip-group{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-secondary);background:var(--color-surface-variant);border-bottom:1px solid var(--color-border-subtle)}.formation-chip-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3) var(--sp-2) var(--sp-6);font-size:.8rem;cursor:pointer;transition:background var(--transition);border-bottom:1px solid var(--color-border-subtle)}.formation-chip-item:hover{background:var(--color-surface-hover)}.formation-chip-item-active{background:var(--color-primary-subtle);color:var(--color-primary)}.formation-chip-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.formation-chip-item-meta{display:flex;align-items:center;gap:var(--sp-2);flex-shrink:0}.formation-chip-item-dates{font-size:.7rem;color:var(--color-text-tertiary);white-space:nowrap}.formation-chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.formation-chip-check{width:16px;height:16px;flex-shrink:0;pointer-events:none}.mod-manager{display:flex;flex-direction:column;gap:var(--space-4);max-width:960px}.mod-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.mod-header h3{margin:0;font-size:calc(var(--font-size-lg) * var(--font-zoom, 1))}.mod-total{font-size:calc(var(--font-size-sm) * var(--font-zoom, 1));color:var(--text-secondary)}.mod-list{display:flex;flex-direction:column;gap:var(--space-3)}.mod-card{border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--bg-card);overflow:hidden;transition:box-shadow .15s}.mod-card:hover{box-shadow:var(--shadow-sm)}.mod-card-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);cursor:pointer;-webkit-user-select:none;user-select:none}.mod-card-header:hover{background:var(--bg-hover)}.mod-card-expand{font-size:20px;color:var(--text-secondary);transition:transform .2s}.mod-card-expand.open{transform:rotate(90deg)}.mod-card-title{flex:1;font-weight:600;font-size:calc(var(--font-size-base) * var(--font-zoom, 1))}.mod-card-hours{background:var(--color-primary-soft, rgba(59, 130, 246, .1));color:var(--color-primary);padding:2px 10px;border-radius:var(--radius-full);font-size:calc(var(--font-size-sm) * var(--font-zoom, 1));font-weight:600;white-space:nowrap}.mod-card-actions{display:flex;gap:4px}.mod-card-body{padding:var(--space-3) var(--space-4) var(--space-4);border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:var(--space-4)}.mod-desc{color:var(--text-secondary);font-size:calc(var(--font-size-sm) * var(--font-zoom, 1))}.mod-prereqs{display:flex;flex-direction:column;gap:var(--space-2)}.mod-prereqs-label{font-weight:600;font-size:calc(var(--font-size-sm) * var(--font-zoom, 1));color:var(--text-secondary)}.mod-prereqs-chips{display:flex;flex-wrap:wrap;gap:6px}.mod-prereq-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:calc(12px * var(--font-zoom, 1));background:var(--bg-muted);color:var(--text-primary);border:1px solid var(--border-color)}.mod-prereq-chip.obligatoire{background:#ef44441a;border-color:#ef44444d;color:var(--color-danger)}.mod-prereq-chip.recommande{background:#f59e0b1a;border-color:#f59e0b4d;color:var(--color-warning)}.mod-prereq-chip .remove{cursor:pointer;font-size:14px;opacity:.6}.mod-prereq-chip .remove:hover{opacity:1}.mod-add-prereq{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}.mod-add-prereq select{flex:1;min-width:200px}.mod-formateurs,.mod-kits{display:flex;flex-direction:column;gap:var(--space-2)}.mod-kits-label{font-weight:600;font-size:calc(var(--font-size-sm) * var(--font-zoom, 1));color:var(--text-secondary)}.mod-kits-chips{display:flex;flex-wrap:wrap;gap:6px}.mod-kit-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--radius-full);font-size:calc(12px * var(--font-zoom, 1));background:#3b82f61a;color:var(--color-primary);border:1px solid rgba(59,130,246,.3);font-weight:500}.mod-kit-chip .remove{cursor:pointer;font-size:14px;opacity:.6}.mod-kit-chip .remove:hover{opacity:1}.mod-add-kit{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}.mod-add-kit select{flex:1;min-width:200px}.mod-formateurs-label{font-weight:600;font-size:calc(var(--font-size-sm) * var(--font-zoom, 1));color:var(--text-secondary)}.mod-eligible-list{display:flex;flex-direction:column;gap:6px}.mod-eligible-row{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);background:var(--bg-muted)}.mod-eligible-name{flex:1;font-weight:500}.mod-eligible-diplomas{display:flex;flex-wrap:wrap;gap:4px}.mod-eligible-diploma{font-size:calc(11px * var(--font-zoom, 1));padding:1px 6px;border-radius:var(--radius-full);background:#10b9811a;color:var(--color-success)}.mod-eligible-ok{color:var(--color-success);font-size:16px}.mod-eligible-partial{color:var(--color-warning);font-size:16px}.mod-eligible-actions{display:flex;gap:4px}.mod-assigned-list{display:flex;flex-direction:column;gap:6px}.mod-assigned-row{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);border:1px solid var(--border-color)}.mod-assigned-name{flex:1;font-weight:500}.mod-status-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);font-size:calc(12px * var(--font-zoom, 1));font-weight:600}.mod-status-chip.propose{background:#f59e0b1f;color:#d97706}.mod-status-chip.accepte{background:#10b9811f;color:#059669}.mod-status-chip.refuse{background:#ef44441f;color:#dc2626}.mod-status-chip.force{background:#a855f71f;color:#7c3aed}.mod-form{display:flex;flex-direction:column;gap:var(--space-2)}.mod-form-row{display:flex;gap:var(--space-2)}.mod-form-row>*{flex:1}.mod-form-row .small{flex:0 0 120px}.mod-empty{text-align:center;padding:var(--space-6);color:var(--text-secondary);font-size:calc(var(--font-size-sm) * var(--font-zoom, 1))}.mod-empty .material-symbols-outlined{font-size:48px;opacity:.3;display:block;margin-bottom:var(--space-2)}.fm-stats-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--sp-3);margin-bottom:var(--sp-4)}.fm-toolbar{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:var(--sp-4)}.fm-toolbar-search{flex:1;min-width:180px;max-width:320px}.fm-toolbar-spacer{flex:1}.fm-tpl-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4);cursor:pointer;transition:box-shadow var(--transition),border-color var(--transition);display:flex;flex-direction:column;gap:var(--sp-2)}.fm-tpl-card:hover{box-shadow:var(--shadow);border-color:var(--color-primary)}.fm-tpl-card-border{border-left-width:4px;border-left-style:solid}.fm-tpl-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-2)}.fm-tpl-card-header h4{margin:0;font-size:.95rem;line-height:1.3}.fm-tpl-card-code{font-family:monospace;font-size:.7rem;color:var(--color-text-tertiary);white-space:nowrap}.fm-tpl-card-desc{font-size:.8rem;color:var(--color-text-secondary);overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.4}.fm-tpl-card-meta{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;margin-top:auto}.fm-tpl-card-actions{display:flex;align-items:center;gap:var(--sp-1);border-top:1px solid var(--color-border-subtle);padding-top:var(--sp-2);margin-top:var(--sp-2)}.fm-tpl-card-actions .btn-flat{padding:var(--sp-1)}.fm-counter-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--radius-full);font-size:.7rem;font-weight:600;background:var(--color-surface-hover);color:var(--color-text-secondary)}.fm-counter-chip-green{background:var(--color-success-subtle);color:var(--color-success)}.fm-counter-chip-blue{background:var(--color-info-subtle);color:var(--color-info)}.fm-promo-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4);cursor:pointer;transition:box-shadow var(--transition),border-color var(--transition);display:flex;flex-direction:column;gap:var(--sp-2)}.fm-promo-card:hover{box-shadow:var(--shadow);border-color:var(--color-primary)}.fm-promo-card-border{border-left-width:4px;border-left-style:solid}.fm-promo-card-template{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-tertiary)}.fm-promo-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-2)}.fm-promo-card-header h4{margin:0;font-size:.95rem;line-height:1.3}.fm-promo-card-dates{font-size:.8rem;color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--sp-1)}.fm-promo-card-counters{display:flex;align-items:center;gap:var(--sp-3);font-size:.8rem;color:var(--color-text-secondary)}.fm-promo-card-counters .material-symbols-outlined{font-size:16px}.fm-promo-card-actions{display:flex;align-items:center;gap:var(--sp-1);border-top:1px solid var(--color-border-subtle);padding-top:var(--sp-2);margin-top:auto}.fm-table-wrap{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-md)}.fm-table-wrap table{min-width:700px}.fm-table-row-clickable{cursor:pointer}.fm-list-wrap{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.fm-modal{width:560px}.fm-modal-wide{width:640px}.fm-json-list{display:flex;flex-direction:column;gap:var(--sp-2)}.fm-json-item{display:flex;align-items:center;gap:var(--sp-2)}.fm-json-item input{flex:1}.fm-json-item .btn-flat{flex-shrink:0}.fm-module-item{display:flex;align-items:center;gap:var(--sp-2)}.fm-module-item input:first-child{flex:2}.fm-module-item input:nth-child(2){flex:1;max-width:100px}.fm-volume-badge{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;color:var(--color-text-secondary)}.fm-volume-badge .material-symbols-outlined{font-size:14px}@keyframes fm-blink-expired{0%,to{border-color:var(--color-warning);box-shadow:0 0 #f59e0b00;background:color-mix(in srgb,var(--color-warning) 6%,transparent)}50%{border-color:var(--color-warning);box-shadow:0 0 8px 2px #f59e0b59;background:color-mix(in srgb,var(--color-warning) 18%,transparent)}}.fm-promo-expired{border-color:var(--color-warning)!important;animation:fm-blink-expired 2s ease-in-out infinite}.fm-promo-expired .fm-promo-card-border,.fm-promo-expired.fm-promo-card-border{border-left-color:var(--color-warning)!important}tr.fm-promo-expired{animation:fm-blink-expired 2s ease-in-out infinite}tr.fm-promo-expired td:first-child{border-left:3px solid var(--color-warning)}.list-row.fm-promo-expired{border-left:3px solid var(--color-warning);animation:fm-blink-expired 2s ease-in-out infinite}.gantt-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:auto;background:var(--color-bg);max-height:70vh;position:relative;cursor:grab}.gantt-wrapper:active{cursor:grabbing}.gantt-grid{display:grid;grid-template-columns:220px repeat(var(--gantt-cols),var(--gantt-col-w, 26px));min-width:max-content}.gantt-grid.zoom-week{--gantt-col-w: 14px}.gantt-grid.zoom-month{--gantt-col-w: 8px}.gantt-grid.zoom-day{--gantt-col-w: 28px}.gantt-header-label{position:sticky;left:0;top:0;z-index:4;background:var(--color-surface);padding:4px 8px;font-size:.72rem;font-weight:700;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);border-right:2px solid var(--color-border);display:flex;align-items:center}.gantt-month-cell{position:sticky;top:0;z-index:3;background:var(--color-surface);text-align:center;font-size:.68rem;font-weight:700;color:var(--color-text-secondary);padding:3px 0;border-bottom:1px solid var(--color-border);border-left:2px solid var(--color-border);text-transform:uppercase;letter-spacing:.04em}.gantt-day-cell{position:sticky;top:22px;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.6rem;padding:2px 0;border-bottom:2px solid var(--color-border);border-left:1px solid color-mix(in srgb,var(--color-border) 50%,transparent);background:var(--color-surface);color:var(--color-text-secondary);line-height:1.15;min-height:28px}.gantt-day-cell.gantt-month-start{border-left:2px solid var(--color-border)}.gantt-day-dow{font-weight:700;font-size:.56rem;text-transform:uppercase}.gantt-day-num{font-weight:600;font-size:.65rem}.gantt-weekend{background:color-mix(in srgb,var(--color-border) 30%,var(--color-bg))!important}.gantt-weekend .gantt-day-dow,.gantt-weekend .gantt-day-num{opacity:.4}.gantt-today{background:color-mix(in srgb,var(--color-primary) 15%,var(--color-bg))!important;position:relative}.gantt-day-cell.gantt-today{border-bottom-color:var(--color-primary);border-bottom-width:3px}.gantt-day-cell.gantt-today .gantt-day-num{color:var(--color-primary);font-weight:800}.gantt-mod-label{position:sticky;left:0;z-index:2;background:var(--color-bg);padding:4px 8px;border-bottom:1px solid var(--color-border);border-right:2px solid var(--color-border);font-size:.78rem;min-height:36px;display:flex;flex-direction:column;justify-content:center}.gantt-mod-color{display:inline-block;width:10px;height:10px;border-radius:2px;flex-shrink:0}.gantt-mod-name{font-weight:700;font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.gantt-mod-meta{font-size:.65rem;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-avatar{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;color:#fff;font-size:.52rem;font-weight:700}.gantt-cell{min-height:36px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;border-left:1px solid color-mix(in srgb,var(--color-border) 40%,transparent);cursor:pointer;transition:background .12s,box-shadow .12s}.gantt-cell.gantt-month-start{border-left:2px solid var(--color-border)}.gantt-cell:hover:not(.gantt-cell-active){background:color-mix(in srgb,var(--color-primary) 15%,var(--color-bg));box-shadow:inset 0 0 0 2px color-mix(in srgb,var(--color-primary) 30%,transparent)}.gantt-cell:active:not(.gantt-cell-active){background:color-mix(in srgb,var(--color-primary) 25%,var(--color-bg))}.gantt-cell-active{background:var(--mod-color, var(--color-primary));opacity:.88;border-left-color:color-mix(in srgb,var(--mod-color, var(--color-primary)) 70%,#000)!important}.gantt-cell-active.gantt-weekend{opacity:.55}.gantt-cell-active.gantt-today{opacity:1;box-shadow:inset 0 0 0 2px #fff}.gantt-cell-first{border-top-left-radius:4px;border-bottom-left-radius:4px}.gantt-cell-last{border-top-right-radius:4px;border-bottom-right-radius:4px}.gantt-cell.gantt-today:not(.gantt-cell-active){background:color-mix(in srgb,var(--color-primary) 10%,var(--color-bg));border-bottom:2px solid var(--color-primary)}.gantt-cell-marked{box-shadow:inset 0 -2px #ffffff80}.gantt-cell-marked.gantt-cell-first{box-shadow:inset 2px -2px #ffffff80}.gantt-cell-marked.gantt-cell-last{box-shadow:inset -2px -2px #ffffff80}.gantt-mod-excluded{opacity:.45}.gantt-cell-disabled{min-height:36px;border-bottom:1px solid var(--color-border);border-left:1px solid color-mix(in srgb,var(--color-border) 40%,transparent);background:repeating-linear-gradient(-45deg,transparent,transparent 3px,color-mix(in srgb,var(--color-border) 20%,transparent) 3px,color-mix(in srgb,var(--color-border) 20%,transparent) 5px);cursor:default}.gantt-cell-disabled.gantt-month-start{border-left:2px solid var(--color-border)}.fm-trombi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--sp-3)}.fm-trombi-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--sp-1);padding:var(--sp-3) var(--sp-2);border-radius:var(--radius-md);background:var(--color-surface-hover);transition:box-shadow var(--transition)}.fm-trombi-card:hover{box-shadow:var(--shadow)}.fm-trombi-avatar{width:72px;height:72px;border-radius:50%;overflow:hidden;background:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.fm-trombi-avatar img{width:100%;height:100%;object-fit:cover}.fm-trombi-initials{font-size:1.4rem;font-weight:700;color:#fff;text-transform:uppercase;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.fm-trombi-name{font-size:.82rem;font-weight:600;color:var(--color-text);line-height:1.2;word-break:break-word}.fm-trombi-email{font-size:.7rem;color:var(--color-text-tertiary);word-break:break-all}.niv-panel{display:flex;flex-direction:column;gap:var(--sp-4, 1rem)}.niv-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--sp-4, 1rem);padding:1rem 1.1rem;border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-lg, 14px);background:linear-gradient(135deg,color-mix(in srgb,var(--color-primary) 10%,transparent),transparent 55%),var(--color-surface, #fff)}.niv-hero-kicker{margin:0;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary)}.niv-hero-text{margin:.3rem 0 0;max-width:52rem;color:var(--color-text-secondary)}.niv-hero-stats{display:flex;gap:.75rem}.niv-stat-card{min-width:96px;padding:.75rem .9rem;border-radius:12px;background:color-mix(in srgb,var(--color-surface-hover, rgba(128,128,128,.08)) 80%,transparent);border:1px solid var(--color-border, rgba(128,128,128,.14))}.niv-stat-value{display:block;font-size:1.25rem;font-weight:700}.niv-stat-label{display:block;font-size:.74rem;color:var(--color-text-secondary)}.niv-error{color:var(--color-danger);font-size:.82rem;padding:.4rem .6rem;background:color-mix(in srgb,var(--color-danger) 8%,transparent);border-radius:var(--radius, 6px)}.niv-split{display:grid;grid-template-columns:minmax(280px,320px) minmax(0,1fr);gap:var(--sp-4, 1rem);min-height:560px}.niv-left{display:flex;flex-direction:column;gap:var(--sp-2, .5rem);padding:1rem;border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-lg, 14px);background:var(--color-surface, #fff)}.niv-section-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--sp-2, .5rem);border-bottom:2px solid var(--color-border, rgba(128, 128, 128, .15))}.niv-section-title{font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:.4rem}.niv-section-actions{display:flex;gap:.5rem;flex-wrap:wrap}.niv-section-title .material-symbols-outlined{font-size:1.1rem;opacity:.7}.niv-add-btn{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;padding:.3rem .65rem;border:none;border-radius:var(--radius, 6px);background:var(--color-primary);color:#fff;cursor:pointer;font-weight:600;transition:background .15s ease}.niv-add-btn:hover{background:var(--color-primary-hover, #1565c0)}.niv-add-btn .material-symbols-outlined{font-size:.9rem}.niv-family-list{display:flex;flex-direction:column;gap:.6rem}.niv-famille{display:flex;flex-direction:column;align-items:stretch;gap:.7rem;padding:.65rem .85rem;background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-left:4px solid var(--color-primary);border-radius:var(--radius-md, 10px);cursor:pointer;transition:all .15s ease;text-align:left}.niv-famille:hover{box-shadow:0 2px 8px #0000000f;border-color:var(--color-primary-subtle, rgba(25, 118, 210, .25))}.niv-famille.active{background:var(--color-surface-hover, rgba(128, 128, 128, .06));border-color:var(--color-primary);box-shadow:0 2px 8px #1976d21f}.niv-famille-head{display:flex;gap:.75rem;align-items:flex-start}.niv-famille-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-top:.25rem}.niv-famille-info{flex:1;min-width:0}.niv-famille-title-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.niv-famille-nom{font-weight:600;font-size:.88rem}.niv-famille-code{font-size:.72rem;color:var(--color-text-secondary);font-family:monospace;margin-top:.12rem}.niv-famille-desc{font-size:.72rem;color:var(--color-text-secondary);margin-top:.3rem;line-height:1.35}.niv-famille-actions{display:flex;gap:.2rem;justify-content:flex-end}.niv-icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:none;border-radius:var(--radius, 6px);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .12s ease}.niv-icon-btn:hover{background:var(--color-surface-hover, rgba(128, 128, 128, .1));color:var(--color-text)}.niv-icon-btn.danger:hover{background:color-mix(in srgb,var(--color-danger) 10%,transparent);color:var(--color-danger)}.niv-icon-btn .material-symbols-outlined{font-size:1rem}.niv-empty-hint{color:var(--color-text-secondary);font-size:.82rem;text-align:center;padding:1.5rem .5rem;font-style:italic}.niv-right{display:flex;flex-direction:column;gap:var(--sp-3, .75rem);padding:1rem;border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-lg, 14px);background:var(--color-surface, #fff)}.niv-right-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.9fr);gap:1rem;min-height:0}.niv-level-list-panel,.niv-inspector{display:flex;flex-direction:column;gap:.75rem}.niv-level-list{display:flex;flex-direction:column;gap:.65rem}.niv-family-context{display:flex;flex-direction:column;gap:.2rem}.niv-family-context-head{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}.niv-family-context-code{font-family:monospace;font-size:.74rem;color:var(--color-text-secondary);background:color-mix(in srgb,var(--color-border, rgba(128,128,128,.1)) 90%,transparent);padding:.16rem .45rem;border-radius:999px}.niv-family-context-meta{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.78rem;color:var(--color-text-secondary)}.niv-right-desc{font-size:.78rem;color:var(--color-text-secondary)}.niv-subheader{display:flex;justify-content:space-between;gap:.6rem;align-items:baseline}.niv-subtitle{font-size:.84rem;font-weight:700}.niv-subhint{font-size:.75rem;color:var(--color-text-secondary)}.niv-niveau{display:flex;align-items:center;gap:var(--sp-3, .75rem);padding:.7rem .9rem;background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-left:4px solid var(--color-primary);border-radius:var(--radius-md, 10px);cursor:pointer;transition:all .15s ease;text-align:left}.niv-niveau:hover{box-shadow:0 2px 8px #0000000f;border-color:var(--color-primary-subtle, rgba(25, 118, 210, .25))}.niv-niveau.active{border-color:var(--color-primary);box-shadow:0 4px 14px #1976d224;background:color-mix(in srgb,var(--color-primary) 5%,var(--color-surface, #fff))}.niv-badge-ordre{width:38px;height:38px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;flex-shrink:0}.niv-niveau-info{flex:1;min-width:0}.niv-niveau-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.niv-niveau-nom{font-weight:600;font-size:.9rem}.niv-niveau-code{font-size:.72rem;color:var(--color-text-secondary);font-family:monospace;background:var(--color-border, rgba(128, 128, 128, .1));padding:.1rem .4rem;border-radius:3px}.niv-niveau-meta-row{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.35rem}.niv-niveau-desc{font-size:.8rem;color:var(--color-text-secondary);margin-top:.2rem}.niv-level-actions{display:flex;gap:.2rem}.niv-inspector-card{padding:.95rem 1rem;border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:12px;background:color-mix(in srgb,var(--color-surface-hover, rgba(128,128,128,.06)) 70%,transparent)}.niv-inspector-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.niv-inspector-head h3{margin:.2rem 0 0;font-size:1rem}.niv-inspector-kicker{margin:0;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-primary)}.niv-inspector-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem;margin-top:.9rem}.niv-summary-item{display:flex;flex-direction:column;gap:.2rem;padding:.65rem .75rem;border-radius:10px;background:var(--color-surface, #fff)}.niv-summary-label,.niv-dependency-label{font-size:.72rem;color:var(--color-text-secondary)}.niv-inspector-description{margin:.9rem 0 0;color:var(--color-text-secondary);line-height:1.45}.niv-dependency-list{display:flex;flex-direction:column;gap:.55rem}.niv-dependency-item{padding:.75rem .85rem;border:1px solid var(--color-border, rgba(128,128,128,.15));border-radius:10px;background:var(--color-surface, #fff);display:flex;flex-direction:column;gap:.2rem}.niv-dependency-item.active{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 6%,var(--color-surface, #fff))}.niv-inspector-actions{display:flex;gap:.5rem;flex-wrap:wrap}.niv-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;color:var(--color-text-secondary);gap:.5rem;padding:2rem 1rem}.niv-placeholder-panel{min-height:100%;border:1px dashed var(--color-border, rgba(128,128,128,.18));border-radius:12px;background:color-mix(in srgb,var(--color-surface-hover, rgba(128,128,128,.05)) 80%,transparent)}.niv-placeholder-icon{font-size:2.5rem;opacity:.3}.niv-placeholder-icon .material-symbols-outlined{font-size:inherit}.niv-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:niv-fade-in .15s ease}@keyframes niv-fade-in{0%{opacity:0}to{opacity:1}}.niv-modal{background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-lg, 12px);width:min(480px,95vw);max-height:80vh;overflow:auto;padding:var(--sp-5, 1.5rem);box-shadow:0 8px 32px #0000001f;animation:niv-slide-up .2s ease}@keyframes niv-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.niv-modal h3{margin:0 0 var(--sp-4, 1rem);font-size:1.1rem;font-weight:700}.niv-modal-confirm{width:min(420px,95vw);text-align:center}.niv-modal-confirm p{margin:0 0 .5rem}.niv-modal-warning{font-size:.82rem;color:var(--color-warning);margin-bottom:1rem}.niv-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3, .75rem)}.niv-form-full{grid-column:1 / -1}.niv-form-label{display:block;font-size:.75rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.25rem}.niv-form-actions{display:flex;gap:.5rem;justify-content:center;margin-top:var(--sp-4, 1rem)}.niv-modal .niv-form-actions{justify-content:flex-end}@media (max-width: 768px){.niv-hero,.niv-split{grid-template-columns:1fr}.niv-hero{flex-direction:column}.niv-hero-stats,.niv-right-grid,.niv-inspector-summary{grid-template-columns:1fr;display:grid}.niv-form-grid{grid-template-columns:1fr}}.niv-stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.niv-stat-card-modern{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid;border-radius:10px;transition:transform .15s,box-shadow .15s}.niv-stat-card-modern:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.niv-stat-icon-modern{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.niv-stat-icon-modern .material-symbols-outlined{color:#fff;font-size:20px}.niv-stat-value-modern{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.1}.niv-stat-label-modern{font-size:.72rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.niv-toolbar-modern{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;margin-bottom:14px;flex-wrap:wrap}.niv-search{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;min-width:200px;max-width:280px}.niv-search .material-symbols-outlined{color:var(--color-text-secondary);font-size:18px}.niv-search input{flex:1;border:none;background:transparent;color:var(--color-text);font-size:.82rem;outline:none;min-width:0}.niv-search button{border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;padding:0;display:flex}.niv-cat-chips{display:flex;gap:4px;flex-wrap:wrap}.niv-cat-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border:1px solid var(--color-border);border-radius:14px;background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.72rem;font-weight:600;transition:all .15s}.niv-cat-chip:hover{border-color:var(--color-primary)}.niv-cat-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.niv-chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.niv-view-toggle{display:flex;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.niv-view-btn{display:flex;align-items:center;justify-content:center;padding:6px 10px;border:none;background:var(--color-bg);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.niv-view-btn:hover{color:var(--color-text)}.niv-view-btn.active{background:var(--color-primary);color:#fff}.niv-list-rows{display:flex;flex-direction:column;gap:6px}.niv-list-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;transition:all .15s}.niv-list-row:hover{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 4%,var(--color-surface))}.niv-list-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem}.niv-list-main{flex:1;min-width:0}.niv-list-title{font-size:.88rem;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.niv-list-desc{font-size:.72rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.niv-list-meta-item{display:inline-flex;align-items:center;gap:3px;font-size:.72rem;color:var(--color-text-secondary);white-space:nowrap}.niv-list-meta-item .material-symbols-outlined{font-size:13px}.niv-list-actions{display:flex;gap:4px;flex-shrink:0}.niv-badge{display:inline-block;padding:3px 9px;border-radius:12px;color:#fff;font-size:.7rem;font-weight:600;text-transform:capitalize;white-space:nowrap}.niv-empty-modern{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:50px 20px;text-align:center;color:var(--color-text-secondary);font-size:.9rem}.niv-empty-modern .material-symbols-outlined{font-size:48px;opacity:.4}.ref-panel{display:flex;flex-direction:column;gap:var(--sp-4, 1rem);min-width:0}.ref-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--sp-4, 1rem);flex-wrap:wrap;padding:1rem 1.1rem;border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-lg, 14px);background:linear-gradient(135deg,color-mix(in srgb,var(--color-primary) 9%,transparent),transparent 52%),var(--color-surface, #fff)}.ref-hero-copy{max-width:54rem}.ref-hero-kicker{margin:0;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary)}.ref-hero-text{margin:.3rem 0 0;color:var(--color-text-secondary);line-height:1.45}.ref-hero-context{display:flex;gap:.75rem;flex-wrap:wrap}.ref-context-card{min-width:180px;padding:.75rem .9rem;border-radius:12px;border:1px solid var(--color-border, rgba(128, 128, 128, .15));background:color-mix(in srgb,var(--color-surface-hover, rgba(128,128,128,.08)) 80%,transparent)}.ref-context-label{display:block;font-size:.72rem;color:var(--color-text-secondary);margin-bottom:.22rem}.ref-toolbar{display:flex;align-items:center;gap:var(--sp-2, .5rem);flex-wrap:wrap;padding:1rem;border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-lg, 14px);background:var(--color-surface, #fff)}.ref-toolbar-group{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.ref-toolbar label{font-size:.85rem;font-weight:600;color:var(--color-text);white-space:nowrap}.ref-toolbar select{min-width:280px;font-size:.875rem;font-weight:500;padding:.45rem 2rem .45rem .75rem}.ref-toolbar select option{padding:.4rem .75rem;font-size:.875rem}.ref-toolbar-spacer{flex:1}.ref-selection-strip{display:flex;gap:.5rem;flex-wrap:wrap}.ref-selection-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .7rem;border-radius:999px;border:1px solid var(--color-border, rgba(128, 128, 128, .15));background:var(--color-surface, #fff);font-size:.78rem;font-weight:600}.ref-selection-chip.muted{color:var(--color-text-secondary)}.ref-selection-chip.accent{color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 7%,transparent)}.ref-selection-chip .material-symbols-outlined{font-size:1rem}.ref-view-toggle{display:inline-flex;gap:1px;background:var(--color-border, rgba(128, 128, 128, .2));border-radius:6px;overflow:hidden}.ref-view-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:var(--color-surface, #fff);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease;font-size:.9rem}.ref-view-btn:hover{background:var(--color-surface-hover, rgba(128, 128, 128, .08));color:var(--color-text)}.ref-view-btn.active{background:var(--color-primary);color:#fff}.ref-tabs{display:flex;gap:2px;border-bottom:2px solid var(--color-border, rgba(128, 128, 128, .2))}.ref-tab{position:relative;display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:none;background:transparent;color:var(--color-text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;border-radius:var(--radius, 6px) var(--radius, 6px) 0 0;transition:all .2s ease}.ref-tab:hover{background:var(--color-surface-hover, rgba(128, 128, 128, .06));color:var(--color-text)}.ref-tab.active{color:var(--color-primary);font-weight:600}.ref-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--color-primary);border-radius:2px 2px 0 0}.ref-tab-icon{font-size:1rem;line-height:1}.ref-tab-icon .material-symbols-outlined,.ref-stat-icon .material-symbols-outlined,.ref-card-row-icon .material-symbols-outlined,.ref-empty-icon .material-symbols-outlined,.ref-bilan-icon .material-symbols-outlined,.ref-placeholder-icon .material-symbols-outlined,.ref-view-btn .material-symbols-outlined{font-size:inherit}.ref-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;font-size:.65rem;font-weight:700;background:var(--color-border, rgba(128, 128, 128, .15));color:var(--color-text-secondary)}.ref-tab.active .ref-tab-badge{background:var(--color-primary-subtle, rgba(25, 118, 210, .12));color:var(--color-primary)}.ref-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:var(--sp-3, .75rem)}.ref-stat-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-4, 1rem) var(--sp-3, .75rem);background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-md, 10px);text-align:center;transition:box-shadow .2s ease,border-color .2s ease}.ref-stat-card:hover{box-shadow:0 2px 8px #0000000f}.ref-stat-icon{font-size:1.5rem;margin-bottom:.25rem;opacity:.8}.ref-stat-value{font-size:1.75rem;font-weight:700;line-height:1.2}.ref-stat-label{font-size:.75rem;color:var(--color-text-secondary);margin-top:.15rem}.ref-content{min-height:200px;min-width:0}.ref-action-bar{display:flex;justify-content:flex-end;margin-bottom:var(--sp-3, .75rem)}.ref-table-wrap{overflow-x:auto;border-radius:var(--radius-md, 10px);border:1px solid var(--color-border, rgba(128, 128, 128, .15))}.ref-table{width:100%;border-collapse:collapse;font-size:.85rem}.ref-table th{padding:.6rem .75rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);background:var(--color-surface, rgba(128, 128, 128, .04));white-space:nowrap;border-bottom:2px solid var(--color-border, rgba(128, 128, 128, .15));-webkit-user-select:none;user-select:none;text-transform:uppercase;letter-spacing:.03em}.ref-table td{padding:.6rem .75rem;vertical-align:middle;border-bottom:1px solid var(--color-border, rgba(128, 128, 128, .08))}.ref-table tbody tr{transition:background .12s ease}.ref-table tbody tr:hover td{background:var(--color-surface-hover, rgba(128, 128, 128, .03))}.ref-table tbody tr:last-child td{border-bottom:none}.ref-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--sp-3, .75rem)}.ref-card{position:relative;background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-md, 10px);padding:var(--sp-4, 1rem);display:flex;flex-direction:column;gap:.6rem;transition:box-shadow .2s ease,border-color .2s ease}.ref-card:hover{box-shadow:0 4px 12px #00000014;border-color:var(--color-primary-subtle, rgba(25, 118, 210, .25))}.ref-card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.ref-card-type{display:inline-flex;align-items:center;gap:.35rem;font-size:.75rem;font-weight:600;padding:.2rem .6rem;border-radius:999px;background:var(--color-primary-subtle, rgba(25, 118, 210, .1));color:var(--color-primary);text-transform:capitalize}.ref-card-type.success{background:color-mix(in srgb,var(--color-success) 12%,transparent);color:var(--color-success)}.ref-card-type.warning{background:color-mix(in srgb,var(--color-warning) 12%,transparent);color:var(--color-warning)}.ref-card-type.danger{background:color-mix(in srgb,var(--color-danger) 12%,transparent);color:var(--color-danger)}.ref-card-type.info{background:color-mix(in srgb,var(--color-info, #06b6d4) 12%,transparent);color:var(--color-info, #06b6d4)}.ref-card-title{font-weight:600;font-size:.95rem}.ref-card-row{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--color-text-secondary)}.ref-card-row-icon{font-size:.9rem;width:1.2rem;text-align:center;flex-shrink:0}.ref-card-row strong{color:var(--color-text)}.ref-card-footer{display:flex;align-items:center;justify-content:flex-end;gap:.4rem;margin-top:auto;padding-top:.5rem;border-top:1px solid var(--color-border, rgba(128, 128, 128, .1))}.ref-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:999px;white-space:nowrap}.ref-badge .material-symbols-outlined{font-size:14px}.ref-badge.success{background:color-mix(in srgb,var(--color-success) 15%,transparent);color:var(--color-success)}.ref-badge.danger{background:color-mix(in srgb,var(--color-danger) 15%,transparent);color:var(--color-danger)}.ref-badge.warning{background:color-mix(in srgb,var(--color-warning) 15%,transparent);color:var(--color-warning)}.ref-badge.info{background:color-mix(in srgb,var(--color-info, #06b6d4) 15%,transparent);color:var(--color-info, #06b6d4)}.ref-badge.neutral{background:var(--color-border, rgba(128, 128, 128, .12));color:var(--color-text-secondary)}.ref-validated{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;font-size:.85rem;font-weight:700}.ref-validated .material-symbols-outlined{font-size:16px}.ref-validated.yes{background:color-mix(in srgb,var(--color-success) 15%,transparent);color:var(--color-success)}.ref-validated.no{background:color-mix(in srgb,var(--color-danger) 15%,transparent);color:var(--color-danger)}.ref-note{display:inline-flex;align-items:baseline;gap:1px;font-weight:700}.ref-note-value{font-size:1.1rem}.ref-note-max{font-size:.75rem;color:var(--color-text-secondary);font-weight:400}.ref-note-bar{height:4px;border-radius:2px;background:var(--color-border, rgba(128, 128, 128, .15));overflow:hidden;margin-top:.3rem}.ref-note-bar-fill{height:100%;border-radius:2px;transition:width .4s ease}.ref-charts{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--sp-3, .75rem);margin-top:var(--sp-3, .75rem)}.ref-chart-card{background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-md, 10px);padding:var(--sp-4, 1rem)}.ref-chart-title{font-size:.8rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:var(--sp-3, .75rem)}.ref-chart-body{position:relative;width:100%;max-height:220px}.ref-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center}.ref-empty-icon{font-size:2.5rem;opacity:.3;margin-bottom:.5rem}.ref-empty-text{font-size:.9rem;color:var(--color-text-secondary)}.ref-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:ref-fade-in .15s ease}@keyframes ref-fade-in{0%{opacity:0}to{opacity:1}}.ref-modal{background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-lg, 12px);width:min(520px,95vw);max-height:80vh;overflow:auto;padding:var(--sp-5, 1.5rem);box-shadow:0 8px 32px #0000001f;animation:ref-slide-up .2s ease}@keyframes ref-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ref-modal h3{margin:0 0 var(--sp-4, 1rem);font-size:1.1rem;font-weight:700}.ref-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3, .75rem)}.ref-form-full{grid-column:1 / -1}.ref-form-label{display:block;font-size:.75rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.25rem}.ref-form-row-inline{display:flex;gap:1rem;align-items:center;grid-column:1 / -1}.ref-form-check{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.85rem}.ref-form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:var(--sp-4, 1rem)}.ref-error{color:var(--color-danger);font-size:.82rem;margin-bottom:var(--sp-2, .5rem);padding:.4rem .6rem;background:color-mix(in srgb,var(--color-danger) 8%,transparent);border-radius:var(--radius, 6px)}.ref-bilan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--sp-3, .75rem)}.ref-bilan-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-5, 1.5rem) var(--sp-4, 1rem);background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-md, 10px);text-align:center;transition:box-shadow .2s ease,border-color .2s ease,transform .2s ease}.ref-bilan-card:hover{box-shadow:0 4px 16px #00000014;transform:translateY(-2px)}.ref-bilan-icon{font-size:1.5rem;margin-bottom:.5rem;opacity:.75}.ref-bilan-value{font-size:2rem;font-weight:700;line-height:1.2}.ref-bilan-label{font-size:.8rem;color:var(--color-text-secondary);margin-top:.25rem}.ref-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:3rem 1rem;color:var(--color-text-secondary);font-size:.9rem}.ref-placeholder-icon{font-size:2rem;opacity:.4}.ref-toolbar-sep{display:flex;align-items:center;color:var(--color-text-secondary);opacity:.5;font-size:1.1rem}.ref-toolbar-sep .material-symbols-outlined{font-size:1.1rem}.ref-toolbar-hint{font-size:.78rem;color:var(--color-text-secondary);font-style:italic}@media (max-width: 768px){.ref-hero{flex-direction:column}.ref-stats{grid-template-columns:repeat(2,1fr)}.ref-grid,.ref-charts,.ref-form-grid{grid-template-columns:1fr}.ref-hero-context,.ref-toolbar-group,.ref-toolbar{flex-direction:column;align-items:stretch}.ref-toolbar select{min-width:unset;width:100%}.ref-toolbar-sep{display:none}.ref-bilan-grid{grid-template-columns:repeat(2,1fr)}}.ref-stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.ref-stat-card-modern{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid;border-radius:10px;transition:transform .15s,box-shadow .15s}.ref-stat-card-modern:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.ref-stat-icon-modern{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ref-stat-icon-modern .material-symbols-outlined{color:#fff;font-size:20px}.ref-stat-value-modern{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.1}.ref-stat-label-modern{font-size:.72rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.comp-panel{display:flex;flex-direction:column;gap:1rem;min-width:0}.comp-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1rem 1.1rem;border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:14px;background:linear-gradient(135deg,color-mix(in srgb,var(--color-primary) 10%,transparent),transparent 52%),var(--color-surface, #fff)}.comp-hero-copy{max-width:54rem}.comp-hero-kicker{margin:0;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-primary)}.comp-hero-text{margin:.3rem 0 0;color:var(--color-text-secondary);line-height:1.45}.comp-hero-stats{display:flex;gap:.75rem}.comp-stat-card{min-width:110px;padding:.75rem .9rem;border-radius:12px;border:1px solid var(--color-border, rgba(128, 128, 128, .15));background:color-mix(in srgb,var(--color-surface-hover, rgba(128,128,128,.08)) 80%,transparent)}.comp-stat-value{display:block;font-size:1.25rem;font-weight:700}.comp-stat-label{display:block;margin-top:.15rem;font-size:.74rem;color:var(--color-text-secondary)}.comp-toolbar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:1rem;border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:14px;background:var(--color-surface, #fff)}.comp-toolbar-group{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.comp-toolbar label{font-size:.85rem;font-weight:600;color:var(--color-text)}.comp-toolbar select{min-width:220px;font-size:.875rem;font-weight:500;padding:.45rem 2rem .45rem .75rem}.comp-toolbar-spacer{flex:1}.comp-demo-banner{display:flex;align-items:flex-start;gap:.75rem;padding:.9rem 1rem;border-radius:12px;border:1px solid color-mix(in srgb,var(--color-warning) 35%,transparent);background:color-mix(in srgb,var(--color-warning) 12%,transparent);color:var(--color-text)}.comp-demo-banner .material-symbols-outlined{font-size:1.2rem;color:var(--color-warning)}.comp-error{color:var(--color-danger);font-size:.82rem;padding:.4rem .6rem;background:color-mix(in srgb,var(--color-danger) 8%,transparent);border-radius:6px}.comp-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,.9fr);gap:1rem;align-items:start}.comp-radar-card,.comp-eval-card{padding:1rem;border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:14px;background:var(--color-surface, #fff)}.comp-radar-card,.comp-eval-col{display:flex;flex-direction:column;gap:1rem}.comp-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;flex-wrap:wrap}.comp-radar-title,.comp-eval-title{margin:0;font-size:1rem;font-weight:700}.comp-card-subtitle{margin:.25rem 0 0;color:var(--color-text-secondary);font-size:.84rem;line-height:1.45}.comp-highlight-pill{display:inline-flex;align-items:center;padding:.3rem .65rem;border-radius:999px;border:1px solid var(--color-primary);background:color-mix(in srgb,var(--color-primary) 8%,transparent);font-size:.76rem;font-weight:600;color:var(--color-text)}.comp-radar-svg{display:block;margin:0 auto}.comp-domain-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.comp-domain-card{padding:.8rem .85rem;border-radius:12px;border:1px solid var(--color-border, rgba(128, 128, 128, .15));background:color-mix(in srgb,var(--color-surface-hover, rgba(128,128,128,.06)) 85%,transparent)}.comp-domain-head{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;margin-bottom:.65rem}.comp-domain-score{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;padding:.18rem .5rem;border-radius:999px;background:var(--color-surface, #fff);color:var(--color-text);font-size:.72rem;font-weight:700}.comp-domain-score.large{font-size:.82rem;padding:.22rem .55rem}.comp-score-dot,.comp-domaine-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.comp-score-track{width:100%;height:8px;border-radius:999px;background:var(--color-border, rgba(128, 128, 128, .15));overflow:hidden}.comp-score-track.accent{background:color-mix(in srgb,var(--color-border, rgba(128,128,128,.18)) 80%,transparent)}.comp-score-fill{height:100%;border-radius:999px;transition:width .3s ease}.comp-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.comp-summary-item{display:flex;flex-direction:column;gap:.2rem;padding:.75rem .8rem;border-radius:12px;background:color-mix(in srgb,var(--color-surface-hover, rgba(128,128,128,.06)) 88%,transparent);border:1px solid var(--color-border, rgba(128, 128, 128, .15))}.comp-summary-label{font-size:.72rem;color:var(--color-text-secondary)}.comp-history-list{display:flex;flex-direction:column;gap:.75rem}.comp-history-item{padding:.9rem;border-radius:12px;border:1px solid var(--color-border, rgba(128, 128, 128, .15));background:linear-gradient(180deg,color-mix(in srgb,var(--color-surface-hover, rgba(128,128,128,.06)) 80%,transparent),var(--color-surface, #fff))}.comp-history-top{display:flex;justify-content:space-between;align-items:center;gap:.75rem;flex-wrap:wrap}.comp-domaine-cell{display:flex;align-items:center;gap:.45rem}.comp-history-meta{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-top:.6rem;font-size:.76rem;color:var(--color-text-secondary)}.comp-source-badge{display:inline-flex;align-items:center;font-size:.68rem;font-weight:700;padding:.18rem .55rem;border-radius:999px;white-space:nowrap;color:#fff}.comp-source-badge.auto{background:var(--color-info, #06b6d4)}.comp-source-badge.manual{background:var(--color-primary)}.comp-source-badge.quality{background:var(--color-warning)}.comp-comment{margin:.7rem 0 0;color:var(--color-text);line-height:1.45;font-size:.84rem}.comp-learner-list{display:flex;flex-direction:column;gap:.65rem}.comp-learner-card{display:flex;justify-content:space-between;align-items:center;gap:.75rem;width:100%;padding:.85rem .9rem;border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:12px;background:color-mix(in srgb,var(--color-surface-hover, rgba(128,128,128,.06)) 85%,transparent);text-align:left;cursor:pointer;color:var(--color-text)}.comp-learner-card:hover{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 5%,var(--color-surface, #fff))}.comp-learner-card strong{display:block}.comp-learner-card span:last-child,.comp-learner-card .material-symbols-outlined{color:var(--color-text-secondary)}.comp-learner-card div span{display:block;margin-top:.2rem;font-size:.76rem;color:var(--color-text-secondary)}.comp-nodata{color:var(--color-text-secondary);font-size:.88rem;padding:.5rem 0}.comp-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.comp-modal{background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:12px;width:min(500px,95vw);max-height:80vh;overflow:auto;padding:1.5rem;box-shadow:0 8px 32px #0000001f}.comp-modal h3{margin:0 0 1rem;font-size:1.1rem;font-weight:700}.comp-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.comp-form-full{grid-column:1 / -1}.comp-form-label{display:block;font-size:.75rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.25rem}.comp-score-display{text-align:center;font-weight:700;font-size:1.2rem;color:var(--color-primary);margin-top:.25rem}.comp-form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}@media (max-width: 900px){.comp-grid{grid-template-columns:1fr}}@media (max-width: 768px){.comp-hero,.comp-toolbar,.comp-toolbar-group{flex-direction:column;align-items:stretch}.comp-hero-stats,.comp-summary-grid,.comp-domain-grid,.comp-form-grid{grid-template-columns:1fr}.comp-toolbar select{min-width:0;width:100%}}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.mk-root{display:flex;flex-direction:column;gap:1rem;position:relative}.mk-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}.mk-title{margin:0;font-size:1.25rem;font-weight:700}.mk-loading,.mk-empty{text-align:center;padding:2rem;color:var(--color-text-secondary, #94a3b8);font-size:.9rem}.mk-tabs{display:flex;gap:.25rem;background:var(--color-bg-elevated, rgba(255, 255, 255, .04));border-radius:.5rem;padding:.2rem}.mk-tab{padding:.4rem .9rem;font-size:.8rem;font-weight:500;color:var(--color-text-secondary, #94a3b8);background:none;border:none;border-radius:.375rem;cursor:pointer;transition:color .15s,background .15s;white-space:nowrap}.mk-tab:hover:not(:disabled){color:var(--color-text, #e2e8f0);background:var(--color-bg-elevated, rgba(255, 255, 255, .06))}.mk-tab--active{color:#fff;background:var(--color-primary, #3b82f6)}.mk-tab:disabled{opacity:.4;cursor:not-allowed}.mk-toolbar{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;justify-content:flex-end}.mk-select{padding:.35rem .6rem;font-size:.8rem;background:var(--color-bg-elevated, rgba(255, 255, 255, .05));color:var(--color-text, #e2e8f0);border:1px solid var(--color-border, rgba(255, 255, 255, .1));border-radius:.375rem}.mk-section-title{font-size:.85rem;font-weight:600;color:var(--color-text-secondary, #94a3b8);margin-right:auto}.mk-badge{display:inline-block;font-size:.6rem;font-weight:700;padding:.1rem .4rem;border-radius:.25rem;color:#fff;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px}.mk-badge--info{background:#6366f1}.mk-badge--correct{background:#10b981}.mk-badge--dim{background:var(--color-bg-elevated, rgba(255, 255, 255, .08));color:var(--color-text-secondary, #94a3b8)}.mk-badge--lg{font-size:.75rem;padding:.2rem .6rem}.mk-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;font-size:.8rem;background:var(--color-bg-elevated, rgba(255, 255, 255, .05));color:var(--color-text, #e2e8f0);border:1px solid var(--color-border, rgba(255, 255, 255, .1));border-radius:.25rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s;line-height:1}.mk-icon-btn .material-symbols-outlined{font-size:1rem}.mk-icon-btn:hover{background:var(--color-bg-elevated, rgba(255, 255, 255, .1));border-color:var(--color-text-secondary, #94a3b8)}.mk-icon-btn--danger:hover{background:#dc262626;border-color:#dc2626;color:#dc2626}.mk-icon-btn--primary:hover{background:#3b82f626;border-color:#3b82f6;color:#3b82f6}.mk-icon-btn--success:hover{background:#10b98126;border-color:#10b981;color:#10b981}.mk-quizzes{display:flex;flex-direction:column;gap:1rem}.mk-quiz-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.mk-quiz-card{background:var(--color-bg-elevated, rgba(255, 255, 255, .03));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-radius:.5rem;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s,border-color .2s}.mk-quiz-card:hover{border-color:var(--color-primary, #3b82f6);box-shadow:0 4px 12px #0003}.mk-quiz-cover{width:100%;aspect-ratio:16 / 9;overflow:hidden;background:var(--color-bg-secondary, #1a1a2e)}.mk-quiz-cover img{width:100%;height:100%;object-fit:cover;display:block}.mk-quiz-cover--empty{display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:var(--color-text-secondary, #64748b);opacity:.3}.mk-quiz-info{padding:.75rem;display:flex;flex-direction:column;gap:.3rem;flex:1}.mk-quiz-top{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.mk-quiz-name{font-size:.95rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mk-quiz-desc{margin:0;font-size:.8rem;color:var(--color-text-secondary, #94a3b8);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.mk-quiz-actions{display:flex;gap:.35rem;padding:.5rem .75rem;border-top:1px solid var(--color-border, rgba(255, 255, 255, .06));justify-content:flex-end}.mk-editor{display:flex;flex-direction:column;gap:.75rem}.mk-editor-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.mk-editor-title{margin:0;font-size:1rem;font-weight:600;flex:1}.mk-qform{display:flex;flex-direction:column;gap:.75rem;padding:1rem}.mk-qform-header{display:flex;justify-content:space-between;align-items:center}.mk-qform-header h4{margin:0;font-size:.95rem}.mk-qform-actions-top{display:flex;gap:.35rem}.mk-qform-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem}.mk-qform-btns{display:flex;gap:.5rem;justify-content:flex-end;padding-top:.5rem;border-top:1px solid var(--color-border, rgba(255, 255, 255, .08))}.mk-qform-img-preview{position:relative;display:inline-block}.mk-qform-img-preview img{max-width:200px;max-height:140px;border-radius:.375rem;object-fit:cover;border:1px solid var(--color-border, rgba(255, 255, 255, .1))}.mk-qform-img-preview .mk-icon-btn{position:absolute;top:4px;right:4px}.mk-field{display:flex;flex-direction:column;gap:.25rem}.mk-label{font-size:.7rem;font-weight:600;color:var(--color-text-secondary, #94a3b8);text-transform:uppercase;letter-spacing:.3px}.mk-label-sm{font-size:.65rem;color:var(--color-text-secondary, #94a3b8)}.mk-field input[type=text],.mk-field input[type=number],.mk-field textarea,.mk-field select{width:100%;padding:.4rem .6rem;font-size:.85rem;background:var(--color-bg-elevated, rgba(255, 255, 255, .05));color:var(--color-text, #e2e8f0);border:1px solid var(--color-border, rgba(255, 255, 255, .1));border-radius:.375rem;transition:border-color .15s}.mk-field input:focus,.mk-field textarea:focus,.mk-field select:focus{outline:none;border-color:var(--color-primary, #3b82f6)}.mk-field textarea{resize:vertical;min-height:60px;font-family:inherit}.mk-answers{display:flex;flex-direction:column;gap:.4rem}.mk-answer-row{display:flex;align-items:center;gap:.4rem}.mk-answer-strip{width:28px;height:28px;border-radius:.25rem;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700;flex-shrink:0}.mk-answer-input{flex:1;min-width:0}.mk-answer-label{font-size:.9rem;font-weight:500}.mk-answer-row input[type=radio]{flex-shrink:0;cursor:pointer}.mk-slider-fields{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:.5rem}.mk-dropzone{border:2px dashed var(--color-border, rgba(255, 255, 255, .15));border-radius:.5rem;padding:1.25rem;text-align:center;color:var(--color-text-secondary, #94a3b8);font-size:.8rem;cursor:pointer;transition:border-color .15s,background .15s}.mk-dropzone:hover{border-color:var(--color-primary, #3b82f6);background:#3b82f60d}.mk-dropzone-hint{font-size:.75rem;color:var(--color-text-secondary, #64748b);padding:.5rem}.mk-question-list{display:flex;flex-direction:column;gap:.35rem}.mk-question-item{display:flex;flex-direction:column;gap:.25rem;padding:.6rem .75rem;background:var(--color-bg-elevated, rgba(255, 255, 255, .03));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-radius:.375rem;transition:background .15s;position:relative}.mk-question-item:hover{background:var(--color-bg-elevated, rgba(255, 255, 255, .06))}.mk-question-left{display:flex;align-items:center;gap:.4rem}.mk-question-num{font-size:.7rem;font-weight:700;color:var(--color-text-secondary, #64748b);font-family:monospace;min-width:1.5rem}.mk-question-meta{font-size:.75rem;color:var(--color-text-secondary, #94a3b8);margin-left:auto}.mk-question-text{font-size:.85rem;color:var(--color-text, #e2e8f0);line-height:1.4}.mk-question-answers{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.15rem}.mk-question-btns{display:flex;gap:.3rem;justify-content:flex-end;margin-top:.25rem}.mk-live{display:flex;flex-direction:column;gap:.75rem}.mk-session-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.mk-session-card{background:var(--color-bg-elevated, rgba(255, 255, 255, .03));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-left:4px solid #94a3b8;border-radius:.5rem;padding:.75rem;cursor:pointer;transition:background .15s,box-shadow .15s;display:flex;flex-direction:column;gap:.5rem}.mk-session-card:hover{background:var(--color-bg-elevated, rgba(255, 255, 255, .06));box-shadow:0 2px 8px #00000026}.mk-session-card-top{display:flex;justify-content:space-between;align-items:center}.mk-session-pin{font-size:2rem;font-weight:700;font-family:monospace;color:var(--color-primary, #3b82f6);letter-spacing:.15em;text-align:center}.mk-session-meta{font-size:.75rem;color:var(--color-text-secondary, #94a3b8);text-align:center}.mk-live-session{display:flex;flex-direction:column;gap:1rem}.mk-live-header{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.mk-pin-card{text-align:center;padding:1.5rem}.mk-pin-label{font-size:.8rem;color:var(--color-text-secondary, #94a3b8);text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem}.mk-pin-value{font-size:3.5rem;font-weight:700;font-family:monospace;color:var(--color-primary, #3b82f6);letter-spacing:.2em;-webkit-user-select:all;user-select:all}.mk-pin-hint{font-size:.75rem;color:var(--color-text-secondary, #64748b);margin-top:.35rem}.mk-kpi-row{display:flex;gap:.75rem;flex-wrap:wrap}.mk-kpi{display:flex;flex-direction:column;align-items:center;gap:.15rem;background:var(--color-bg-elevated, rgba(255, 255, 255, .03));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-radius:.5rem;padding:.6rem 1rem;min-width:80px}.mk-kpi-val{font-size:1.1rem;font-weight:700;font-family:monospace;color:var(--color-primary, #3b82f6)}.mk-kpi-label{font-size:.65rem;color:var(--color-text-secondary, #94a3b8);text-transform:uppercase;letter-spacing:.3px}.mk-players-section{display:flex;flex-direction:column;gap:.4rem}.mk-player-chips{display:flex;flex-wrap:wrap;gap:.3rem;max-height:100px;overflow-y:auto}.mk-player-chip{display:inline-flex;align-items:center;gap:.3rem;font-size:.75rem;font-weight:500;padding:.2rem .6rem;border-radius:999px;background:#3b82f61f;color:var(--color-primary, #3b82f6);white-space:nowrap}.mk-player-score{font-size:.65rem;font-weight:700;opacity:.7}.mk-controls{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.mk-btn-lg{padding:.6rem 1.5rem;font-size:.95rem;font-weight:600}.mk-btn-sm{padding:.2rem .5rem;font-size:.75rem}.mk-finished-msg{font-size:1.1rem;font-weight:700;color:var(--color-text-secondary, #94a3b8);padding:1rem;text-align:center}.mk-current-q{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.mk-current-q-header{display:flex;align-items:center;gap:.5rem}.mk-current-q-type{font-size:.8rem;font-weight:500;color:var(--color-text-secondary, #94a3b8)}.mk-current-q-meta{font-size:.75rem;color:var(--color-text-secondary, #64748b);margin-left:auto}.mk-current-q-text{font-size:1.1rem;font-weight:600;line-height:1.4;color:var(--color-text, #e2e8f0)}.mk-current-q-img{text-align:center}.mk-current-q-img img{max-width:100%;max-height:250px;border-radius:.5rem;object-fit:contain}.mk-live-answers{display:flex;flex-direction:column;gap:.4rem}.mk-live-answer{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;background:var(--color-bg-elevated, rgba(255, 255, 255, .04));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-left:4px solid #94a3b8;border-radius:.375rem;font-size:.9rem;transition:background .3s,border-color .3s}.mk-live-answer-letter{width:28px;height:28px;border-radius:.25rem;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8rem;font-weight:700;flex-shrink:0}.mk-live-answer--correct{background:#10b98126;border-color:#10b981;border-left-color:#10b981}.mk-live-answer--wrong{opacity:.45}.mk-check{margin-left:auto;color:#10b981;font-size:1.1rem;font-weight:700;display:inline-flex;align-items:center}.mk-check .material-symbols-outlined{font-size:1.2rem}.mk-slider-result{font-size:.95rem;padding:.5rem;background:var(--color-bg-elevated, rgba(255, 255, 255, .04));border-radius:.375rem;text-align:center}.mk-explication{font-size:.85rem;padding:.6rem .75rem;background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:.375rem;color:var(--color-text, #e2e8f0);line-height:1.4}.mk-leaderboard{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.mk-lb-title{margin:0;font-size:1rem;font-weight:700}.mk-podium{display:flex;justify-content:center;align-items:flex-end;gap:1.5rem;padding:1.25rem 0}.mk-podium-item{text-align:center;min-width:80px;animation:mk-pop .4s ease-out both}.mk-podium-item:nth-child(1){animation-delay:.1s}.mk-podium-item:nth-child(2){animation-delay:.25s}.mk-podium-item:nth-child(3){animation-delay:.4s}.mk-podium-medal{width:48px;height:48px;border-radius:50%;margin:0 auto .4rem;display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:700;color:#000;box-shadow:0 2px 8px #0000004d}.mk-podium-name{font-weight:700;font-size:.9rem;margin-bottom:.15rem}.mk-podium-score{font-size:1rem;font-weight:700;color:var(--color-primary, #3b82f6)}.mk-podium-streak{font-size:.65rem;color:var(--color-text-secondary, #94a3b8);margin-top:.1rem}.mk-lb-table{width:100%;border-collapse:collapse;font-size:.8rem}.mk-lb-table th{text-align:left;padding:.4rem .5rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.3px;color:var(--color-text-secondary, #94a3b8);border-bottom:1px solid var(--color-border, rgba(255, 255, 255, .1))}.mk-lb-table td{padding:.35rem .5rem;border-bottom:1px solid var(--color-border, rgba(255, 255, 255, .05))}.mk-lb-rank{font-weight:700;color:var(--color-text-secondary, #64748b);min-width:1.5rem;text-align:center}.mk-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:mk-fade-in .15s ease-out}@keyframes mk-fade-in{0%{opacity:0}to{opacity:1}}.mk-modal{width:500px;max-width:95vw;max-height:85vh;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;padding:1.25rem}.mk-modal h3{margin:0 0 .25rem;font-size:1.05rem}.mk-modal-btns{display:flex;gap:.5rem;justify-content:flex-end;padding-top:.5rem;border-top:1px solid var(--color-border, rgba(255, 255, 255, .08))}.mk-toast{position:fixed;top:1.25rem;right:1.25rem;z-index:9999;padding:.6rem 1rem;border-radius:.5rem;font-size:.85rem;font-weight:500;box-shadow:0 4px 12px #0000004d;cursor:pointer;animation:mk-toast-in .25s ease-out;max-width:350px}.mk-toast--success{background:#10b981;color:#fff}.mk-toast--error{background:#dc2626;color:#fff}@keyframes mk-toast-in{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes mk-pop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.08)}to{transform:scale(1);opacity:1}}@media (max-width: 768px){.mk-quiz-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.mk-qform-row3{grid-template-columns:1fr}.mk-slider-fields{grid-template-columns:1fr 1fr}.mk-pin-value{font-size:2.5rem}.mk-podium{gap:.75rem}.mk-podium-medal{width:40px;height:40px;font-size:1.1rem}.mk-modal{width:100%;max-width:100vw;border-radius:.5rem .5rem 0 0}.mk-header,.mk-editor-header{flex-direction:column;align-items:flex-start}}.img-annotator{display:flex;flex-direction:column;gap:.5rem}.img-annotator-toolbar{display:flex;flex-wrap:wrap;align-items:stretch;gap:0;background:var(--color-surface, var(--bg-surface, #f5f5f5));border-radius:.625rem;border:1px solid var(--color-border);padding:.25rem;box-shadow:0 2px 8px #00000014}.img-annotator-group{display:flex;flex-direction:column;gap:.15rem;padding:.2rem .4rem}.img-annotator-group--actions{margin-left:auto}.img-annotator-group-label{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-secondary, #64748b);padding-left:.15rem;line-height:1;-webkit-user-select:none;user-select:none}.img-annotator-divider{width:1px;align-self:stretch;margin:.35rem 0;background:var(--color-border)}.img-annotator-tools{display:flex;gap:1px;background:color-mix(in srgb,var(--color-text) 6%,transparent);border-radius:.375rem;padding:1px}.img-annotator-tool{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:.3rem;background:transparent;color:var(--color-text-secondary, #94a3b8);cursor:pointer;transition:all .15s}.img-annotator-tool .material-symbols-outlined{font-size:1.1rem}.img-annotator-tool:hover{background:var( --color-surface-hover, color-mix(in srgb, var(--color-text) 8%, transparent) );color:var(--color-text)}.img-annotator-tool.active{background:var(--color-primary, #6366f1);color:#fff;box-shadow:0 1px 4px #6366f159}.img-annotator-colors{display:flex;gap:3px;align-items:center}.img-annotator-color{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:.3rem;border:2px solid transparent;background:transparent;cursor:pointer;transition:transform .15s,border-color .15s,background .15s;padding:0}.img-annotator-color:hover{background:var( --color-surface-hover, color-mix(in srgb, var(--color-text) 8%, transparent) );transform:scale(1.1)}.img-annotator-color.active{border-color:var(--color-primary, #6366f1);background:color-mix(in srgb,var(--color-primary) 10%,transparent)}.img-annotator-color-dot{display:block;width:14px;height:14px;border-radius:50%;box-shadow:inset 0 0 0 1px #00000026,0 0 0 1px #80808033;pointer-events:none}.img-annotator-stroke{display:flex;align-items:center;gap:.3rem}.img-annotator-stroke input[type=range]{width:55px;height:4px;accent-color:var(--color-primary, #6366f1)}.img-annotator-stroke-val{font-size:.65rem;font-weight:600;color:var(--color-text-secondary, #94a3b8);min-width:22px;text-align:center}.img-annotator-actions{display:flex;gap:2px}.img-annotator-action-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:.3rem;background:transparent;color:var(--color-text-secondary, #94a3b8);cursor:pointer;transition:all .15s}.img-annotator-action-btn .material-symbols-outlined{font-size:1rem}.img-annotator-action-btn:hover{background:var( --color-surface-hover, color-mix(in srgb, var(--color-text) 8%, transparent) );color:var(--color-text)}.img-annotator-action-btn:disabled{opacity:.3;cursor:not-allowed}.img-annotator-action-btn--danger:hover{background:#dc262626;color:#ef4444}.img-annotator-canvas{position:relative;display:inline-block;border-radius:.5rem;overflow:hidden;border:1px solid var(--color-border);background:#000;-webkit-user-select:none;user-select:none}.img-annotator-bg{display:block;width:100%;max-height:400px;object-fit:contain;pointer-events:none}.img-annotator-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.img-annotator-text-modal{display:flex;gap:.5rem;align-items:center;padding:.5rem;background:var(--color-surface, var(--bg-surface, #f5f5f5));border-radius:.375rem;border:1px solid var(--color-border)}.img-annotator-text-modal input{flex:1;padding:.3rem .5rem;font-size:.85rem}.img-annotator-count{font-size:.7rem;color:var(--color-text-secondary, #94a3b8);text-align:right}.img-annotated-display{position:relative;display:inline-block;max-width:100%}.img-annotated-display img{display:block;width:100%;border-radius:.5rem}.img-annotated-display svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}@media (max-width: 600px){.img-annotator-toolbar{gap:0;padding:.15rem}.img-annotator-group{padding:.15rem .25rem}.img-annotator-group-label,.img-annotator-divider{display:none}.img-annotator-group--actions{margin-left:0}}.materiel-planning-view{display:flex;flex-direction:column;gap:12px;padding:12px;height:100%;overflow:hidden}.mp-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:8px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px}.mp-view-toggle{display:flex;gap:2px;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.mp-view-toggle button{border-radius:0;border:none;padding:4px 10px;font-size:.78rem}.mp-nav{display:flex;align-items:center;gap:4px}.mp-today-btn{font-size:.78rem!important;padding:3px 10px!important}.mp-period-label{font-size:.85rem;font-weight:600;color:var(--color-text);margin-left:4px;text-transform:capitalize}.mp-date-range{display:flex;align-items:center;gap:6px}.mp-date-range label{font-size:.8rem;color:var(--color-text-secondary)}.mp-date-range input{padding:4px 8px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg);color:var(--color-text);font-size:.8rem}.mp-legend{display:flex;gap:12px;margin-left:auto;font-size:.75rem;color:var(--color-text-secondary)}.mp-legend span{display:flex;align-items:center;gap:4px}.mp-legend i{display:inline-block;width:14px;height:10px;border-radius:2px}.mp-loading,.mp-empty,.mp-error{text-align:center;padding:30px;color:var(--color-text-secondary);font-size:.85rem}.mp-error{color:var(--color-danger)}.mp-gantt-wrapper{flex:1;overflow:auto;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg)}.mp-gantt-grid{display:grid;grid-template-columns:200px repeat(var(--mp-cols),minmax(22px,1fr));font-size:.72rem;min-width:100%}.mp-gantt-grid.mp-gantt-week{grid-template-columns:200px repeat(var(--mp-cols),1fr)}.mp-header-cell{background:var(--color-surface);position:sticky;top:0;z-index:3}.mp-row-label{padding:4px 8px;background:var(--color-surface);border-right:2px solid var(--color-border);border-bottom:1px solid var(--color-border);position:sticky;left:0;z-index:2;display:flex;flex-direction:column;justify-content:center;min-height:32px;font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mp-mat-name{font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis}.mp-mat-ref{font-size:.65rem;color:var(--color-text-secondary);font-family:monospace}.mp-month-cell{padding:4px 6px;background:var(--color-surface);border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);text-align:center;font-weight:600;font-size:.7rem;color:var(--color-text-secondary);text-transform:uppercase;position:sticky;top:0;z-index:2}.mp-day-cell.mp-day-header{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4px 2px;gap:1px}.mp-day-name{font-size:.7rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase}.mp-day-num{font-size:.8rem;font-weight:700;color:var(--color-text)}.mp-day-header.today .mp-day-num{color:var(--color-primary)}.mp-day-cell{padding:2px 0;background:var(--color-surface);border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);text-align:center;font-size:.65rem;color:var(--color-text-secondary);position:sticky;top:26px;z-index:2}.mp-gantt-week .mp-day-cell{top:0}.mp-day-cell.weekend{background:var(--color-bg)}.mp-day-cell.today{background:color-mix(in srgb,var(--color-primary) 25%,transparent);color:var(--color-primary);font-weight:700}.mp-group-row{padding:4px 8px;background:color-mix(in srgb,var(--color-primary) 10%,transparent);border-bottom:1px solid var(--color-border);font-size:.72rem;font-weight:700;text-transform:uppercase;color:var(--color-primary);position:sticky;left:0;z-index:2}.mp-group-count{font-weight:400;color:var(--color-text-secondary);margin-left:6px}.mp-mat-row{display:contents}.mp-bars{display:grid;position:relative;border-bottom:1px solid var(--color-border);min-height:32px}.mp-bg-cell{border-right:1px solid var(--color-border);background:var(--color-bg)}.mp-bg-cell.weekend{background:var(--color-surface)}.mp-bg-cell.today{background:color-mix(in srgb,var(--color-primary) 6%,transparent)}.mp-bar{grid-row:1;margin:4px 1px;border-radius:4px;padding:2px 6px;color:#fff;font-size:.7rem;font-weight:600;display:flex;align-items:center;cursor:pointer;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;box-shadow:0 1px 2px #0003;transition:transform .1s}.mp-bar:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000004d}.mp-bar-label{overflow:hidden;text-overflow:ellipsis}.mp-cal{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--color-border);border-radius:var(--radius-md, .5rem);overflow:auto;flex:1}.mp-cal-head{padding:.4rem;text-align:center;font-weight:700;font-size:.75rem;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.mp-cal-cell{min-height:100px;padding:.3rem;border-bottom:1px solid var(--color-border-light, rgba(255, 255, 255, .05));border-left:1px solid var(--color-border-light, rgba(255, 255, 255, .05));position:relative}.mp-cal-cell:hover{background:var(--color-bg-hover, rgba(255, 255, 255, .02))}.mp-cal-today{background:#3b82f614}.mp-cal-other{opacity:.4}.mp-cal-day{font-size:.75rem;font-weight:700;margin-bottom:.2rem}.mp-cal-evt{font-size:.65rem;padding:.1rem .3rem;border-radius:.2rem;margin-bottom:.15rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:default}.mp-cal-more{font-size:.65rem;color:var(--color-primary);font-weight:600;cursor:default}.ddes-root{display:flex;flex-direction:column;gap:8px}.ddes-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:8px 10px;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-color)}.ddes-toolbar-sep{width:1px;height:22px;background:var(--border-color);margin:0 4px}.ddes-var-chip{padding:3px 8px;font-size:.72rem;font-family:Courier New,monospace;background:#7c3aed1a;color:#7c3aed;border:1px solid rgba(124,58,237,.25);border-radius:4px;cursor:pointer;transition:background .15s}.ddes-var-chip:hover{background:#7c3aed33}.ddes-tb-btn{padding:4px 10px;font-size:.75rem;background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:background .15s}.ddes-tb-btn:hover{background:var(--bg-hover)}.ddes-tb-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.ddes-workspace{display:flex;flex-direction:row;gap:0;border:1px solid var(--border-color);border-radius:6px;overflow:hidden}.ddes-props{width:190px;min-width:190px;background:var(--bg-surface);border-right:1px solid var(--border-color);padding:10px;overflow-y:auto;max-height:72vh}.ddes-props h4{font-size:.78rem;margin:0 0 8px;color:var(--text-primary)}.ddes-props-group{margin-bottom:8px}.ddes-props-label{font-size:.68rem;color:var(--text-secondary);margin-bottom:2px;display:block}.ddes-props input[type=number],.ddes-props input[type=text],.ddes-props input[type=color],.ddes-props select,.ddes-props textarea{width:100%;font-size:.78rem;padding:3px 6px;border:1px solid var(--border-color);border-radius:3px;background:var(--bg-primary);color:var(--text-primary);box-sizing:border-box}.ddes-props textarea{resize:vertical;min-height:48px}.ddes-props-row{display:flex;gap:6px;margin-bottom:6px}.ddes-props-toggle-row{display:flex;gap:4px;margin-bottom:6px}.ddes-props-toggle{flex:1;padding:3px 0;font-size:.72rem;text-align:center;border:1px solid var(--border-color);border-radius:3px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer}.ddes-props-toggle.on{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.ddes-props-sep{border:none;border-top:1px solid var(--border-color);margin:8px 0}.ddes-props-empty{font-size:.72rem;color:var(--text-secondary);text-align:center;padding:20px 4px}.ddes-canvas-scroll{flex:1;overflow:auto;max-height:72vh;background:var(--bg-primary);padding:16px;display:flex;justify-content:center}.ddes-canvas{position:relative;background:#fff;border:1px solid var(--border-color);box-shadow:0 2px 12px #0000001f;flex-shrink:0}:root[data-theme=dark] .ddes-canvas{background:#fff;color:#1e293b}:root[data-theme=dark] .ddes-canvas-scroll{background:var(--bg-primary)}.ddes-grid{position:absolute;top:0;left:0;pointer-events:none;z-index:1}.ddes-element{position:absolute;cursor:move;border:1px dashed transparent;border-radius:2px;padding:2px 4px;box-sizing:border-box;z-index:2;-webkit-user-select:none;user-select:none;transition:border-color .12s;white-space:pre-wrap;overflow:visible;min-height:1.4em}.ddes-element:hover{border-color:#3b82f64d}.ddes-element.selected{border-color:#3b82f6;border-style:solid;z-index:3}.ddes-element.multi-selected{border-color:#3b82f6;border-style:dashed;z-index:3}.ddes-el-preview{cursor:default!important;border-color:transparent!important}.ddes-el-preview .ddes-el-handle{display:none}.ddes-el-variable span{background:#ede9fe;color:#7c3aed;font-family:Courier New,monospace;padding:1px 4px;border-radius:2px;font-size:inherit}.ddes-el-handle{position:absolute;top:-6px;right:-6px;width:16px;height:16px;border-radius:50%;background:#3b82f6;color:#fff;font-size:9px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;opacity:0;transition:opacity .12s}.ddes-element:hover .ddes-el-handle,.ddes-element.selected .ddes-el-handle{opacity:1}.ddes-inline-edit{width:100%;min-height:60px;background:#fffffff2;border:1px solid #3b82f6;border-radius:2px;resize:vertical;outline:none;z-index:20;padding:4px 6px;box-sizing:border-box;overflow:auto}.ddes-el-resize{position:absolute;top:0;right:-4px;width:8px;height:100%;cursor:ew-resize;z-index:10}.ddes-el-resize:after{content:"";position:absolute;top:50%;right:2px;transform:translateY(-50%);width:3px;height:16px;border-radius:2px;background:#3b82f6;opacity:0;transition:opacity .12s}.ddes-element.selected .ddes-el-resize:after{opacity:.6}.ddes-element.selected .ddes-el-resize:hover:after{opacity:1}.docp-panel{padding:12px;display:flex;flex-direction:column;gap:16px}.docp-toast{position:fixed;top:16px;right:16px;padding:10px 18px;border-radius:6px;font-size:.82rem;color:#fff;z-index:9999;animation:docp-slide-in .25s ease-out}.docp-toast.success{background:#10b981}.docp-toast.error{background:#ef4444}.docp-toast.info{background:#3b82f6}@keyframes docp-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.docp-tabs{display:flex;gap:4px;margin-bottom:8px}.docp-tab{padding:6px 14px;font-size:.78rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;gap:5px;transition:background .15s}.docp-tab:hover{background:var(--bg-hover)}.docp-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.docp-tab-count{font-size:.65rem;background:#fff3;padding:0 5px;border-radius:8px;min-width:16px;text-align:center}.docp-btn{padding:5px 12px;font-size:.78rem;background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:background .15s;display:inline-flex;align-items:center;gap:4px}.docp-btn:hover{background:var(--bg-hover)}.docp-btn-primary,.docp-btn-new,.docp-btn-save{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.docp-btn-primary:hover,.docp-btn-new:hover,.docp-btn-save:hover{opacity:.9}.docp-btn-danger{background:#ef4444;color:#fff;border-color:#ef4444}.docp-btn-danger:hover{opacity:.9}.docp-btn-success{background:#10b981;color:#fff;border-color:#10b981}.docp-btn-success:hover{opacity:.9}.docp-btn-email{background:#06b6d4;color:#fff;border-color:#06b6d4}.docp-btn-email:hover{background:#0891b2}.docp-icon-btn{width:30px;height:30px;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s}.docp-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.docp-icon-btn--danger:hover{background:#fecaca;color:#dc2626}.docp-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.docp-toolbar-spacer{flex:1}.docp-section-header{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-secondary);margin:4px 0}.docp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px}.docp-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:8px;overflow:hidden;transition:box-shadow .15s}.docp-card:hover{box-shadow:0 2px 10px #00000014}.docp-card-top{display:flex;align-items:center;gap:10px;padding:12px 14px}.docp-card-icon{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.docp-card-icon .material-symbols-outlined{font-size:20px}.docp-card-info{flex:1;min-width:0}.docp-card-info h4{margin:0;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.docp-card-info small{font-size:.72rem;color:var(--text-secondary)}.docp-card-body{padding:0 14px 10px;font-size:.78rem;color:var(--text-secondary);display:flex;flex-wrap:wrap;gap:6px;align-items:center}.docp-card-footer{display:flex;gap:4px;padding:8px 14px;border-top:1px solid var(--border-color)}.docp-badge{display:inline-flex;align-items:center;gap:3px;font-size:.65rem;padding:2px 8px;border-radius:10px;color:#fff;white-space:nowrap}.docp-badge-outline{display:inline-flex;align-items:center;gap:3px;font-size:.65rem;padding:2px 8px;border-radius:10px;border:1px solid var(--border-color);color:var(--text-secondary);white-space:nowrap}.docp-gen-card{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;transition:background .15s}.docp-gen-card:hover{background:var(--bg-hover)}.docp-editor{display:flex;flex-direction:column;gap:12px}.docp-ed-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}.docp-ed-meta label{font-size:.72rem;color:var(--text-secondary);display:block;margin-bottom:2px}.docp-ed-meta input,.docp-ed-meta select{font-size:.82rem;padding:4px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-surface);color:var(--text-primary)}.docp-formations-bar{display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:.75rem;color:var(--text-secondary)}.docp-generate{max-width:640px;display:flex;flex-direction:column;gap:12px}.docp-generate label,.docp-label{font-size:.75rem;color:var(--text-secondary);display:block;margin-bottom:2px}.docp-generate select,.docp-generate input,.docp-input,.docp-select{width:100%;font-size:.82rem;padding:5px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-surface);color:var(--text-primary)}.docp-generate select[multiple]{min-height:140px}.docp-gen-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px}.docp-radio-group{display:flex;align-items:center;gap:12px}.docp-radio-group label{display:flex;align-items:center;gap:4px;cursor:pointer;font-size:.82rem}.docp-preview-view{display:flex;flex-direction:column;gap:12px}.docp-preview-a4-wrap{overflow:auto;max-height:72vh;padding:16px;background:var(--bg-primary);border-radius:6px;display:flex;justify-content:center}.docp-preview-a4{background:#fff;color:#1e293b;box-shadow:0 2px 12px #0000001f;min-height:297mm;position:relative;outline:none;overflow:hidden}:root[data-theme=dark] .docp-preview-a4{background:#fff;color:#1e293b}.docp-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.docp-modal{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:10px;padding:24px;width:90%;max-width:480px;max-height:85vh;overflow-y:auto}.docp-modal h3{margin:0 0 16px;font-size:1rem;display:flex;align-items:center}.docp-modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;padding-top:12px;border-top:1px solid var(--border-color)}.docp-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.docp-form-grid .full{grid-column:1 / -1}.docp-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px;color:var(--text-secondary);font-size:.85rem}.docp-empty .material-symbols-outlined{font-size:40px;opacity:.3}.docp-error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;padding:8px 14px;border-radius:6px;font-size:.82rem}.docp-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:docp-spin .6s linear infinite}@keyframes docp-spin{to{transform:rotate(360deg)}}@media print{.docp-preview-view>*:not(.docp-preview-a4-wrap){display:none}.docp-preview-a4-wrap{padding:0;background:none;max-height:none}.docp-preview-a4{box-shadow:none;width:100%;min-height:auto;padding:0}}.docp-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:30px;color:var(--color-text-secondary);font-size:.9rem}.spin{animation:docp-spin 1s linear infinite}@keyframes docp-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.docp-stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.docp-stat-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid;border-radius:10px;transition:transform .15s,box-shadow .15s}.docp-stat-card:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.docp-stat-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.docp-stat-icon .material-symbols-outlined{color:#fff;font-size:20px}.docp-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.1}.docp-stat-label{font-size:.72rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.docp-toolbar-modern{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;margin-bottom:14px;flex-wrap:wrap}.docp-tabs{display:flex;gap:4px;background:var(--color-bg);border-radius:8px;padding:3px}.docp-tab{display:flex;align-items:center;gap:6px;padding:6px 14px;border:none;border-radius:6px;background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:.82rem;font-weight:500;transition:all .15s}.docp-tab:hover{color:var(--color-text)}.docp-tab.active{background:var(--color-primary);color:#fff}.docp-tab-count{font-size:.7rem;background:#ffffff40;padding:1px 6px;border-radius:10px;font-weight:700}.docp-tab:not(.active) .docp-tab-count{background:var(--color-border);color:var(--color-text-secondary)}.docp-filters{display:flex;align-items:center;gap:8px;flex:1;flex-wrap:wrap}.docp-search{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;min-width:200px;flex:1;max-width:280px}.docp-search .material-symbols-outlined{color:var(--color-text-secondary);font-size:18px}.docp-search input{flex:1;border:none;background:transparent;color:var(--color-text);font-size:.82rem;outline:none;min-width:0}.docp-search button{border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;padding:0;display:flex}.docp-type-chips{display:flex;gap:4px;flex-wrap:wrap}.docp-type-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border:1px solid var(--color-border);border-radius:14px;background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.72rem;font-weight:600;transition:all .15s}.docp-type-chip:hover{border-color:var(--color-primary)}.docp-type-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.docp-type-chip .material-symbols-outlined{font-size:14px}.docp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.docp-card-modern{display:flex;flex-direction:column;gap:8px;padding:16px;background:var(--color-surface);border:1px solid var(--color-border);border-top:4px solid;border-radius:10px;transition:all .15s}.docp-card-modern:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.docp-card-modern-header{display:flex;justify-content:space-between;align-items:flex-start}.docp-card-modern-icon{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center}.docp-card-modern-icon .material-symbols-outlined{color:#fff;font-size:20px}.docp-card-modern-title{margin:0;font-size:.95rem;font-weight:700;color:var(--color-text);line-height:1.3}.docp-card-modern-desc{margin:0;font-size:.78rem;color:var(--color-text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.docp-card-modern-meta{display:flex;gap:10px;font-size:.72rem;color:var(--color-text-secondary);flex-wrap:wrap}.docp-card-modern-meta span{display:inline-flex;align-items:center;gap:3px}.docp-card-modern-meta .material-symbols-outlined{font-size:13px}.docp-card-modern-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.docp-card-modern-footer{display:flex;align-items:center;gap:6px;margin-top:8px;padding-top:10px;border-top:1px solid var(--color-border)}.docp-gen-list{display:flex;flex-direction:column;gap:8px}.docp-gen-card-modern{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;transition:all .15s}.docp-gen-card-modern:hover{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 4%,var(--color-surface))}.docp-gen-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.docp-gen-icon .material-symbols-outlined{color:#fff;font-size:18px}.docp-gen-content{flex:1;min-width:0}.docp-gen-title{display:flex;align-items:center;gap:8px;font-size:.88rem;font-weight:600;color:var(--color-text);margin-bottom:3px}.docp-gen-meta{display:flex;gap:12px;font-size:.72rem;color:var(--color-text-secondary);flex-wrap:wrap}.docp-gen-meta span{display:inline-flex;align-items:center;gap:3px}.docp-gen-meta .material-symbols-outlined{font-size:13px}.docp-gen-actions{display:flex;gap:4px}.docp-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:50px 20px;text-align:center;color:var(--color-text-secondary);font-size:.9rem}.docp-empty .material-symbols-outlined{font-size:48px;opacity:.4}.docp-btn-success{background:#10b981;color:#fff;border:1px solid #10b981}.docp-btn-success:hover{background:#059669;border-color:#059669}.docp-view-toggle{display:flex;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.docp-view-btn{display:flex;align-items:center;justify-content:center;padding:6px 10px;border:none;background:var(--color-bg);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.docp-view-btn:hover{color:var(--color-text)}.docp-view-btn.active{background:var(--color-primary);color:#fff}.docp-list-rows{display:flex;flex-direction:column;gap:6px}.docp-list-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;transition:all .15s}.docp-list-row:hover{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 4%,var(--color-surface))}.docp-list-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.docp-list-icon .material-symbols-outlined{color:#fff;font-size:18px}.docp-list-main{flex:1;min-width:0}.docp-list-title{font-size:.88rem;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.docp-list-desc{font-size:.72rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.docp-list-meta-item{display:inline-flex;align-items:center;gap:3px;font-size:.72rem;color:var(--color-text-secondary);white-space:nowrap}.docp-list-meta-item .material-symbols-outlined{font-size:13px}.docp-list-actions{display:flex;gap:4px;flex-shrink:0}.dip-panel{padding:12px;display:flex;flex-direction:column;gap:16px}.dip-toast{position:fixed;top:16px;right:16px;padding:10px 18px;border-radius:6px;font-size:.82rem;color:#fff;z-index:9999;animation:dip-slide-in .25s ease-out}.dip-toast.success{background:#10b981}.dip-toast.error{background:#ef4444}.dip-toast.info{background:#3b82f6}@keyframes dip-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.dip-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border-color)}.dip-tab{padding:8px 16px;font-size:.85rem;font-weight:400;background:transparent;color:var(--text-secondary);border:none;border-radius:8px 8px 0 0;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .15s,color .15s}.dip-tab:hover{background:var(--bg-hover)}.dip-tab.active{background:var(--color-primary);color:#fff;font-weight:600}.dip-btn{padding:5px 12px;font-size:.78rem;background:var(--bg-surface, var(--bg-secondary));color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:background .15s}.dip-btn:hover{background:var(--bg-hover)}.dip-btn:disabled{opacity:.5;cursor:not-allowed}.dip-btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.dip-btn-primary:hover{opacity:.9}.dip-btn-danger{background:var(--color-danger, #ef4444);color:#fff;border-color:var(--color-danger, #ef4444)}.dip-btn-danger:hover{opacity:.9}.dip-btn-success{background:#10b981;color:#fff;border-color:#10b981}.dip-btn-success:hover{opacity:.9}.dip-icon-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.dip-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.dip-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.dip-toolbar-spacer{flex:1}.dip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px}.dip-card{background:var(--bg-surface, var(--bg-secondary));border:1px solid var(--border-color);border-radius:8px;overflow:hidden;transition:box-shadow .15s}.dip-card:hover{box-shadow:0 2px 8px #00000014}.dip-card-top{display:flex;align-items:center;gap:10px;padding:12px 14px}.dip-card-icon{width:38px;height:38px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.dip-card-icon .material-symbols-outlined{font-size:20px}.dip-card-info{flex:1;min-width:0}.dip-card-info h4{margin:0;font-size:.88rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dip-card-info small{font-size:.72rem;color:var(--text-secondary)}.dip-card-body{padding:8px 14px 10px;font-size:.78rem;color:var(--text-secondary);display:flex;flex-wrap:wrap;gap:6px}.dip-card-footer{display:flex;justify-content:flex-end;gap:4px;padding:6px 14px 10px;border-top:1px solid var(--border-color)}.dip-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.65rem;font-weight:600;color:#fff}.dip-badge-outline{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.65rem;font-weight:600;background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.dip-table{width:100%;border-collapse:collapse;font-size:.85rem}.dip-table thead tr{border-bottom:2px solid var(--border-color)}.dip-table th{padding:8px;text-align:left;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.dip-table td{padding:8px}.dip-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .1s}.dip-table tbody tr:hover{background:var(--bg-hover)}.dip-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.dip-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;width:540px;max-height:80vh;overflow:auto;padding:20px}.dip-modal h3{margin:0 0 16px;font-size:1rem}.dip-modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.dip-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.dip-form-grid .full{grid-column:1/-1}.dip-label{font-size:.72rem;color:var(--text-secondary);display:block;margin-bottom:3px;text-transform:uppercase;letter-spacing:.03em}.dip-input,.dip-select{width:100%;font-size:.82rem;padding:5px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-surface, var(--bg-secondary));color:var(--text-primary)}.dip-select{cursor:pointer}.dip-textarea{width:100%;font-size:.82rem;padding:5px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-surface, var(--bg-secondary));color:var(--text-primary);resize:vertical}.dip-generate{max-width:720px;display:flex;flex-direction:column;gap:16px}.dip-gen-section{background:var(--bg-surface, var(--bg-secondary));border:1px solid var(--border-color);border-radius:8px;padding:16px}.dip-gen-section h4{margin:0 0 12px;font-size:.85rem;display:flex;align-items:center;gap:6px;color:var(--text-primary)}.dip-eleve-list{display:flex;flex-direction:column;gap:4px;max-height:280px;overflow-y:auto}.dip-eleve-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:4px;font-size:.82rem;cursor:pointer;transition:background .1s}.dip-eleve-item:hover{background:var(--bg-hover)}.dip-eleve-item input[type=checkbox]{accent-color:var(--color-primary)}.dip-select-all{display:flex;align-items:center;gap:8px;padding:6px 10px;font-size:.82rem;font-weight:600;border-bottom:1px solid var(--border-color);margin-bottom:4px;cursor:pointer}.dip-select-all input[type=checkbox]{accent-color:var(--color-primary)}.dip-gen-count{font-size:.75rem;color:var(--text-secondary);margin-top:8px}.dip-preview-wrap{overflow:auto;max-height:72vh;padding:16px;background:var(--bg-primary);border-radius:6px;display:flex;flex-direction:column;align-items:center;gap:24px}.dip-preview-a4{background:#fff;color:#1e293b;box-shadow:0 2px 12px #0000001f;min-height:297mm;width:210mm;position:relative;outline:none;overflow:hidden}.dip-preview-a4.landscape{min-height:210mm;width:297mm}:root[data-theme=dark] .dip-preview-a4{background:#fff;color:#1e293b}.dip-filter-select{min-width:180px;font-size:.82rem;padding:4px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-surface, var(--bg-secondary));color:var(--text-primary)}.dip-empty{text-align:center;padding:32px;color:var(--text-secondary);font-size:.85rem}.dip-empty .material-symbols-outlined{font-size:48px;opacity:.3;display:block;margin-bottom:8px}.dip-radio-group{display:flex;gap:16px}.dip-radio-group label{font-size:.82rem;display:flex;align-items:center;gap:4px;cursor:pointer}.dip-hint{font-size:.7rem;color:var(--text-secondary);margin-top:3px}.dip-error{color:var(--color-danger, #ef4444);font-size:.82rem;margin-bottom:8px}.dip-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:30px;color:var(--color-text-secondary);font-size:.9rem}.dip-loading .spin{animation:dip-spin 1s linear infinite}@keyframes dip-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dip-stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.dip-stat-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid;border-radius:10px;transition:transform .15s,box-shadow .15s}.dip-stat-card:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.dip-stat-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dip-stat-icon .material-symbols-outlined{color:#fff;font-size:20px}.dip-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.1}.dip-stat-label{font-size:.72rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.dip-toolbar-modern{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;margin-bottom:14px;flex-wrap:wrap}.dip-search{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;min-width:200px;max-width:280px}.dip-search .material-symbols-outlined{color:var(--color-text-secondary);font-size:18px}.dip-search input{flex:1;border:none;background:transparent;color:var(--color-text);font-size:.82rem;outline:none;min-width:0}.dip-search button{border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;padding:0;display:flex}.dip-cat-chips{display:flex;gap:4px;flex-wrap:wrap}.dip-cat-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border:1px solid var(--color-border);border-radius:14px;background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.72rem;font-weight:600;text-transform:capitalize;transition:all .15s}.dip-cat-chip:hover{border-color:var(--color-primary)}.dip-cat-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.dip-cat-chip .material-symbols-outlined{font-size:14px}.dip-card-modern{display:flex;flex-direction:column;gap:8px;padding:16px;background:var(--color-surface);border:1px solid var(--color-border);border-top:4px solid;border-radius:10px;transition:all .15s}.dip-card-modern:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.dip-card-modern-header{display:flex;justify-content:space-between;align-items:flex-start}.dip-card-modern-icon{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center}.dip-card-modern-icon .material-symbols-outlined{color:#fff;font-size:20px}.dip-card-modern-title{margin:0;font-size:.95rem;font-weight:700;color:var(--color-text);line-height:1.3}.dip-card-modern-code{margin:0;font-size:.72rem;font-family:monospace;color:var(--color-text-secondary)}.dip-card-modern-desc{margin:0;font-size:.78rem;color:var(--color-text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.dip-card-modern-meta{display:flex;gap:12px;font-size:.72rem;color:var(--color-text-secondary);flex-wrap:wrap}.dip-card-modern-meta span{display:inline-flex;align-items:center;gap:3px}.dip-card-modern-meta .material-symbols-outlined{font-size:13px}.dip-card-modern-tags{display:flex;flex-wrap:wrap;gap:4px}.dip-card-modern-footer{display:flex;align-items:center;gap:6px;margin-top:8px;padding-top:10px;border-top:1px solid var(--color-border)}.dip-btn-success{background:#10b981;color:#fff;border:1px solid #10b981}.dip-btn-success:hover{background:#059669;border-color:#059669}.dip-view-toggle{display:flex;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.dip-view-btn{display:flex;align-items:center;justify-content:center;padding:6px 10px;border:none;background:var(--color-bg);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.dip-view-btn:hover{color:var(--color-text)}.dip-view-btn.active{background:var(--color-primary);color:#fff}.dip-list-rows{display:flex;flex-direction:column;gap:6px}.dip-list-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;transition:all .15s}.dip-list-row:hover{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 4%,var(--color-surface))}.dip-list-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dip-list-icon .material-symbols-outlined{color:#fff;font-size:18px}.dip-list-main{flex:1;min-width:0}.dip-list-title{font-size:.88rem;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dip-list-desc{font-size:.72rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.dip-list-meta-item{display:inline-flex;align-items:center;gap:3px;font-size:.72rem;color:var(--color-text-secondary);white-space:nowrap}.dip-list-meta-item .material-symbols-outlined{font-size:13px}.dip-list-actions{display:flex;gap:4px;flex-shrink:0}.dip-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:50px 20px;text-align:center;color:var(--color-text-secondary);font-size:.9rem}.dip-empty .material-symbols-outlined{font-size:48px;opacity:.4}.dip-modal-wide{max-width:900px;width:90vw}.dip-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.dip-cascade{display:flex;flex-direction:column;gap:14px}.dip-cascade-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.dip-cascade-step{display:flex;gap:10px;padding:10px 12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;transition:all .2s}.dip-cascade-step.active{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 8%,var(--color-bg))}.dip-cascade-step-num{width:24px;height:24px;border-radius:50%;background:var(--color-bg-secondary, color-mix(in srgb, var(--color-text) 10%, transparent));color:var(--color-text-secondary);font-size:.78rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dip-cascade-step.active .dip-cascade-step-num{background:var(--color-primary);color:#fff}.dip-cascade-step-content{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.dip-cascade-step-content label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:space-between;gap:4px}.dip-cascade-toggle{display:inline-flex;align-items:center;gap:2px;padding:1px 6px;font-size:.62rem;text-transform:none;letter-spacing:0;background:transparent;border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-secondary);cursor:pointer}.dip-cascade-toggle:hover{border-color:var(--color-primary);color:var(--color-primary)}.dip-cascade-toggle .material-symbols-outlined{font-size:12px}.dip-cascade-select{width:100%;padding:5px 8px;border:1px solid var(--color-border);border-radius:5px;background:var(--color-bg);color:var(--color-text);font-size:.82rem;cursor:pointer}.dip-cascade-select:disabled{opacity:.5;cursor:not-allowed}.dip-cascade-eleves{display:flex;flex-direction:column;gap:10px;padding:12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px}.dip-cascade-eleves-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.dip-cascade-eleves-header strong{font-size:.85rem;color:var(--color-text)}.dip-cascade-search{flex:1;min-width:180px;padding:5px 10px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface);color:var(--color-text);font-size:.8rem}.dip-cascade-empty{text-align:center;padding:20px;color:var(--color-text-secondary);font-size:.85rem}.dip-cascade-eleves-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:6px;max-height:300px;overflow-y:auto;padding:4px}.dip-cascade-eleve-chip{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--color-border);border-radius:20px;background:var(--color-surface);color:var(--color-text);cursor:pointer;transition:all .15s;text-align:left;overflow:hidden;font-size:.82rem}.dip-cascade-eleve-chip:hover{border-color:var(--color-primary)}.dip-cascade-eleve-chip.selected{background:color-mix(in srgb,var(--color-primary) 15%,var(--color-surface));border-color:var(--color-primary);color:var(--color-primary);font-weight:600}.dip-cascade-eleve-avatar{width:26px;height:26px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;flex-shrink:0}.dip-cascade-eleve-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dip-cascade-eleve-chip .material-symbols-outlined{font-size:16px;color:var(--color-primary)}.dip-cascade-meta{display:flex;gap:10px;padding:12px;background:color-mix(in srgb,var(--color-primary) 4%,var(--color-bg));border:1px solid color-mix(in srgb,var(--color-primary) 20%,var(--color-border));border-radius:8px}.ppn-root{display:flex;flex-direction:column;gap:1rem;height:100%}.ppn-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.ppn-header h2{margin:0}.ppn-views{display:flex;gap:.25rem}.ppn-views button{font-size:.8rem;padding:.3rem .7rem}.ppn-toolbar{display:flex;gap:.5rem;align-items:center;justify-content:space-between;flex-wrap:wrap}.ppn-nav{display:flex;gap:.5rem;align-items:center}.ppn-nav-label{font-weight:700;font-size:.95rem;min-width:220px;text-align:center}.ppn-actions{display:flex;gap:.5rem;align-items:center}.ppn-grid{border:1px solid var(--color-border);border-radius:var(--radius-md, .5rem);overflow:hidden;position:relative}.ppn-grid-week{display:grid;grid-template-columns:50px repeat(7,1fr)}.ppn-grid-day{display:grid;grid-template-columns:50px 1fr}.ppn-grid-head{padding:.5rem;text-align:center;font-weight:700;font-size:.8rem;background:var(--color-surface, rgba(255, 255, 255, .05));border-bottom:1px solid var(--color-border);border-left:1px solid var(--color-border-light, rgba(255, 255, 255, .05))}.ppn-grid-head.ppn-today{background:var(--color-primary);color:#fff}.ppn-grid-head-corner{padding:.5rem;background:var(--color-surface, rgba(255, 255, 255, .05));border-bottom:1px solid var(--color-border)}.ppn-hour-label{padding:.25rem .4rem;font-size:.7rem;font-family:monospace;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-light, rgba(255, 255, 255, .05));height:60px;display:flex;align-items:flex-start}.ppn-day-col{position:relative;height:60px;border-bottom:1px solid var(--color-border-light, rgba(255, 255, 255, .05));border-left:1px solid var(--color-border-light, rgba(255, 255, 255, .05));cursor:pointer}.ppn-day-col:hover{background:var(--color-bg-hover, rgba(255, 255, 255, .02))}.ppn-evt{position:absolute;left:2px;right:2px;color:#fff;border-radius:.25rem;padding:.2rem .3rem;font-size:.65rem;overflow:hidden;cursor:pointer;z-index:2;line-height:1.2;transition:box-shadow .15s;-webkit-user-select:none;user-select:none}.ppn-evt:hover{box-shadow:0 2px 8px #0000004d;z-index:5}.ppn-evt strong{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ppn-evt-time{opacity:.85;font-size:.6rem}.ppn-evt-resize{position:absolute;bottom:0;left:0;right:0;height:6px;cursor:ns-resize;background:#fff3;border-radius:0 0 .25rem .25rem}.ppn-evt-resize:hover{background:#fff6}.ppn-evt.ppn-evt-dragging{opacity:.6;z-index:10}.ppn-evt-ghost{position:absolute;left:2px;right:2px;border-radius:.25rem;pointer-events:none;z-index:3;opacity:.3;border:2px dashed #fff}.ppn-cluster{position:absolute;left:4px;right:4px;display:flex;align-items:center;justify-content:center;border-radius:.5rem;cursor:pointer;z-index:4;font-size:.75rem;font-weight:700;color:#fff}.ppn-cluster:hover{box-shadow:0 2px 8px #0000004d}.ppn-flower{position:absolute;z-index:100;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md, .5rem);padding:.5rem;box-shadow:var(--shadow-lg, 0 4px 12px rgba(0, 0, 0, .3));max-width:280px}.ppn-flower-item{padding:.3rem .5rem;border-radius:.25rem;cursor:pointer;font-size:.75rem;display:flex;align-items:center;gap:.4rem;margin-bottom:.25rem}.ppn-flower-item:hover{background:var(--color-bg-hover, rgba(255, 255, 255, .1))}.ppn-flower-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ppn-month{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--color-border);border-radius:var(--radius-md, .5rem);overflow:hidden}.ppn-month-head{padding:.4rem;text-align:center;font-weight:700;font-size:.75rem;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.ppn-month-cell{min-height:100px;padding:.3rem;border-bottom:1px solid var(--color-border-light, rgba(255, 255, 255, .05));border-left:1px solid var(--color-border-light, rgba(255, 255, 255, .05));cursor:pointer;position:relative}.ppn-month-cell:hover{background:var(--color-bg-hover, rgba(255, 255, 255, .02))}.ppn-month-cell.ppn-today{background:#3b82f614}.ppn-month-cell.ppn-other-month{opacity:.4}.ppn-month-day{font-size:.75rem;font-weight:700;margin-bottom:.2rem}.ppn-month-evt{font-size:.65rem;padding:.1rem .3rem;border-radius:.2rem;margin-bottom:.15rem;color:#fff;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ppn-month-more{font-size:.65rem;color:var(--color-primary);cursor:pointer;font-weight:600}.ppn-month-more:hover{text-decoration:underline}.ppn-tooltip{position:fixed;z-index:9999;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md, .5rem);padding:.6rem .8rem;box-shadow:var(--shadow-lg, 0 4px 12px rgba(0, 0, 0, .3));pointer-events:none;max-width:280px;font-size:.8rem}.ppn-tooltip-type{display:inline-block;border-radius:.2rem;padding:.1rem .4rem;color:#fff;font-size:.65rem;font-weight:600;margin-bottom:.3rem}.ppn-tooltip-title{font-weight:700;margin-bottom:.2rem}.ppn-tooltip-row{font-size:.75rem;color:var(--color-text-secondary)}.ppn-ctx{position:fixed;z-index:9998;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md, .5rem);padding:.3rem 0;box-shadow:var(--shadow-lg, 0 4px 12px rgba(0, 0, 0, .3));min-width:160px}.ppn-ctx-item{padding:.4rem .8rem;font-size:.8rem;cursor:pointer;display:flex;align-items:center;gap:.5rem}.ppn-ctx-item:hover{background:var(--color-bg-hover, rgba(255, 255, 255, .1))}.ppn-ctx-item.ppn-ctx-danger{color:var(--color-danger)}.ppn-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.ppn-modal{background:var(--color-bg-card, var(--color-surface));border:1px solid var(--color-border);border-radius:var(--radius-md, .5rem);padding:1.25rem;width:560px;max-width:95vw;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg, 0 4px 12px rgba(0, 0, 0, .3))}.ppn-modal-lg{width:700px}.ppn-modal h3{margin:0 0 1rem}.ppn-modal-footer{display:flex;gap:.5rem;margin-top:1rem;justify-content:flex-end}.ppn-modal-footer-left{display:flex;gap:.5rem;margin-top:1rem;justify-content:space-between}.ppn-form{display:flex;flex-direction:column;gap:.75rem}.ppn-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.ppn-form-full{grid-column:1 / -1}.ppn-label{font-size:.75rem;color:var(--color-text-secondary);display:block;margin-bottom:.25rem}.ppn-chips{display:flex;flex-wrap:wrap;gap:.3rem}.ppn-chip{display:inline-flex;align-items:center;gap:.3rem;background:var(--color-bg-elevated, rgba(255, 255, 255, .1));border-radius:1rem;padding:.15rem .5rem .15rem .6rem;font-size:.75rem}.ppn-chip-x{cursor:pointer;font-size:.85rem;opacity:.6;line-height:1}.ppn-chip-x:hover{opacity:1;color:var(--color-danger)}.ppn-exam-banner{background:var(--color-danger);color:#fff;padding:.5rem .75rem;border-radius:.25rem;font-weight:700;font-size:.85rem;display:flex;align-items:center;gap:.5rem}.ppn-salles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.ppn-salle-card{cursor:pointer;border-left:4px solid var(--color-info);transition:box-shadow var(--transition, .15s)}.ppn-salle-card:hover{box-shadow:var(--shadow, 0 2px 8px rgba(0, 0, 0, .2))}.ppn-salle-equip{display:flex;gap:.5rem;margin-top:.5rem;font-size:.8rem}.ppn-salle-equip span{color:var(--color-text-secondary)}.ppn-salle-equip .ppn-equip-on{color:var(--color-success)}.ppn-interv-layout{display:grid;grid-template-columns:320px 1fr;gap:1rem;height:calc(100vh - 200px);min-height:400px}.ppn-interv-list{overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding-right:.5rem}.ppn-interv-card{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:var(--radius-md, .5rem);cursor:pointer;border:1px solid transparent;transition:all .15s}.ppn-interv-card:hover{background:var(--color-bg-hover, rgba(255, 255, 255, .05))}.ppn-interv-card.ppn-active{border-color:var(--color-primary);background:#3b82f614}.ppn-interv-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:#fff;flex-shrink:0}.ppn-interv-info{flex:1;min-width:0}.ppn-interv-name{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ppn-interv-meta{font-size:.75rem;color:var(--color-text-secondary)}.ppn-interv-badges{display:flex;gap:.3rem;margin-top:.2rem;flex-wrap:wrap}.ppn-interv-detail{overflow-y:auto;padding:0 .5rem}.ppn-interv-detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.ppn-interv-detail-avatar{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.3rem;color:#fff;flex-shrink:0}.ppn-interv-detail-name{font-size:1.1rem;font-weight:700}.ppn-interv-detail-sub{font-size:.85rem;color:var(--color-text-secondary)}.ppn-interv-detail-actions{margin-left:auto;display:flex;gap:.5rem}.ppn-interv-section{margin-bottom:1rem}.ppn-interv-section h4{font-size:.85rem;margin-bottom:.5rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.ppn-interv-contact-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem;margin-bottom:.3rem}.ppn-timeline{position:relative;padding-left:1.5rem}.ppn-timeline:before{content:"";position:absolute;left:6px;top:0;bottom:0;width:2px;background:var(--color-border)}.ppn-tl-item{position:relative;margin-bottom:1rem;padding-left:1rem}.ppn-tl-dot{position:absolute;left:-1.5rem;top:4px;width:12px;height:12px;border-radius:50%;border:2px solid var(--color-border);background:var(--color-surface)}.ppn-tl-dot.ppn-tl-diplome{border-color:var(--color-primary);background:var(--color-primary)}.ppn-tl-dot.ppn-tl-recyclage{border-color:var(--color-warning);background:var(--color-warning)}.ppn-tl-dot.ppn-tl-habilitation{border-color:var(--color-success);background:var(--color-success)}.ppn-tl-dot.ppn-tl-certification{border-color:var(--color-info);background:var(--color-info)}.ppn-tl-dot.ppn-tl-formation{border-color:var(--color-accent, #8b5cf6);background:var(--color-accent, #8b5cf6)}.ppn-tl-dot.ppn-tl-autre{border-color:var(--color-text-secondary);background:var(--color-text-secondary)}.ppn-tl-type{display:inline-block;font-size:.65rem;padding:.1rem .4rem;border-radius:.2rem;color:#fff;font-weight:600;margin-bottom:.2rem}.ppn-tl-title{font-weight:600;font-size:.85rem}.ppn-tl-org{font-size:.75rem;color:var(--color-text-secondary)}.ppn-tl-dates{font-size:.75rem;color:var(--color-text-secondary);display:flex;gap:.75rem}.ppn-tl-expired{color:var(--color-danger);font-weight:600}.ppn-tl-delete{font-size:.7rem;cursor:pointer;color:var(--color-text-secondary);opacity:.6}.ppn-tl-delete:hover{opacity:1;color:var(--color-danger)}.ppn-dip-add{display:flex;gap:.4rem;align-items:flex-end;flex-wrap:wrap;margin-top:.75rem;padding:.5rem;background:var(--color-surface);border-radius:var(--radius-md, .5rem);border:1px solid var(--color-border)}.ppn-dip-add input,.ppn-dip-add select{font-size:.8rem;padding:.3rem .4rem}.ppn-geo-wrap{position:relative}.ppn-geo-list{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--color-surface);border:1px solid var(--color-border);border-radius:0 0 var(--radius-md, .5rem) var(--radius-md, .5rem);max-height:200px;overflow-y:auto;box-shadow:var(--shadow, 0 2px 8px rgba(0, 0, 0, .2))}.ppn-geo-item{padding:.4rem .6rem;font-size:.8rem;cursor:pointer}.ppn-geo-item:hover{background:var(--color-bg-hover, rgba(255, 255, 255, .1))}.ppn-map-container{height:200px;border-radius:var(--radius-md, .5rem);overflow:hidden;border:1px solid var(--color-border);margin-top:.5rem}.ppn-ics-steps{display:flex;gap:.5rem;margin-bottom:1rem}.ppn-ics-step{flex:1;text-align:center;padding:.4rem;border-radius:.25rem;font-size:.8rem;font-weight:600;background:var(--color-surface);border:1px solid var(--color-border)}.ppn-ics-step.ppn-ics-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.ppn-ics-drop{border:2px dashed var(--color-border);border-radius:var(--radius-md, .5rem);padding:2rem;text-align:center;cursor:pointer;transition:border-color .2s}.ppn-ics-drop:hover,.ppn-ics-drop.ppn-ics-dragover{border-color:var(--color-primary);background:#3b82f60d}.ppn-ics-table{width:100%;font-size:.8rem;border-collapse:collapse}.ppn-ics-table th,.ppn-ics-table td{padding:.4rem .5rem;border-bottom:1px solid var(--color-border);text-align:left}.ppn-ics-table th{font-weight:600;color:var(--color-text-secondary);font-size:.75rem}.ppn-basket{margin-top:.5rem}.ppn-basket-row{display:flex;align-items:center;gap:.5rem;font-size:.8rem;margin-bottom:.3rem;padding:.25rem 0}.ppn-basket-name{flex:1}.ppn-basket-qty{width:60px}.ppn-basket-rm{cursor:pointer;color:var(--color-text-secondary);font-size:.85rem}.ppn-basket-rm:hover{color:var(--color-danger)}.ppn-holiday-head{background:#ef44441f!important}.ppn-holiday-head:not(.ppn-today){color:#dc2626}.ppn-holiday-label{font-size:.55rem;font-weight:600;color:#dc2626;text-transform:uppercase;letter-spacing:.3px;margin-top:.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ppn-holiday-col{background:#ef44440a}.ppn-holiday-col:hover{background:#ef444414!important}.ppn-holiday-cell{background:#ef44440f}.ppn-holiday-cell:hover{background:#ef44441a!important}.ppn-holiday-tag{font-size:.55rem;font-weight:600;color:#dc2626;background:#ef44441f;padding:.05rem .25rem;border-radius:.2rem;margin-bottom:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ppn-dup-source{padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md, .5rem)}.ppn-dup-source-badge{display:inline-block;color:#fff;padding:.25rem .6rem;border-radius:.25rem;font-weight:600;font-size:.85rem}.ppn-dup-days{display:flex;gap:.4rem;margin-top:.3rem}.ppn-dup-day-btn{display:flex;align-items:center;justify-content:center;width:48px;height:36px;border-radius:.4rem;cursor:pointer;font-size:.8rem;font-weight:600;border:2px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);transition:all .15s;-webkit-user-select:none;user-select:none}.ppn-dup-day-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.ppn-dup-day-btn.ppn-dup-day-on{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}[data-theme=light] .ppn-grid,:root .ppn-grid{border-color:#bdbdbd}[data-theme=light] .ppn-grid-head,:root .ppn-grid-head{border-bottom-color:#bdbdbd;border-left-color:#d0d0d0;background:#f0f4f8;color:#424242}[data-theme=light] .ppn-grid-head-corner,:root .ppn-grid-head-corner{border-bottom-color:#bdbdbd;background:#f0f4f8}[data-theme=light] .ppn-hour-label,:root .ppn-hour-label{border-bottom-color:#d0d0d0;color:#616161}[data-theme=light] .ppn-day-col,:root .ppn-day-col{border-bottom-color:#d0d0d0;border-left-color:#d0d0d0}[data-theme=light] .ppn-day-col:hover,:root .ppn-day-col:hover{background:#1976d20a}[data-theme=light] .ppn-month,:root .ppn-month{border-color:#bdbdbd}[data-theme=light] .ppn-month-head,:root .ppn-month-head{background:#f0f4f8;color:#424242;border-bottom-color:#bdbdbd}[data-theme=light] .ppn-month-cell,:root .ppn-month-cell{border-bottom-color:#d0d0d0;border-left-color:#d0d0d0}[data-theme=light] .ppn-month-cell:hover,:root .ppn-month-cell:hover{background:#1976d20a}[data-theme=light] .ppn-month-cell.ppn-today,:root .ppn-month-cell.ppn-today{background:#1976d21a}[data-theme=light] .ppn-evt,:root .ppn-evt{box-shadow:0 1px 3px #0000002e}[data-theme=light] .ppn-evt:hover,:root .ppn-evt:hover{box-shadow:0 2px 8px #00000040}[data-theme=light] .ppn-tooltip,:root .ppn-tooltip{border-color:#bdbdbd;box-shadow:0 4px 16px #00000024}[data-theme=light] .ppn-ctx,:root .ppn-ctx{border-color:#bdbdbd;box-shadow:0 4px 16px #00000024}[data-theme=light] .ppn-modal,:root .ppn-modal{border-color:#bdbdbd;box-shadow:0 8px 24px #00000029}[data-theme=light] .ppn-salle-card,:root .ppn-salle-card{border:1px solid #d0d0d0;border-left-width:4px}[data-theme=light] .ppn-interv-card,:root .ppn-interv-card{border:1px solid #e0e0e0}[data-theme=light] .ppn-interv-card.ppn-active,:root .ppn-interv-card.ppn-active{border-color:var(--color-primary)}[data-theme=light] .ppn-timeline:before,:root .ppn-timeline:before{background:#bdbdbd}[data-theme=light] .ppn-tl-dot,:root .ppn-tl-dot{border-width:3px}[data-theme=light] .ppn-ics-drop,:root .ppn-ics-drop{border-color:#bdbdbd}[data-theme=light] .ppn-ics-table th,:root .ppn-ics-table th{background:#f5f5f5}[data-theme=light] .ppn-ics-table td,:root .ppn-ics-table td{border-bottom-color:#d0d0d0}[data-theme=light] .ppn-ics-table th,:root .ppn-ics-table th{border-bottom-color:#bdbdbd}[data-theme=light] .ppn-dip-add,:root .ppn-dip-add{border-color:#d0d0d0;background:#fafafa}[data-theme=light] .ppn-map-container,:root .ppn-map-container{border-color:#bdbdbd}[data-theme=light] .ppn-chip,:root .ppn-chip{background:#e8eef4;color:#37474f;border:1px solid #cfd8dc}[data-theme=dark] .ppn-grid{border-width:2px;border-color:#555}[data-theme=dark] .ppn-grid-head{border-bottom-width:2px;border-left-width:2px;border-bottom-color:#555;border-left-color:#444}[data-theme=dark] .ppn-grid-head-corner{border-bottom-width:2px;border-bottom-color:#555}[data-theme=dark] .ppn-hour-label{border-bottom-width:2px;border-bottom-color:#3a3a3a}[data-theme=dark] .ppn-day-col{border-bottom-width:2px;border-left-width:2px;border-bottom-color:#3a3a3a;border-left-color:#3a3a3a}[data-theme=dark] .ppn-month{border-width:2px;border-color:#555}[data-theme=dark] .ppn-month-head{border-bottom-width:2px;border-bottom-color:#555}[data-theme=dark] .ppn-month-cell{border-bottom-width:2px;border-left-width:2px;border-bottom-color:#3a3a3a;border-left-color:#3a3a3a}[data-theme=dark] .ppn-timeline:before{width:3px}[data-theme=dark] .ppn-tl-dot{border-width:3px;width:14px;height:14px}[data-theme=dark] .ppn-salle-card{border-width:2px;border-left-width:5px}[data-theme=dark] .ppn-interv-card,[data-theme=dark] .ppn-interv-card.ppn-active,[data-theme=dark] .ppn-modal,[data-theme=dark] .ppn-tooltip,[data-theme=dark] .ppn-ctx,[data-theme=dark] .ppn-flower{border-width:2px}[data-theme=dark] .ppn-ics-drop{border-width:3px}[data-theme=dark] .ppn-ics-table th,[data-theme=dark] .ppn-ics-table td{border-bottom-width:2px}.ppn-views-group{display:flex;gap:.25rem;align-items:center;flex-wrap:wrap}.ppn-views-sep{color:var(--color-border);font-size:1.1rem;margin:0 .15rem;-webkit-user-select:none;user-select:none}.ppn-btn-sm{font-size:.7rem!important;padding:.15rem .4rem!important}.ppn-resource-filter{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;padding:.5rem 0}.ppn-resource-filter select{font-size:.8rem;padding:.3rem .5rem;max-width:200px}.ppn-resource-chips{display:flex;gap:.3rem;flex-wrap:wrap;flex:1;min-width:0}.ppn-resource-empty{color:var(--color-text-secondary);text-align:center;padding:3rem 1rem;font-size:.9rem}.ppn-resource-grid{display:grid;border:1px solid var(--color-border);border-radius:var(--radius-md, .5rem);overflow:auto;max-height:calc(100vh - 250px)}.ppn-resource-corner{padding:.5rem;text-align:center;font-weight:700;font-size:.75rem;background:var(--color-surface, rgba(255, 255, 255, .05));border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);position:sticky;top:0;left:0;z-index:3;color:var(--color-text-secondary)}.ppn-resource-label{display:flex;align-items:center;gap:.5rem;padding:.5rem;border-bottom:1px solid var(--color-border-light, rgba(255, 255, 255, .05));border-right:1px solid var(--color-border);cursor:pointer;position:sticky;left:0;background:var(--color-bg-card, var(--color-surface));z-index:2;min-height:60px;transition:background .15s}.ppn-resource-label:hover{background:var(--color-bg-hover, rgba(255, 255, 255, .05))}.ppn-resource-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.7rem;color:#fff;flex-shrink:0}.ppn-resource-info{flex:1;min-width:0}.ppn-resource-name{font-weight:600;font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ppn-resource-sub{font-size:.65rem;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ppn-resource-cell{border-bottom:1px solid var(--color-border-light, rgba(255, 255, 255, .05));border-left:1px solid var(--color-border-light, rgba(255, 255, 255, .05));padding:.2rem;min-height:60px;cursor:pointer;display:flex;flex-direction:column;gap:.15rem}.ppn-resource-cell:hover{background:var(--color-bg-hover, rgba(255, 255, 255, .02))}.ppn-resource-evt{background:var(--color-bg-elevated, rgba(255, 255, 255, .08));border-left:3px solid var(--color-primary);border-radius:.2rem;padding:.15rem .3rem;font-size:.65rem;cursor:pointer;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;transition:box-shadow .15s}.ppn-resource-evt:hover{box-shadow:0 1px 4px #0003}.ppn-resource-evt-time{font-weight:600;margin-right:.3rem;opacity:.8}.ppn-resource-evt-title{opacity:.9}.ppn-detail-panel{position:fixed;right:0;top:0;bottom:0;width:380px;max-width:90vw;background:var(--color-bg-card, var(--color-surface));border-left:1px solid var(--color-border);box-shadow:-4px 0 16px #0003;padding:1.25rem;overflow-y:auto;z-index:1001;animation:ppn-slide-in .2s ease-out}@keyframes ppn-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.ppn-detail-close{display:flex;justify-content:flex-end;margin-bottom:.5rem}.ppn-detail-hero{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border);border-left:4px solid var(--color-primary);padding-left:.75rem}.ppn-detail-hero h3{margin:0;font-size:1.1rem}.ppn-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.75rem}.ppn-detail-stat{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md, .5rem);padding:.5rem;text-align:center}.ppn-detail-stat-val{font-size:1.1rem;font-weight:700}.ppn-detail-stat-label{font-size:.65rem;color:var(--color-text-secondary);text-transform:uppercase}.ppn-detail-row{font-size:.85rem;margin-bottom:.4rem;padding:.25rem 0}.ppn-detail-equip{display:flex;gap:.5rem;flex-wrap:wrap;font-size:.8rem;margin-bottom:.5rem}[data-theme=light] .ppn-resource-grid,:root .ppn-resource-grid{border-color:#bdbdbd}[data-theme=light] .ppn-resource-corner,:root .ppn-resource-corner{background:#f0f4f8;border-bottom-color:#bdbdbd;border-right-color:#bdbdbd;color:#616161}[data-theme=light] .ppn-resource-label,:root .ppn-resource-label{border-bottom-color:#d0d0d0;border-right-color:#bdbdbd;background:#fafafa}[data-theme=light] .ppn-resource-label:hover,:root .ppn-resource-label:hover{background:#eef2f7}[data-theme=light] .ppn-resource-cell,:root .ppn-resource-cell{border-bottom-color:#d0d0d0;border-left-color:#d0d0d0}[data-theme=light] .ppn-resource-cell:hover,:root .ppn-resource-cell:hover{background:#1976d20a}[data-theme=light] .ppn-resource-evt,:root .ppn-resource-evt{background:#f5f5f5;color:#333}[data-theme=light] .ppn-detail-panel,:root .ppn-detail-panel{border-left-color:#bdbdbd;box-shadow:-4px 0 16px #0000001a}[data-theme=light] .ppn-detail-stat,:root .ppn-detail-stat{border-color:#d0d0d0;background:#f5f5f5}[data-theme=dark] .ppn-resource-grid{border-width:2px;border-color:#555}[data-theme=dark] .ppn-resource-corner,[data-theme=dark] .ppn-resource-label{border-bottom-width:2px;border-right-width:2px}[data-theme=dark] .ppn-resource-cell{border-bottom-width:2px;border-left-width:2px}[data-theme=dark] .ppn-detail-panel{border-left-width:2px}} [data-theme="dark"] .ppn-dip-add{border-width:2px}[data-theme=dark] .ppn-map-container{border-width:2px}[data-theme=dark] .ppn-chip{border:1px solid #555}[data-theme=light] .ppn-holiday-head,:root .ppn-holiday-head{background:#dc26261a!important}[data-theme=light] .ppn-holiday-label,:root .ppn-holiday-label{color:#b91c1c}[data-theme=light] .ppn-holiday-col,:root .ppn-holiday-col{background:#dc26260a}[data-theme=light] .ppn-holiday-tag,:root .ppn-holiday-tag{color:#b91c1c;background:#dc26261a}[data-theme=dark] .ppn-holiday-head{background:#ef444426!important}[data-theme=dark] .ppn-holiday-label{color:#f87171}[data-theme=dark] .ppn-holiday-col{background:#ef44440f}[data-theme=dark] .ppn-holiday-tag{color:#fca5a5;background:#ef44442e}.presence-session-card{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:box-shadow var(--transition)}.presence-session-card:hover{box-shadow:var(--shadow)}.presence-session-left{flex-shrink:0}.presence-session-center{flex:1;min-width:0}.presence-session-center h4{font-size:.95rem;margin-bottom:2px}.presence-session-meta{font-size:.8rem;color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap}.presence-session-right{display:flex;flex-direction:column;align-items:flex-end;gap:var(--sp-2);flex-shrink:0}.presence-session-actions{display:flex;gap:var(--sp-1);align-items:center}.presence-creneau-badge{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-md);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:#fff}.presence-creneau-badge.creneau-matin{background:var(--color-info)}.presence-creneau-badge.creneau-apres_midi{background:var(--color-warning)}.presence-creneau-badge.creneau-journee{background:var(--color-primary)}.presence-sig-count{display:inline-flex;align-items:center;gap:var(--sp-1);font-size:.85rem;font-weight:600}.presence-open-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}.presence-open-dot.is-open{background:var(--color-success);box-shadow:0 0 6px var(--color-success)}.presence-open-dot.is-closed{background:var(--color-text-tertiary)}.presence-date-group{margin-bottom:var(--sp-4)}.presence-date-group-header{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:var(--sp-2);padding-bottom:var(--sp-1);border-bottom:1px solid var(--color-border-subtle)}.presence-date-group-cards{display:flex;flex-direction:column;gap:var(--sp-2)}.presence-week-nav{display:flex;align-items:center;gap:var(--sp-2)}.presence-week-label{font-size:.9rem;font-weight:500;min-width:200px;text-align:center}.presence-qr-modal{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3)}.presence-qr-modal .qr-wrapper{background:#fff;padding:var(--sp-4);border-radius:var(--radius-md);display:inline-flex}.presence-qr-modal .qr-url{padding:var(--sp-3);background:var(--color-surface-variant);border-radius:var(--radius);font-family:monospace;font-size:.78rem;word-break:break-all;text-align:center;max-width:100%;color:var(--color-text-secondary)}.presence-qr-modal .qr-expiry{font-size:.8rem;color:var(--color-warning);display:flex;align-items:center;gap:var(--sp-1)}.presence-feuille-table{width:100%;border-collapse:separate;border-spacing:0}.presence-feuille-table th{text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-secondary);padding:var(--sp-2) var(--sp-3);border-bottom:2px solid var(--color-border);background:var(--color-surface-variant);white-space:nowrap}.presence-feuille-table td{padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--color-border-subtle);font-size:.85rem;vertical-align:middle}.presence-sig-thumb{width:80px;height:30px;object-fit:contain;border:1px solid var(--color-border);border-radius:3px;background:#fff}.presence-gps-cell{position:relative;cursor:default}.presence-gps-cell .gps-tooltip{display:none;position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--color-surface-variant);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--sp-1) var(--sp-2);font-size:.7rem;font-family:monospace;white-space:nowrap;z-index:10;box-shadow:var(--shadow-sm)}.presence-gps-cell:hover .gps-tooltip{display:block}.presence-feuille-header{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2);margin-bottom:var(--sp-4);padding:var(--sp-3);background:var(--color-surface-variant);border-radius:var(--radius)}.presence-feuille-header dt{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-tertiary)}.presence-feuille-header dd{font-size:.85rem;margin:0 0 var(--sp-2) 0}.modal-content.modal-wide{width:720px}.qualiopi-panel{padding:12px;display:flex;flex-direction:column;gap:16px}.qualiopi-toast{position:fixed;top:16px;right:16px;padding:10px 18px;border-radius:6px;font-size:.82rem;color:#fff;z-index:9999;animation:qualiopi-slide-in .25s ease-out}.qualiopi-toast.success{background:#10b981}.qualiopi-toast.error{background:#ef4444}.qualiopi-toast.info{background:#3b82f6}@keyframes qualiopi-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.qualiopi-btn{padding:5px 12px;font-size:.78rem;background:var(--bg-surface, var(--bg-secondary));color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:background .15s;white-space:nowrap}.qualiopi-btn:hover{background:var(--bg-hover)}.qualiopi-btn:disabled{opacity:.5;cursor:not-allowed}.qualiopi-btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.qualiopi-btn-primary:hover{opacity:.9}.qualiopi-btn-danger{background:var(--color-danger, #ef4444);color:#fff;border-color:var(--color-danger, #ef4444)}.qualiopi-btn-danger:hover{opacity:.9}.qualiopi-btn-success{background:#10b981;color:#fff;border-color:#10b981}.qualiopi-btn-success:hover{opacity:.9}.qualiopi-icon-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.qualiopi-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.qualiopi-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.qualiopi-toolbar-spacer{flex:1}.qualiopi-filter-select{min-width:180px;font-size:.82rem;padding:4px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-surface, var(--bg-secondary));color:var(--text-primary)}.qualiopi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px}.qualiopi-card{background:var(--bg-surface, var(--bg-secondary));border:1px solid var(--border-color);border-radius:8px;overflow:hidden;transition:box-shadow .15s}.qualiopi-card:hover{box-shadow:0 2px 8px #00000014}.qualiopi-card-top{display:flex;align-items:center;gap:10px;padding:12px 14px}.qualiopi-card-icon{width:38px;height:38px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.qualiopi-card-icon .material-symbols-outlined{font-size:20px}.qualiopi-card-info{flex:1;min-width:0}.qualiopi-card-info h4{margin:0;font-size:.88rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qualiopi-card-info small{font-size:.72rem;color:var(--text-secondary)}.qualiopi-card-body{padding:8px 14px 10px;font-size:.78rem;color:var(--text-secondary);display:flex;flex-wrap:wrap;gap:6px}.qualiopi-card-footer{display:flex;justify-content:flex-end;gap:4px;padding:6px 14px 10px;border-top:1px solid var(--border-color)}.qualiopi-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.65rem;font-weight:600;color:#fff}.qualiopi-badge-outline{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.65rem;font-weight:600;background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.qualiopi-table{width:100%;border-collapse:collapse;font-size:.85rem}.qualiopi-table thead tr{border-bottom:2px solid var(--border-color)}.qualiopi-table th{padding:8px;text-align:left;font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.qualiopi-table td{padding:8px}.qualiopi-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .1s}.qualiopi-table tbody tr:hover{background:var(--bg-hover)}.qualiopi-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.qualiopi-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;width:600px;max-width:95vw;max-height:85vh;overflow:auto;padding:20px}.qualiopi-modal-wide{width:750px}.qualiopi-modal h3{margin:0 0 16px;font-size:1rem}.qualiopi-modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.qualiopi-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.qualiopi-form-grid .full{grid-column:1/-1}.qualiopi-label{font-size:.72rem;color:var(--text-secondary);display:block;margin-bottom:3px;text-transform:uppercase;letter-spacing:.03em}.qualiopi-input,.qualiopi-select{width:100%;font-size:.82rem;padding:5px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-surface, var(--bg-secondary));color:var(--text-primary)}.qualiopi-select{cursor:pointer}.qualiopi-textarea{width:100%;font-size:.82rem;padding:5px 8px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-surface, var(--bg-secondary));color:var(--text-primary);resize:vertical}.qualiopi-checkbox-row{display:flex;gap:16px;align-items:center;padding-top:8px;grid-column:1 / -1}.qualiopi-checkbox-label{font-size:.82rem;display:flex;align-items:center;gap:4px;cursor:pointer}.qualiopi-champs-header{display:flex;justify-content:space-between;align-items:center;margin-top:16px;margin-bottom:8px}.qualiopi-champs-list{display:flex;flex-direction:column;gap:8px}.qualiopi-champ-row{border:1px solid var(--border-color);border-radius:6px;padding:8px;display:grid;grid-template-columns:1fr auto auto auto;gap:8px;align-items:center}.qualiopi-champ-row .qualiopi-input,.qualiopi-champ-row .qualiopi-select{font-size:.8rem}.qualiopi-champ-row .qualiopi-select{min-width:100px}.qualiopi-champ-required{font-size:.75rem;display:flex;align-items:center;gap:3px}.qualiopi-champ-options{grid-column:1 / -1}.qualiopi-champ-options .qualiopi-input{width:100%}.qualiopi-qr-modal{width:440px;text-align:center}.qualiopi-qr-url{background:var(--bg-surface, var(--bg-secondary));padding:12px;border-radius:6px;word-break:break-all;font-size:.85rem;font-family:monospace;margin-bottom:12px}.qualiopi-qr-actions{display:flex;gap:8px;justify-content:center}.qualiopi-empty{text-align:center;padding:32px;color:var(--text-secondary);font-size:.85rem}.qualiopi-empty .material-symbols-outlined{font-size:48px;opacity:.3;display:block;margin-bottom:8px}.qualiopi-error{color:var(--color-danger, #ef4444);font-size:.82rem;margin-bottom:8px}.qualiopi-types-section{background:var(--bg-surface, var(--bg-secondary));border:1px solid var(--border-color);border-radius:8px;padding:16px}.qualiopi-types-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.qualiopi-types-header h4{margin:0;font-size:.85rem;display:flex;align-items:center;gap:6px}.qualiopi-type-form{display:flex;gap:8px;align-items:center;margin-bottom:12px;flex-wrap:wrap}.qualiopi-type-form .qualiopi-input{width:auto;font-size:.8rem}.qualiopi-types-list{display:flex;flex-direction:column;gap:4px}.qualiopi-type-row{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:4px;font-size:.8rem;transition:background .1s}.qualiopi-type-row:hover{background:var(--bg-hover)}.qualiopi-type-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.qualiopi-type-code{font-family:monospace;font-size:.75rem;color:var(--text-secondary);min-width:120px}.qualiopi-cascade{background:linear-gradient(135deg,color-mix(in srgb,var(--color-primary) 6%,var(--color-surface)),var(--color-surface));border:1px solid color-mix(in srgb,var(--color-primary) 20%,var(--color-border));border-radius:12px;padding:16px 20px;display:flex;flex-direction:column;gap:14px}.qualiopi-cascade-header{display:flex;align-items:center;gap:10px}.qualiopi-cascade-header .material-symbols-outlined{font-size:24px;color:var(--color-primary)}.qualiopi-cascade-header h3{margin:0;font-size:1rem;font-weight:700;color:var(--color-text)}.qualiopi-cascade-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.qualiopi-cascade-step{display:flex;gap:10px;padding:10px 12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;transition:all .2s}.qualiopi-cascade-step.active{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 8%,var(--color-bg))}.qualiopi-cascade-step-num{width:24px;height:24px;border-radius:50%;background:var(--color-bg-secondary, color-mix(in srgb, var(--color-text) 10%, transparent));color:var(--color-text-secondary);font-size:.78rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.qualiopi-cascade-step.active .qualiopi-cascade-step-num{background:var(--color-primary);color:#fff}.qualiopi-cascade-step-content{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.qualiopi-cascade-step-content label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:space-between;gap:4px}.qualiopi-cascade-toggle{display:inline-flex;align-items:center;gap:2px;padding:1px 6px;font-size:.62rem;text-transform:none;letter-spacing:0;background:transparent;border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-secondary);cursor:pointer}.qualiopi-cascade-toggle:hover{border-color:var(--color-primary);color:var(--color-primary)}.qualiopi-cascade-toggle .material-symbols-outlined{font-size:12px}.qualiopi-cascade-select{width:100%;padding:5px 8px;border:1px solid var(--color-border);border-radius:5px;background:var(--color-bg);color:var(--color-text);font-size:.82rem;cursor:pointer}.qualiopi-cascade-select:disabled{opacity:.5;cursor:not-allowed}.qualiopi-cascade-eleves{display:flex;flex-direction:column;gap:10px;padding:12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px}.qualiopi-cascade-eleves-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.qualiopi-cascade-eleves-header strong{font-size:.85rem;color:var(--color-text)}.qualiopi-cascade-search{flex:1;min-width:180px;padding:5px 10px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface);color:var(--color-text);font-size:.8rem}.qualiopi-cascade-empty{text-align:center;padding:20px;color:var(--color-text-secondary);font-size:.85rem}.qualiopi-cascade-eleves-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:6px;max-height:320px;overflow-y:auto;padding:4px}.qualiopi-cascade-eleve-chip{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--color-border);border-radius:20px;background:var(--color-surface);color:var(--color-text);cursor:pointer;transition:all .15s;text-align:left;overflow:hidden;font-size:.82rem}.qualiopi-cascade-eleve-chip:hover{border-color:var(--color-primary)}.qualiopi-cascade-eleve-chip.selected{background:color-mix(in srgb,var(--color-primary) 15%,var(--color-surface));border-color:var(--color-primary);color:var(--color-primary);font-weight:600}.qualiopi-cascade-eleve-avatar{width:26px;height:26px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;flex-shrink:0}.qualiopi-cascade-eleve-chip.selected .qualiopi-cascade-eleve-avatar{background:var(--color-primary)}.qualiopi-cascade-eleve-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qualiopi-cascade-eleve-chip .material-symbols-outlined{font-size:16px;color:var(--color-primary)}.qualiopi-stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.qualiopi-stat-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid;border-radius:10px;transition:transform .15s,box-shadow .15s}.qualiopi-stat-card:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.qualiopi-stat-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.qualiopi-stat-icon .material-symbols-outlined{color:#fff;font-size:20px}.qualiopi-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.1}.qualiopi-stat-label{font-size:.72rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.qualiopi-toolbar-modern{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;margin-bottom:14px;flex-wrap:wrap}.qualiopi-search{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;min-width:200px;max-width:280px}.qualiopi-search .material-symbols-outlined{color:var(--color-text-secondary);font-size:18px}.qualiopi-search input{flex:1;border:none;background:transparent;color:var(--color-text);font-size:.82rem;outline:none;min-width:0}.qualiopi-search button{border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;padding:0;display:flex}.qualiopi-type-chips{display:flex;gap:4px;flex-wrap:wrap}.qualiopi-type-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border:1px solid var(--color-border);border-radius:14px;background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.72rem;font-weight:600;transition:all .15s}.qualiopi-type-chip:hover{border-color:var(--color-primary)}.qualiopi-type-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.qualiopi-type-chip .material-symbols-outlined{font-size:14px}.qualiopi-card-modern{display:flex;flex-direction:column;gap:8px;padding:16px;background:var(--color-surface);border:1px solid var(--color-border);border-top:4px solid;border-radius:10px;transition:all .15s}.qualiopi-card-modern:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.qualiopi-card-modern-header{display:flex;justify-content:space-between;align-items:flex-start}.qualiopi-card-modern-icon{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center}.qualiopi-card-modern-icon .material-symbols-outlined{color:#fff;font-size:20px}.qualiopi-card-modern-title{margin:0;font-size:.95rem;font-weight:700;color:var(--color-text);line-height:1.3}.qualiopi-card-modern-desc{margin:0;font-size:.78rem;color:var(--color-text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.qualiopi-card-modern-meta{display:flex;gap:12px;font-size:.72rem;color:var(--color-text-secondary);flex-wrap:wrap}.qualiopi-card-modern-meta span{display:inline-flex;align-items:center;gap:3px}.qualiopi-card-modern-meta .material-symbols-outlined{font-size:13px}.qualiopi-card-modern-tags{display:flex;flex-wrap:wrap;gap:4px}.qualiopi-card-modern-footer{display:flex;align-items:center;gap:6px;margin-top:8px;padding-top:10px;border-top:1px solid var(--color-border)}.qualiopi-view-toggle{display:flex;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.qualiopi-view-btn{display:flex;align-items:center;justify-content:center;padding:6px 10px;border:none;background:var(--color-bg);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.qualiopi-view-btn:hover{color:var(--color-text)}.qualiopi-view-btn.active{background:var(--color-primary);color:#fff}.qualiopi-list-rows{display:flex;flex-direction:column;gap:6px}.qualiopi-list-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;transition:all .15s}.qualiopi-list-row:hover{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 4%,var(--color-surface))}.qualiopi-list-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.qualiopi-list-icon .material-symbols-outlined{color:#fff;font-size:18px}.qualiopi-list-main{flex:1;min-width:0}.qualiopi-list-title{font-size:.88rem;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qualiopi-list-desc{font-size:.72rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.qualiopi-list-meta-item{display:inline-flex;align-items:center;gap:3px;font-size:.72rem;color:var(--color-text-secondary);white-space:nowrap}.qualiopi-list-meta-item .material-symbols-outlined{font-size:13px}.qualiopi-list-actions{display:flex;gap:4px;flex-shrink:0}.mtp-panel{display:flex;flex-direction:column;gap:16px}.mtp-toast{position:fixed;top:16px;right:16px;z-index:9999;padding:10px 18px;border-radius:8px;font-size:.82rem;font-weight:500;color:#fff;box-shadow:0 4px 16px #00000040;animation:mtp-slide-in .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.mtp-toast.success{background:#10b981}.mtp-toast.error{background:#ef4444}@keyframes mtp-slide-in{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.mtp-btn{padding:6px 14px;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-secondary);color:var(--text-primary);font-size:.78rem;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s;display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.mtp-btn:hover{background:var(--bg-hover)}.mtp-btn-primary{background:#3b82f6;color:#fff;border-color:#3b82f6}.mtp-btn-primary:hover{background:#2563eb;box-shadow:0 2px 8px #3b82f659}.mtp-btn-danger{background:#ef4444;color:#fff;border-color:#ef4444}.mtp-btn-danger:hover{background:#dc2626}.mtp-btn-success{background:#10b981;color:#fff;border-color:#10b981}.mtp-btn-success:hover{background:#059669;box-shadow:0 2px 8px #10b98159}.mtp-icon-btn{width:30px;height:30px;padding:0;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s}.mtp-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-secondary)}.mtp-icon-btn--danger:hover{background:#ef44441f;border-color:#ef4444;color:#ef4444}.mtp-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}.mtp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:12px}.mtp-card{padding:0;border-radius:.5rem;background:var(--color-bg-elevated, var(--bg-secondary));border:1px solid var(--color-border, var(--border-color));display:flex;flex-direction:column;overflow:hidden;transition:border-color .2s,box-shadow .2s}.mtp-card:hover{border-color:#3b82f680;box-shadow:0 2px 12px #00000026}.mtp-card-top{display:flex;align-items:center;gap:10px;padding:14px 16px 10px}.mtp-card-icon{width:38px;height:38px;border-radius:.5rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mtp-card-icon .material-symbols-outlined{font-size:1.15rem;color:#fff}.mtp-card-info{flex:1;min-width:0}.mtp-card-info strong{font-size:.88rem;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mtp-card-subject{font-size:.75rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.mtp-badge{font-size:.6rem;padding:2px 8px;border-radius:99px;color:#fff;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;font-weight:600}.mtp-card-body{padding:0 16px 10px}.mtp-card-meta{font-size:.72rem;color:var(--text-secondary);display:flex;flex-wrap:wrap;gap:10px;align-items:center}.mtp-card-meta span{display:inline-flex;align-items:center;gap:3px}.mtp-card-footer{display:flex;gap:6px;padding:8px 16px;border-top:1px solid var(--color-border, var(--border-color));background:#00000005}.mtp-editor{display:flex;flex-direction:column;gap:14px}.mtp-editor-meta{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;padding:14px 16px;background:var(--color-bg-elevated, var(--bg-secondary));border-radius:.5rem;border:1px solid var(--color-border, var(--border-color))}.mtp-editor-meta>div{display:flex;flex-direction:column;gap:4px}.mtp-editor-meta label{font-size:.7rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.3px}.mtp-editor-meta input,.mtp-editor-meta select{padding:7px 10px;font-size:.82rem;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-primary);color:var(--text-primary);transition:border-color .15s}.mtp-editor-meta input:focus,.mtp-editor-meta select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f626}.mtp-var-section{padding:14px 16px;background:var(--color-bg-elevated, var(--bg-secondary));border-radius:.5rem;border:1px solid var(--color-border, var(--border-color))}.mtp-var-section h4{font-size:.75rem;color:var(--text-secondary);margin:0 0 4px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.mtp-var-section p{font-size:.72rem;color:var(--text-secondary);margin:0 0 8px}.mtp-var-groups{display:flex;flex-direction:column;gap:8px}.mtp-var-group-label{font-size:.65rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.mtp-var-chips{display:flex;flex-wrap:wrap;gap:5px}.mtp-var-chip{padding:4px 10px;font-size:.72rem;font-family:JetBrains Mono,Fira Code,Courier New,monospace;background:#7c3aed0f;color:#7c3aed;border:1px solid rgba(124,58,237,.15);border-radius:99px;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.mtp-var-chip:hover{background:#7c3aed26;border-color:#7c3aed66}.mtp-var-chip.active{background:#7c3aed;color:#fff;border-color:#7c3aed;box-shadow:0 1px 4px #7c3aed4d}.mtp-body-wrap{display:flex;flex-direction:column;gap:4px}.mtp-body-wrap>label{font-size:.7rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.3px;display:flex;align-items:center;gap:6px}.mtp-body-wrap>label .mtp-hint{font-weight:400;text-transform:none;letter-spacing:0;opacity:.7;font-size:.68rem}.mtp-body-wrap textarea{min-height:220px;padding:12px 14px;font-size:.85rem;line-height:1.6;border:1px solid var(--border-color);border-radius:.5rem;background:var(--bg-primary);color:var(--text-primary);resize:vertical;font-family:inherit;transition:border-color .15s}.mtp-body-wrap textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f626}.mtp-body-wrap input[type=text],.mtp-body-wrap input:not([type]){padding:8px 12px;font-size:.85rem;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-primary);color:var(--text-primary);transition:border-color .15s}.mtp-body-wrap input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f626}.mtp-insert-row{display:flex;gap:4px;flex-wrap:wrap}.mtp-insert-pill{padding:2px 8px;font-size:.65rem;font-family:JetBrains Mono,Fira Code,Courier New,monospace;background:#7c3aed14;color:#7c3aed;border:1px solid rgba(124,58,237,.2);border-radius:99px;cursor:pointer;transition:all .15s}.mtp-insert-pill:hover{background:#7c3aed33;border-color:#7c3aed}.mtp-preview-card{padding:16px;border-radius:.5rem;background:var(--color-bg-elevated, var(--bg-secondary));border:1px solid var(--color-border, var(--border-color))}.mtp-preview-card h4{margin:0 0 10px;font-size:.82rem;display:flex;align-items:center;gap:6px}.mtp-preview-body{padding:16px;background:#fff;color:#111;border-radius:.375rem;font-size:.85rem;line-height:1.65;min-height:120px;border:1px solid #e5e7eb;box-shadow:inset 0 1px 3px #0000000d}.mtp-send-view{display:flex;flex-direction:column;gap:14px}.mtp-send-controls{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;padding:14px 16px;background:var(--color-bg-elevated, var(--bg-secondary));border-radius:.5rem;border:1px solid var(--color-border, var(--border-color))}.mtp-send-controls>div{display:flex;flex-direction:column;gap:4px}.mtp-send-controls label{font-size:.7rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.3px}.mtp-send-controls select{padding:7px 10px;font-size:.82rem;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-primary);color:var(--text-primary);min-width:240px}.mtp-send-controls select:focus{border-color:#3b82f6;outline:none}.mtp-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mtp-modal{width:520px;max-width:95vw;max-height:85vh;overflow-y:auto;padding:20px 24px;border-radius:.75rem;background:var(--bg-primary);border:1px solid var(--border-color);box-shadow:0 8px 32px #0000004d}.mtp-modal h3{margin:0 0 12px;font-size:1rem}.mtp-recipient-header{display:flex;align-items:center;gap:8px;font-size:.82rem}.mtp-recipient-count{color:var(--text-secondary);font-size:.78rem}.mtp-recipient-list{max-height:240px;overflow-y:auto;border:1px solid var(--border-color);border-radius:.5rem;padding:4px;display:flex;flex-direction:column;gap:2px}.mtp-recipient-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:.375rem;font-size:.8rem;transition:background .1s}.mtp-recipient-row:hover{background:var(--bg-hover)}.mtp-recipient-row input[type=checkbox]{accent-color:#3b82f6}.mtp-rules{display:flex;flex-direction:column;gap:8px;padding:14px 16px;background:var(--color-bg-elevated, var(--bg-secondary));border-radius:.5rem;border:1px solid var(--color-border, var(--border-color))}.mtp-rules-title{display:flex;align-items:center;gap:6px;font-size:.82rem;font-weight:600;margin:0}.mtp-rule-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-primary);border-radius:.375rem;border:1px solid var(--border-color);font-size:.78rem;transition:border-color .15s}.mtp-rule-row:hover{border-color:var(--text-secondary)}.mtp-rule-row .mtp-badge{font-size:.58rem}.mtp-rule-status{margin-left:auto;font-size:.72rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:99px;transition:background .15s}.mtp-rule-status--active{color:#10b981;background:#10b9811a}.mtp-rule-status--active:hover{background:#10b98133}.mtp-rule-status--inactive{color:#6b7280;background:#6b72801a}.mtp-rule-status--inactive:hover{background:#6b728033}.mtp-rule-add{display:flex;gap:8px;align-items:flex-end;flex-wrap:wrap;padding-top:4px;border-top:1px dashed var(--border-color);margin-top:2px}.mtp-rule-add>div{display:flex;flex-direction:column;gap:3px}.mtp-rule-add label{font-size:.65rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.3px}.mtp-rule-add select{padding:5px 8px;font-size:.78rem;border:1px solid var(--border-color);border-radius:.375rem;background:var(--bg-primary);color:var(--text-primary)}.mtp-log-table{width:100%;border-collapse:collapse;font-size:.78rem}.mtp-log-table th{text-align:left;padding:8px 10px;border-bottom:2px solid var(--border-color);color:var(--text-secondary);font-weight:600;font-size:.68rem;text-transform:uppercase;letter-spacing:.4px}.mtp-log-table td{padding:7px 10px;border-bottom:1px solid var(--border-color)}.mtp-log-table tr:hover td{background:var(--bg-hover)}.mtp-status-sent{color:#10b981;font-weight:600;font-size:.72rem}.mtp-status-failed{color:#ef4444;font-weight:600;font-size:.72rem}.mtp-status-pending{color:#f59e0b;font-weight:600;font-size:.72rem}.mtp-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:mtp-spin .6s linear infinite}@keyframes mtp-spin{to{transform:rotate(360deg)}}.mtp-tabs{display:flex;gap:4px;margin-bottom:8px}.mtp-tab{padding:6px 14px;font-size:.78rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;gap:5px;transition:background .15s}.mtp-tab:hover{background:var(--bg-hover)}.mtp-tab.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);font-weight:500}.mtp-tab-count{font-size:.65rem;background:#fff3;padding:0 5px;border-radius:8px;min-width:16px;text-align:center}.mtp-empty{text-align:center;padding:40px 20px;color:var(--text-secondary)}.mtp-empty .material-symbols-outlined{font-size:2.5rem;opacity:.3;display:block;margin:0 auto 8px}.mtp-empty p{font-size:.82rem;margin:4px 0 16px}.mtp-subject-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#3b82f60f;border:1px solid rgba(59,130,246,.15);border-radius:.375rem;font-size:.82rem;color:var(--text-secondary)}.mtp-subject-banner strong{color:var(--text-primary)}.mtp-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:30px;color:var(--color-text-secondary);font-size:.9rem}.spin{animation:mtp-spin 1s linear infinite}@keyframes mtp-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mtp-stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.mtp-stat-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid;border-radius:10px;transition:transform .15s,box-shadow .15s}.mtp-stat-card:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.mtp-stat-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mtp-stat-icon .material-symbols-outlined{color:#fff;font-size:20px}.mtp-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.1}.mtp-stat-label{font-size:.72rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.mtp-toolbar-modern{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;margin-bottom:14px;flex-wrap:wrap}.mtp-filters{display:flex;align-items:center;gap:8px;flex:1;flex-wrap:wrap}.mtp-search{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;min-width:200px;flex:1;max-width:280px}.mtp-search .material-symbols-outlined{color:var(--color-text-secondary);font-size:18px}.mtp-search input{flex:1;border:none;background:transparent;color:var(--color-text);font-size:.82rem;outline:none;min-width:0}.mtp-search button{border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;padding:0;display:flex}.mtp-type-chips{display:flex;gap:4px;flex-wrap:wrap}.mtp-type-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border:1px solid var(--color-border);border-radius:14px;background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.72rem;font-weight:600;transition:all .15s}.mtp-type-chip:hover{border-color:var(--color-primary)}.mtp-type-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.mtp-type-chip .material-symbols-outlined{font-size:14px}.mtp-card-modern{display:flex;flex-direction:column;gap:8px;padding:16px;background:var(--color-surface);border:1px solid var(--color-border);border-top:4px solid;border-radius:10px;transition:all .15s}.mtp-card-modern:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.mtp-card-modern-header{display:flex;justify-content:space-between;align-items:flex-start}.mtp-card-modern-icon{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center}.mtp-card-modern-icon .material-symbols-outlined{color:#fff;font-size:20px}.mtp-card-modern-title{margin:0;font-size:.95rem;font-weight:700;color:var(--color-text);line-height:1.3}.mtp-card-modern-subject{margin:0;font-size:.78rem;color:var(--color-text-secondary);line-height:1.4;display:flex;align-items:center;gap:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mtp-card-modern-subject .material-symbols-outlined{font-size:13px;flex-shrink:0}.mtp-card-modern-meta{display:flex;gap:12px;font-size:.72rem;color:var(--color-text-secondary);flex-wrap:wrap}.mtp-card-modern-meta span{display:inline-flex;align-items:center;gap:3px}.mtp-card-modern-meta .material-symbols-outlined{font-size:13px}.mtp-card-modern-footer{display:flex;align-items:center;gap:6px;margin-top:8px;padding-top:10px;border-top:1px solid var(--color-border)}.mtp-view-toggle{display:flex;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.mtp-view-btn{display:flex;align-items:center;justify-content:center;padding:6px 10px;border:none;background:var(--color-bg);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.mtp-view-btn:hover{color:var(--color-text)}.mtp-view-btn.active{background:var(--color-primary);color:#fff}.mtp-list-rows{display:flex;flex-direction:column;gap:6px}.mtp-list-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;transition:all .15s}.mtp-list-row:hover{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 4%,var(--color-surface))}.mtp-list-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.mtp-list-icon .material-symbols-outlined{color:#fff;font-size:18px}.mtp-list-main{flex:1;min-width:0}.mtp-list-title{font-size:.88rem;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mtp-list-desc{font-size:.72rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.mtp-list-meta-item{display:inline-flex;align-items:center;gap:3px;font-size:.72rem;color:var(--color-text-secondary);white-space:nowrap}.mtp-list-meta-item .material-symbols-outlined{font-size:13px}.mtp-list-actions{display:flex;gap:4px;flex-shrink:0}.fiche-eleve{display:flex;flex-direction:column;gap:var(--sp-4);height:100%;overflow:hidden}.fiche-header{display:flex;align-items:center;gap:var(--sp-3);padding-bottom:var(--sp-3);border-bottom:1px solid var(--border-color);flex-shrink:0}.fiche-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary)}.fiche-error{display:flex;align-items:center;gap:var(--sp-2);background:var(--color-danger-light);color:var(--color-danger);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.fiche-layout{display:grid;grid-template-columns:380px 1fr;gap:var(--sp-6);flex:1;min-height:0;overflow:hidden}.fiche-left{display:flex;flex-direction:column;gap:var(--sp-3);overflow-y:auto;padding-right:var(--sp-2)}.fiche-identity-card{background:var(--bg-surface);border-radius:var(--radius);padding:var(--sp-6);text-align:center;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.fiche-avatar{width:80px;height:80px;border-radius:var(--radius-full);margin:0 auto var(--sp-2);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xxl);font-weight:var(--font-weight-bold);color:var(--text-inverse);overflow:hidden;position:relative;cursor:pointer}.fiche-avatar img{width:100%;height:100%;object-fit:cover}.fiche-avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;color:#fff;font-size:1.5rem}.fiche-avatar:hover .fiche-avatar-overlay{opacity:1}.fiche-photo-remove{display:flex;align-items:center;gap:var(--sp-1);margin:0 auto var(--sp-3);color:var(--color-danger);font-size:var(--font-size-xs)}.fiche-name{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--sp-2)}.fiche-badges{display:flex;justify-content:center;gap:var(--sp-2);margin-bottom:var(--sp-4);flex-wrap:wrap}.fiche-contact-row{display:flex;align-items:center;gap:var(--sp-2);color:var(--text-secondary);font-size:var(--font-size-sm);margin-top:var(--sp-1);justify-content:center}.fiche-section{background:var(--bg-surface);border-radius:var(--radius);border:1px solid var(--border-color);overflow:hidden}.fiche-section-header{all:unset;display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--sp-3) var(--sp-4);cursor:pointer;transition:background var(--transition-fast);box-sizing:border-box}.fiche-section-header:hover{background:var(--bg-surface-hover)}.fiche-section-title{display:flex;align-items:center;gap:var(--sp-2);font-weight:var(--font-weight-medium);font-size:var(--font-size-md);color:var(--text-primary)}.fiche-section-body{padding:var(--sp-3) var(--sp-4) var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-3);border-top:1px solid var(--border-color)}.fiche-field-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-2) var(--sp-4)}.fiche-field{display:flex;flex-direction:column;gap:2px}.fiche-field-label{font-size:var(--font-size-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-weight:var(--font-weight-medium)}.fiche-field-value{font-size:var(--font-size-md);color:var(--text-primary)}.fiche-urgence-block{background:var(--color-danger-subtle);border-radius:var(--radius-sm);padding:var(--sp-3);margin-top:var(--sp-2)}.fiche-urgence-title{display:flex;align-items:center;gap:var(--sp-2);font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--text-primary);margin-bottom:var(--sp-2)}.fiche-edit-form{display:flex;flex-direction:column;gap:var(--sp-2)}.fiche-edit-actions{display:flex;justify-content:flex-end;gap:var(--sp-2);margin-top:var(--sp-2)}.fiche-inline-form{display:flex;flex-direction:column;gap:var(--sp-2);background:var(--bg-section);padding:var(--sp-3);border-radius:var(--radius-sm);border:1px dashed var(--border-color)}.fiche-adresse-card{background:var(--bg-section);border-radius:var(--radius-sm);padding:var(--sp-3);border:1px solid var(--border-color)}.fiche-adresse-header{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2)}.fiche-adresse-header .btn-flat{margin-left:auto;opacity:.4;transition:opacity var(--transition-fast)}.fiche-adresse-card:hover .fiche-adresse-header .btn-flat{opacity:1}.fiche-adresse-body{display:flex;flex-direction:column;gap:2px;font-size:var(--font-size-sm);color:var(--text-secondary);padding-left:var(--sp-2)}.fiche-employeur-card{background:var(--bg-section);border-radius:var(--radius-sm);padding:var(--sp-3);border:1px solid var(--border-color)}.fiche-employeur-header{display:flex;align-items:flex-start;gap:var(--sp-3)}.fiche-employeur-icon{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--color-primary-subtle);display:flex;align-items:center;justify-content:center;flex-shrink:0}.fiche-employeur-icon .material-symbols-outlined{font-size:18px;color:var(--color-primary)}.fiche-employeur-info{flex:1;min-width:0}.fiche-employeur-name{font-weight:var(--font-weight-medium);font-size:var(--font-size-md);color:var(--text-primary);display:flex;align-items:center;gap:var(--sp-2)}.fiche-employeur-poste{font-size:var(--font-size-sm);color:var(--text-secondary)}.fiche-employeur-dates{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-top:2px}.fiche-employeur-header>.btn-flat{opacity:.4;transition:opacity var(--transition-fast)}.fiche-employeur-card:hover>.fiche-employeur-header>.btn-flat{opacity:1}.fiche-employeur-details{display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-2);margin-top:var(--sp-2);padding-top:var(--sp-2);border-top:1px solid var(--border-color)}.fiche-right{display:flex;flex-direction:column;min-height:0;overflow:hidden}.timeline-header{flex-shrink:0;margin-bottom:var(--sp-3)}.timeline-title{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--sp-3)}.timeline-title .material-symbols-outlined{color:var(--color-primary)}.timeline-filters{display:flex;flex-wrap:wrap;gap:var(--sp-1)}.timeline-filters .chip{all:unset;display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--text-secondary);background:var(--bg-section);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;box-sizing:border-box}.timeline-filters .chip:hover{background:var(--bg-surface-hover);border-color:var(--border-color-hover)}.timeline-filters .chip-active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary);font-weight:var(--font-weight-medium)}.timeline-container{flex:1;overflow-y:auto;padding-right:var(--sp-2)}.timeline{position:relative;display:flex;flex-direction:column}.timeline-item{display:flex;gap:var(--sp-4);min-height:60px}.timeline-line-segment{display:flex;flex-direction:column;align-items:center;width:32px;flex-shrink:0}.timeline-dot{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1;transition:transform var(--transition-fast)}.timeline-item:hover .timeline-dot{transform:scale(1.15)}.timeline-connector{width:2px;flex:1;background:var(--border-color);min-height:20px}.timeline-content{flex:1;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius);padding:var(--sp-3) var(--sp-4);margin-bottom:var(--sp-3);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);min-width:0}.timeline-content:hover{border-color:var(--border-color-hover);box-shadow:var(--shadow-sm)}.timeline-content-header{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2);margin-bottom:var(--sp-1)}.timeline-date{font-size:var(--font-size-xs);color:var(--text-tertiary);font-weight:var(--font-weight-medium)}.timeline-content-title{font-weight:var(--font-weight-medium);font-size:var(--font-size-md);color:var(--text-primary);line-height:1.3}.timeline-content-desc{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--sp-1);line-height:1.4}.timeline-score{display:flex;align-items:center;gap:var(--sp-2);margin-top:var(--sp-2)}.timeline-score-bar{flex:1;height:6px;background:var(--bg-disabled);border-radius:var(--radius-full);overflow:hidden}.timeline-score-fill{height:100%;border-radius:var(--radius-full);transition:width .5s ease}.timeline-score-text{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-secondary);white-space:nowrap;min-width:45px;text-align:right}.timeline-validity{display:flex;align-items:center;gap:var(--sp-2);margin-top:var(--sp-2);padding:var(--sp-2);background:var(--bg-section);border-radius:var(--radius-sm);font-size:var(--font-size-xs)}.timeline-validity-text{flex-shrink:0;font-weight:var(--font-weight-medium);color:var(--text-secondary)}.timeline-validity-bar{flex:1;height:4px;background:var(--bg-disabled);border-radius:var(--radius-full);overflow:hidden}.timeline-validity-fill{height:100%;border-radius:var(--radius-full);transition:width .5s ease}.btn-flat-active{background:var(--color-primary-light)!important;color:var(--color-primary)!important}.timeline-compact{display:flex;flex-direction:column;gap:2px}.timeline-compact-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm);transition:background var(--transition-fast);min-height:32px}.timeline-compact-item:hover{background:var(--bg-surface-hover)}.timeline-compact-item:nth-child(2n){background:var(--bg-section)}.timeline-compact-item:nth-child(2n):hover{background:var(--bg-surface-hover)}.timeline-compact-dot{width:22px;height:22px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.timeline-compact-date{font-size:var(--font-size-xs);color:var(--text-tertiary);white-space:nowrap;min-width:80px}.timeline-compact-title{flex:1;font-size:var(--font-size-sm);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.timeline-compact-score{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);white-space:nowrap;flex-shrink:0}.timeline-horizontal{display:flex;flex-wrap:wrap;gap:var(--sp-3);align-content:flex-start}.timeline-h-card{display:flex;flex-direction:column;width:calc(50% - var(--sp-3) / 2);min-width:180px;background:var(--bg-surface);border:1px solid var(--border-color);border-top:3px solid;border-radius:var(--radius);padding:var(--sp-3);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.timeline-h-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.timeline-h-header{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2)}.timeline-h-dot{width:26px;height:26px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.timeline-h-date{font-size:var(--font-size-xs);color:var(--text-tertiary);margin-bottom:var(--sp-1)}.timeline-h-title{font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--text-primary);line-height:1.3;margin-bottom:var(--sp-1)}.timeline-h-desc{font-size:var(--font-size-xs);color:var(--text-secondary);line-height:1.3}@media (max-width: 600px){.timeline-h-card{width:100%}}.fiche-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--sp-2);margin-bottom:var(--sp-3)}.fiche-photo-card{position:relative;border-radius:var(--radius-md);overflow:hidden;aspect-ratio:1;background:var(--bg-disabled);cursor:pointer;border:1px solid var(--color-border);transition:border-color .2s}.fiche-photo-card:hover{border-color:var(--color-primary)}.fiche-photo-card img{width:100%;height:100%;object-fit:cover;display:block}.fiche-photo-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);display:flex;align-items:center;justify-content:space-between;padding:var(--sp-1) var(--sp-2);opacity:0;transition:opacity .2s}.fiche-photo-card:hover .fiche-photo-overlay{opacity:1}.fiche-photo-name{font-size:.65rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.fiche-photo-overlay .btn-flat{color:#fff;padding:0;min-width:0}.fiche-fichiers-list{display:flex;flex-direction:column;gap:var(--sp-1);margin-bottom:var(--sp-3)}.fiche-fichier-row{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);background:var(--color-surface-variant);border:1px solid var(--color-border);transition:border-color .2s}.fiche-fichier-row:hover{border-color:var(--color-primary)}.fiche-fichier-info{flex:1;min-width:0}.fiche-fichier-name{font-size:.85rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.fiche-fichier-meta{font-size:.7rem;color:var(--color-text-secondary)}.fiche-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-1);padding:var(--sp-4) var(--sp-3);border:2px dashed var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface-variant);cursor:pointer;transition:border-color .2s,background .2s;text-align:center;margin-bottom:var(--sp-2)}.fiche-dropzone:hover{border-color:var(--color-primary);background:var(--color-primary-subtle)}.fiche-dropzone-active{border-color:var(--color-primary);background:var(--color-primary-subtle);border-style:solid}.fiche-dropzone .material-symbols-outlined{font-size:2rem;color:var(--color-text-secondary)}.fiche-dropzone span{font-size:.85rem;color:var(--color-text-secondary)}.fiche-upload-buttons{display:flex;gap:var(--sp-2);flex-wrap:wrap}.fiche-upload-buttons label{cursor:pointer;display:inline-flex;align-items:center;gap:var(--sp-1)}@media (max-width: 1024px){.fiche-layout{grid-template-columns:1fr;overflow-y:auto}.fiche-left{overflow-y:visible}.fiche-right{overflow:visible}.timeline-container{overflow-y:visible;max-height:none}}@media (max-width: 640px){.fiche-field-grid{grid-template-columns:1fr}.fiche-identity-card{padding:var(--sp-4)}.fiche-avatar{width:64px;height:64px;font-size:var(--font-size-xl)}}.mkp-page{min-height:100vh;min-height:100dvh;background:#0f172a;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;box-sizing:border-box;overflow-y:auto}.mkp-card{width:100%;max-width:420px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:2rem 1.5rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.mkp-title{font-size:2.5rem;font-weight:900;letter-spacing:.05em;background:linear-gradient(135deg,#6366f1,#ec4899,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;line-height:1.1}.mkp-subtitle{color:#ffffff80;font-size:.9rem;margin:-.25rem 0 .5rem}.mkp-input{width:100%;padding:.85rem 1rem;font-size:1.15rem;text-align:center;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:10px;color:#fff;outline:none;transition:border-color .2s;box-sizing:border-box}.mkp-input::placeholder{color:#ffffff59}.mkp-input:focus{border-color:#6366f1}.mkp-btn{width:100%;padding:.9rem;font-size:1.1rem;font-weight:700;border:none;border-radius:10px;cursor:pointer;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;transition:opacity .2s,transform .1s;margin-top:.25rem}.mkp-btn:hover:not(:disabled){opacity:.9}.mkp-btn:active:not(:disabled){transform:scale(.97)}.mkp-btn:disabled{opacity:.4;cursor:not-allowed}.mkp-error{color:#f87171;font-size:.9rem;margin:0}.mkp-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:#fff;flex-shrink:0}.mkp-lobby{gap:.75rem}.mkp-lobby-hello{color:#fff;font-size:1.4rem;font-weight:700;margin:0}.mkp-lobby-wait{color:#ffffff80;font-size:1rem;margin:0}.mkp-dots:after{content:"";animation:mkp-dots 1.5s steps(4,end) infinite}.mkp-countdown{font-size:3rem;font-weight:900;color:#fff;width:72px;height:72px;border-radius:50%;background:#ffffff14;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .3s,background .3s}.mkp-countdown.urgent{color:#f87171;background:#f8717126;animation:mkp-pulse .6s ease-in-out infinite}.mkp-question{gap:.75rem;max-width:500px}.mkp-q-text{color:#fff;font-size:1.2rem;font-weight:600;line-height:1.4;margin:0;word-break:break-word}.mkp-q-image{width:100%;max-height:220px;object-fit:contain;border-radius:10px}.mkp-q-answers{width:100%;display:flex;flex-direction:column;gap:.6rem}.mkp-q-ans{display:flex;align-items:center;gap:.75rem;width:100%;padding:.85rem 1rem;border:none;border-radius:10px;color:#fff;font-size:1.05rem;font-weight:600;cursor:pointer;text-align:left;transition:opacity .15s,transform .1s;min-height:52px}.mkp-q-ans:hover{opacity:.85}.mkp-q-ans:active{transform:scale(.97)}.mkp-q-letter{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:#fff3;font-weight:800;font-size:.95rem;flex-shrink:0}.mkp-q-label{flex:1;line-height:1.3}.mkp-result{gap:.75rem}.mkp-result-score{color:#fff;font-size:2rem;font-weight:800;margin:0}.mkp-result-wait{color:#ffffff73;font-size:.95rem;margin:0}.mkp-result-text{color:#fff;font-size:1.3rem;font-weight:700;margin:0}.mkp-check{width:72px;height:72px;border-radius:50%;background:#22c55e;color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:900;animation:mkp-pop .35s ease-out}.mkp-cross{width:72px;height:72px;border-radius:50%;background:#ef4444;color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:900;animation:mkp-pop .35s ease-out}.mkp-points{font-size:2rem;font-weight:900;color:#facc15;margin:0;animation:mkp-pop .4s ease-out}.mkp-final{gap:.5rem}.mkp-final-title{color:#fff;font-size:1.6rem;font-weight:800;margin:0}.mkp-final-pseudo{color:#fff9;font-size:1rem;margin:0}.mkp-final-score{font-size:3.5rem;font-weight:900;background:linear-gradient(135deg,#facc15,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:.25rem 0 0;line-height:1.1}.mkp-final-label{color:#ffffff73;font-size:1rem;text-transform:uppercase;letter-spacing:.1em}@keyframes mkp-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes mkp-dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}to{content:""}}@keyframes mkp-pop{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@media (min-width: 600px){.mkp-card{padding:2.5rem 2rem}.mkp-q-answers{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.mkp-q-ans{min-height:64px}.mkp-question{max-width:600px}}.up-view-toggle{display:flex;gap:2px;background:var(--color-bg-alt, var(--bg-sidebar));border-radius:.5rem;padding:2px;flex-shrink:0}.up-view-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:.4rem;cursor:pointer;background:transparent;color:var(--color-text-secondary);transition:background .15s,color .15s}.up-view-btn:hover{background:var(--color-bg-hover, rgba(128,128,128,.12))}.up-view-btn.active{background:var(--color-primary);color:#fff}.up-avatar{width:36px;height:36px;border-radius:var(--radius-full, 50%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.up-avatar-lg{width:48px;height:48px;font-size:1.1rem}.up-row-click{cursor:pointer;transition:background .12s}.up-row-click:hover{background:var(--color-bg-hover, rgba(128,128,128,.06))}.up-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.up-card{background:var(--color-bg-card, var(--color-bg));border:1px solid var(--color-border);border-radius:var(--radius-lg, .75rem);padding:1rem;cursor:pointer;position:relative;transition:box-shadow .15s,border-color .15s,transform .1s}.up-card:hover{box-shadow:0 4px 16px #0000001f;border-color:var(--color-primary);transform:translateY(-1px)}.up-card-delete{position:absolute;top:.5rem;right:.5rem;background:transparent;border:none;cursor:pointer;color:var(--color-text-secondary);padding:4px;border-radius:var(--radius-sm, .25rem);opacity:0;transition:opacity .15s,color .15s}.up-card:hover .up-card-delete{opacity:1}.up-card-delete:hover{color:var(--color-danger);background:var(--color-danger-subtle, rgba(239,68,68,.1))}.up-card-head{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.up-card-name{font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-card-username{font-size:.75rem;color:var(--color-text-secondary);font-family:var(--font-mono, monospace)}.up-card-info{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem;font-size:.8rem;color:var(--color-text-secondary)}.up-card-info-row{display:flex;align-items:center;gap:.4rem}.up-card-info-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-card-footer{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.prof-panel{display:flex;flex-direction:column;gap:var(--sp-3, .75rem)}.prof-stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:4px}.prof-stat-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-left:4px solid;border-radius:10px;transition:transform .15s,box-shadow .15s}.prof-stat-card:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.prof-stat-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.prof-stat-icon .material-symbols-outlined{color:#fff;font-size:20px}.prof-stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1.1}.prof-stat-label{font-size:.72rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}.prof-toolbar-modern{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;margin-bottom:4px;flex-wrap:wrap}.prof-search{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;min-width:220px;max-width:320px}.prof-search .material-symbols-outlined{color:var(--color-text-secondary);font-size:18px}.prof-search input{flex:1;border:none;background:transparent;color:var(--color-text);font-size:.82rem;outline:none;min-width:0}.prof-search button{border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;padding:0;display:flex}.prof-chips{display:flex;gap:4px;flex-wrap:wrap}.prof-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border:1px solid var(--color-border);border-radius:14px;background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.72rem;font-weight:600;transition:all .15s}.prof-chip:hover{border-color:var(--color-primary)}.prof-chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.prof-chip .material-symbols-outlined{font-size:14px}.prof-view-toggle{display:flex;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.prof-view-btn{display:flex;align-items:center;justify-content:center;padding:6px 10px;border:none;background:var(--color-bg);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.prof-view-btn:hover{color:var(--color-text)}.prof-view-btn.active{background:var(--color-primary);color:#fff}.prof-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:.78rem;font-weight:600;transition:all .15s}.prof-btn:hover{border-color:var(--color-primary)}.prof-btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.prof-btn-primary:hover{background:var(--color-primary-hover, #1565c0);border-color:var(--color-primary-hover, #1565c0)}.prof-btn-success{background:#10b981;color:#fff;border-color:#10b981}.prof-btn-success:hover{background:#0e9d6e;border-color:#0e9d6e}.prof-btn .material-symbols-outlined{font-size:15px}.prof-icon-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .12s}.prof-icon-btn:hover{background:var(--color-surface-hover, rgba(128, 128, 128, .08));color:var(--color-text)}.prof-icon-btn.danger:hover{background:color-mix(in srgb,var(--color-danger) 12%,transparent);border-color:var(--color-danger);color:var(--color-danger)}.prof-icon-btn .material-symbols-outlined{font-size:16px}.prof-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:12px;color:#fff;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.prof-badge .material-symbols-outlined{font-size:13px}.prof-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.prof-card-modern{display:flex;flex-direction:column;gap:10px;padding:16px;background:var(--color-surface);border:1px solid var(--color-border);border-top:4px solid;border-radius:10px;transition:transform .15s,box-shadow .15s}.prof-card-modern:hover{transform:translateY(-2px);box-shadow:0 4px 14px #00000014}.prof-card-modern-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.prof-card-modern-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.prof-card-modern-icon .material-symbols-outlined{color:#fff;font-size:22px}.prof-card-modern-title{margin:0;font-size:1rem;font-weight:700;color:var(--color-text)}.prof-card-modern-desc{margin:0;font-size:.78rem;color:var(--color-text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.prof-card-modern-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:.74rem;color:var(--color-text-secondary)}.prof-card-modern-meta>span{display:inline-flex;align-items:center;gap:4px}.prof-card-modern-meta .material-symbols-outlined{font-size:14px}.prof-progress{height:6px;background:color-mix(in srgb,var(--color-border) 60%,transparent);border-radius:3px;overflow:hidden}.prof-progress-fill{height:100%;border-radius:3px;transition:width .25s ease}.prof-card-modern-footer{display:flex;align-items:center;gap:6px;padding-top:8px;border-top:1px solid var(--color-border)}.prof-list-rows{display:flex;flex-direction:column;gap:6px}.prof-list-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;transition:all .15s}.prof-list-row:hover{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 4%,var(--color-surface))}.prof-list-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.prof-list-icon .material-symbols-outlined{color:#fff;font-size:18px}.prof-list-main{flex:1;min-width:0}.prof-list-title{font-size:.88rem;font-weight:600;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prof-list-desc{font-size:.72rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.prof-list-meta-item{display:inline-flex;align-items:center;gap:3px;font-size:.74rem;color:var(--color-text-secondary);white-space:nowrap}.prof-list-meta-item .material-symbols-outlined{font-size:13px}.prof-list-actions{display:flex;gap:4px;flex-shrink:0}.prof-matrix-wrap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;overflow:auto;max-width:100%}.prof-matrix{width:100%;border-collapse:collapse;font-size:.78rem}.prof-matrix th,.prof-matrix td{padding:9px 12px;text-align:center;border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border)}.prof-matrix th:last-child,.prof-matrix td:last-child{border-right:none}.prof-matrix tbody tr:last-child td{border-bottom:none}.prof-matrix-corner{text-align:left!important;background:color-mix(in srgb,var(--color-primary) 8%,var(--color-surface));color:var(--color-text);font-weight:700;position:sticky;left:0;z-index:2}.prof-matrix-profile-head{background:color-mix(in srgb,var(--color-primary) 6%,var(--color-surface));color:var(--color-text);font-weight:600;min-width:110px;vertical-align:middle}.prof-matrix-profile-name{font-size:.78rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:150px}.prof-matrix-profile-head .material-symbols-outlined{font-size:14px;vertical-align:middle;margin-top:2px}.prof-matrix-mod{text-align:left!important;background:var(--color-surface);position:sticky;left:0;z-index:1;min-width:160px}.prof-matrix-mod-name{font-size:.82rem;font-weight:700;color:var(--color-text)}.prof-matrix-mod-actions{font-size:.68rem;color:var(--color-text-secondary);margin-top:2px}.prof-matrix-cell{font-weight:700;font-size:.78rem;transition:background .15s}.prof-matrix-cell.empty{color:var(--color-text-secondary);background:color-mix(in srgb,var(--color-border) 30%,transparent)}.prof-matrix-cell.partial{color:#b45309;background:color-mix(in srgb,#f59e0b 18%,transparent)}.prof-matrix-cell.full{color:#047857;background:color-mix(in srgb,#10b981 18%,transparent)}.prof-matrix-cell.full .material-symbols-outlined{font-size:16px;color:#047857}.prof-matrix-total td{background:color-mix(in srgb,var(--color-primary) 12%,var(--color-surface));font-weight:800;color:var(--color-text);border-top:2px solid var(--color-primary)}.prof-matrix-total td:first-child{text-align:left;position:sticky;left:0}[data-theme=dark] .prof-matrix-cell.partial{color:#fbbf24}[data-theme=dark] .prof-matrix-cell.full,[data-theme=dark] .prof-matrix-cell.full .material-symbols-outlined{color:#34d399}.prof-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 20px;text-align:center;color:var(--color-text-secondary);font-size:.9rem;background:var(--color-surface);border:1px dashed var(--color-border);border-radius:10px}.prof-empty .material-symbols-outlined{font-size:56px;opacity:.35}.prof-empty p{margin:0}.prof-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:40px 20px;color:var(--color-text-secondary);font-size:.9rem}.prof-loading .spin{animation:prof-spin 1s linear infinite;font-size:22px}@keyframes prof-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.prof-stats-bar{grid-template-columns:repeat(2,1fr)}.prof-toolbar-modern{flex-direction:column;align-items:stretch}.prof-search{max-width:none}.prof-grid{grid-template-columns:1fr}.prof-list-row{flex-wrap:wrap}}.trac-panel{display:flex;flex-direction:column;gap:var(--sp-3, .75rem)}.trac-header{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3, .75rem);flex-wrap:wrap}.trac-tabs{display:flex;gap:2px;background:var(--color-surface, rgba(128, 128, 128, .06));border-radius:8px;padding:3px}.trac-tab{display:flex;align-items:center;gap:6px;padding:.45rem 1rem;border:none;border-radius:6px;background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:.85rem;font-weight:500;transition:all .15s ease}.trac-tab:hover{background:var(--color-surface-hover, rgba(128, 128, 128, .08));color:var(--color-text)}.trac-tab--active,.trac-tab--active:hover{background:var(--color-primary);color:#fff}.trac-tab .material-symbols-outlined{font-size:18px}.trac-views{display:inline-flex;gap:1px;background:var(--color-border, rgba(128, 128, 128, .2));border-radius:6px;overflow:hidden}.trac-view-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:var(--color-surface, #fff);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.trac-view-btn:hover{background:var(--color-surface-hover, rgba(128, 128, 128, .08));color:var(--color-text)}.trac-view-btn.active{background:var(--color-primary);color:#fff}.trac-view-btn .material-symbols-outlined{font-size:18px}.trac-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--sp-3, .75rem)}.trac-stat-card{display:flex;align-items:center;gap:var(--sp-3, .75rem);padding:var(--sp-4, 1rem);background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-md, 10px);transition:box-shadow .2s ease}.trac-stat-card:hover{box-shadow:0 2px 8px #0000000f}.trac-stat-card--today{border-left:3px solid var(--color-primary)}.trac-stat-icon{font-size:1.3rem;opacity:.7;color:var(--color-primary)}.trac-stat-icon .material-symbols-outlined{font-size:inherit}.trac-stat-value{font-size:1.5rem;font-weight:700;line-height:1.2}.trac-stat-label{font-size:.72rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em}.trac-filters{display:flex;align-items:center;gap:var(--sp-2, .5rem);flex-wrap:wrap}.trac-search{flex:1 1 200px;min-width:180px;max-width:320px}.trac-select{min-width:140px;max-width:200px}.trac-date-input{width:140px}.trac-table-wrap{border-radius:var(--radius-md, 10px);border:1px solid var(--color-border, rgba(128, 128, 128, .15));overflow:hidden}.trac-table{width:100%;border-collapse:collapse;font-size:.85rem}.trac-table thead th{padding:.6rem .75rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);background:var(--color-surface, rgba(128, 128, 128, .04));white-space:nowrap;border-bottom:2px solid var(--color-border, rgba(128, 128, 128, .15));text-transform:uppercase;letter-spacing:.03em;position:sticky;top:0;z-index:1}.trac-table tbody tr{border-bottom:1px solid var(--color-border, rgba(128, 128, 128, .08));transition:background .12s ease}.trac-table tbody tr:hover{background:var(--color-surface-hover, rgba(128, 128, 128, .03))}.trac-table tbody tr:last-child{border-bottom:none}.trac-row td{padding:.5rem .75rem;vertical-align:middle}.trac-row--expanded{background:var(--color-surface-hover, rgba(128, 128, 128, .04))}.trac-date{white-space:nowrap;font-family:Cascadia Mono,Fira Mono,monospace;font-size:.8rem;color:var(--color-text-secondary)}.trac-user{display:flex;align-items:center;gap:.4rem;white-space:nowrap}.trac-user-avatar{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--color-primary-subtle, rgba(25, 118, 210, .12));color:var(--color-primary);font-size:.7rem;font-weight:700;flex-shrink:0}.trac-user-avatar--sm{width:22px;height:22px;font-size:.65rem}.trac-uuid{font-family:Cascadia Mono,Fira Mono,monospace;font-size:.78rem;color:var(--color-text-secondary)}.trac-ip{font-family:Cascadia Mono,Fira Mono,monospace;font-size:.8rem;color:var(--color-text-secondary)}.trac-details-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trac-ua-cell{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.78rem;color:var(--color-text-secondary)}.trac-details-inline{font-size:.8rem;color:var(--color-text-secondary)}.trac-action-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:.78rem;font-weight:500;white-space:nowrap;background:color-mix(in srgb,var(--action-color, #6b7280) 15%,transparent);color:var(--action-color, #6b7280);border:1px solid color-mix(in srgb,var(--action-color, #6b7280) 30%,transparent)}.trac-entity-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap;background:color-mix(in srgb,var(--entity-color, #6b7280) 12%,transparent);color:var(--entity-color, #6b7280)}.trac-diff-expand-row td{padding:0 .75rem .75rem;background:var(--color-surface, #fff)}.trac-diff-viewer{border-radius:6px;overflow:hidden;border:1px solid var(--color-border, rgba(128, 128, 128, .15))}.trac-diff-table{width:100%;border-collapse:collapse;font-size:.82rem}.trac-diff-table thead th{text-align:left;padding:6px 10px;font-weight:600;font-size:.75rem;text-transform:uppercase;color:var(--color-text-secondary);background:var(--color-surface, #fff);border-bottom:1px solid var(--color-border, rgba(128, 128, 128, .15))}.trac-diff-row td{padding:4px 10px;border-bottom:1px solid var(--color-border, rgba(128, 128, 128, .08));vertical-align:top}.trac-diff-key{font-weight:600;white-space:nowrap;font-size:.8rem}.trac-diff-val{font-family:Cascadia Mono,Fira Mono,monospace;font-size:.78rem;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:pre-wrap;word-break:break-all}.trac-diff-added{background:color-mix(in srgb,#10b981 8%,transparent)}.trac-diff-removed{background:color-mix(in srgb,#ef4444 8%,transparent)}.trac-diff-changed{background:color-mix(in srgb,#f59e0b 8%,transparent)}.trac-diff-badge{display:inline-flex;padding:1px 6px;border-radius:3px;font-size:.7rem;font-weight:600;text-transform:uppercase}.trac-diff-badge-added{background:color-mix(in srgb,#10b981 20%,transparent);color:#10b981}.trac-diff-badge-removed{background:color-mix(in srgb,#ef4444 20%,transparent);color:#ef4444}.trac-diff-badge-changed{background:color-mix(in srgb,#f59e0b 20%,transparent);color:#f59e0b}.trac-diff-empty{padding:16px;text-align:center;color:var(--color-text-secondary);font-style:italic}.trac-pagination{display:flex;align-items:center;justify-content:center;gap:12px}.trac-page-info{font-size:.85rem;color:var(--color-text-secondary)}.trac-timeline{display:flex;flex-direction:column;gap:var(--sp-5, 1.5rem)}.trac-timeline-group{display:flex;flex-direction:column;gap:0}.trac-timeline-day{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;font-size:.85rem;font-weight:600;color:var(--color-text);text-transform:capitalize}.trac-timeline-day .material-symbols-outlined{font-size:18px;color:var(--color-primary)}.trac-timeline-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;font-size:.65rem;font-weight:700;background:var(--color-border, rgba(128, 128, 128, .15));color:var(--color-text-secondary)}.trac-timeline-trunk{padding-left:8px}.trac-timeline-item{display:flex;gap:var(--sp-3, .75rem);min-height:60px}.trac-timeline-rail{display:flex;flex-direction:column;align-items:center;width:20px;flex-shrink:0}.trac-timeline-dot{width:10px;height:10px;border-radius:50%;background:var(--tl-color, var(--color-primary));flex-shrink:0;margin-top:6px;box-shadow:0 0 0 3px color-mix(in srgb,var(--tl-color, var(--color-primary)) 20%,transparent)}.trac-timeline-line{width:2px;flex:1;background:var(--color-border, rgba(128, 128, 128, .2));margin:4px 0}.trac-timeline-card{flex:1;background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-md, 10px);padding:var(--sp-3, .75rem);margin-bottom:var(--sp-2, .5rem);transition:box-shadow .2s ease}.trac-timeline-card:hover{box-shadow:0 2px 8px #0000000f}.trac-timeline-card-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.trac-timeline-card-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-top:.35rem;font-size:.8rem}.trac-timeline-icon{font-size:.9rem;color:var(--tl-color, var(--color-text-secondary))}.trac-timeline-icon .material-symbols-outlined{font-size:inherit}.trac-timeline-time{font-family:Cascadia Mono,Fira Mono,monospace;font-size:.78rem;color:var(--color-text-secondary);margin-left:auto}.trac-timeline-user{display:flex;align-items:center;gap:.3rem;font-weight:500}.trac-timeline-diff{margin-top:var(--sp-2, .5rem);border-top:1px solid var(--color-border, rgba(128, 128, 128, .1));padding-top:var(--sp-2, .5rem)}.trac-timeline-diff-toggle{display:flex;align-items:center;gap:.3rem;border:none;background:none;color:var(--color-text-secondary);cursor:pointer;font-size:.8rem;padding:.2rem 0;transition:color .15s ease}.trac-timeline-diff-toggle:hover{color:var(--color-text)}.trac-timeline-diff-toggle .material-symbols-outlined{font-size:18px}.trac-charts{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--sp-3, .75rem)}.trac-chart-card{background:var(--color-surface, #fff);border:1px solid var(--color-border, rgba(128, 128, 128, .15));border-radius:var(--radius-md, 10px);padding:var(--sp-4, 1rem)}.trac-chart-card--wide{grid-column:1 / -1}.trac-chart-title{display:flex;align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:var(--sp-3, .75rem)}.trac-chart-title .material-symbols-outlined{font-size:18px}.trac-chart-body{position:relative;width:100%;max-height:250px}@media (max-width: 768px){.trac-header{flex-direction:column;align-items:stretch}.trac-tabs{width:100%}.trac-tab{flex:1;justify-content:center}.trac-views{align-self:flex-end}.trac-stats{grid-template-columns:repeat(2,1fr)}.trac-filters{flex-direction:column;align-items:stretch}.trac-search{max-width:none}.trac-select,.trac-date-input{width:100%;max-width:none;min-width:unset}.trac-charts{grid-template-columns:1fr}.trac-chart-card--wide{grid-column:1}.trac-timeline-card-header{flex-wrap:wrap}}.statistiques-panel{display:flex;flex-direction:column;gap:1rem;max-width:100%}.stat-toolbar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;justify-content:space-between}.stat-date-range{display:flex;align-items:center;gap:8px}.stat-date-range input[type=date]{padding:.35rem .6rem;font-size:.8rem;background:var(--color-bg-elevated, rgba(255, 255, 255, .05));color:var(--color-text, #e2e8f0);border:1px solid var(--color-border, rgba(255, 255, 255, .1));border-radius:.375rem;transition:border-color .15s}.stat-date-range input[type=date]:focus{outline:none;border-color:var(--color-primary, #3b82f6)}.stat-tabs{display:flex;gap:4px;background:var(--color-surface, rgba(255, 255, 255, .04));border-radius:8px;padding:4px;overflow-x:auto;-webkit-overflow-scrolling:touch}.stat-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;border:none;border-radius:6px;background:transparent;color:var(--color-text-secondary, #94a3b8);cursor:pointer;font-size:.82rem;font-weight:500;transition:all .15s;white-space:nowrap}.stat-tab:hover{background:var(--color-surface-hover, rgba(255, 255, 255, .06));color:var(--color-text, #e2e8f0)}.stat-tab.active,.stat-tab.active:hover{background:var(--color-primary, #3b82f6);color:#fff}.stat-tab .material-symbols-outlined{font-size:18px}.stat-category-header{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--color-surface, rgba(255, 255, 255, .03));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-left:4px solid var(--color-primary, #3b82f6);border-radius:10px}.stat-category-icon{font-size:28px!important}.stat-category-info{display:flex;flex-direction:column;gap:2px;flex:1}.stat-category-title{margin:0;font-size:1.1rem;font-weight:700;color:var(--color-text, #e2e8f0)}.stat-category-count{font-size:.75rem;color:var(--color-text-secondary, #64748b)}.stat-loading{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--color-text-secondary, #94a3b8);font-size:.9rem}.stat-loading .spin{animation:stat-spin 1s linear infinite}@keyframes stat-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stat-error{padding:1rem 1.25rem;background:color-mix(in srgb,#ef4444 10%,transparent);border:1px solid color-mix(in srgb,#ef4444 30%,transparent);border-radius:.5rem;color:#ef4444;font-size:.85rem;font-weight:500}.stat-content{display:flex;flex-direction:column;gap:1.25rem}.stat-sub-group{display:flex;flex-direction:column;gap:.6rem}.stat-sub-group-card{background:var(--color-surface, rgba(255, 255, 255, .02));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-radius:10px;padding:16px;transition:border-color .2s}.stat-sub-group-card:hover{border-color:color-mix(in srgb,var(--color-primary, #3b82f6) 30%,transparent)}.stat-sub-group-title{margin:0 0 .5rem;font-size:.85rem;font-weight:600;color:var(--color-text-secondary, #94a3b8);text-transform:uppercase;letter-spacing:.03em;padding-bottom:.35rem;border-bottom:1px solid var(--color-border, rgba(255, 255, 255, .08));display:flex;align-items:center;gap:8px}.stat-sg-icon{font-size:18px!important}.stat-kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.stat-kpi-card{background:var(--color-surface, rgba(255, 255, 255, .03));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-left:3px solid var(--color-primary, #3b82f6);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:.25rem;transition:background .15s,border-color .15s,transform .15s}.stat-kpi-card:hover{background:var(--color-surface-hover, rgba(255, 255, 255, .06));transform:translateY(-1px)}.stat-kpi-label{font-size:.68rem;font-weight:600;color:var(--color-text-secondary, #94a3b8);text-transform:uppercase;letter-spacing:.3px;line-height:1.3}.stat-kpi-value{font-size:1.5rem;font-weight:700;font-family:Cascadia Mono,Fira Mono,monospace;color:var(--color-text, #e2e8f0);line-height:1.2}.stat-kpi-unit{font-size:.7rem;color:var(--color-text-secondary, #64748b);font-weight:500}.stat-kpi-bar{height:3px;background:var(--color-border, rgba(255, 255, 255, .1));border-radius:2px;margin-top:4px;overflow:hidden}.stat-kpi-bar-fill{height:100%;border-radius:2px;transition:width .4s ease}.stat-kpi-card.highlight{background:color-mix(in srgb,var(--color-primary, #3b82f6) 8%,transparent);border-color:color-mix(in srgb,var(--color-primary, #3b82f6) 25%,transparent)}.stat-kpi-card.highlight .stat-kpi-value{color:var(--color-primary, #3b82f6)}.stat-kpi-card.warning{background:color-mix(in srgb,#f59e0b 8%,transparent);border-color:color-mix(in srgb,#f59e0b 25%,transparent)}.stat-kpi-card.warning .stat-kpi-value{color:#f59e0b}.stat-kpi-card.danger{background:color-mix(in srgb,#ef4444 8%,transparent);border-color:color-mix(in srgb,#ef4444 25%,transparent)}.stat-kpi-card.danger .stat-kpi-value{color:#ef4444}.stat-top-list{display:flex;flex-direction:column;gap:.3rem}.stat-top-item{display:flex;align-items:center;gap:.6rem;padding:.5rem .75rem;background:var(--color-surface, rgba(255, 255, 255, .03));border:1px solid var(--color-border, rgba(255, 255, 255, .06));border-radius:.375rem;font-size:.85rem;transition:background .15s}.stat-top-item:hover{background:var(--color-surface-hover, rgba(255, 255, 255, .06))}.stat-top-item-rank{font-size:.75rem;font-weight:700;font-family:monospace;color:var(--color-text-secondary, #64748b);min-width:1.5rem;text-align:center}.stat-top-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text, #e2e8f0)}.stat-top-item-value{font-weight:700;font-family:Cascadia Mono,Fira Mono,monospace;font-size:.8rem;color:var(--color-primary, #3b82f6);white-space:nowrap}@media (max-width: 768px){.stat-toolbar{flex-direction:column;align-items:stretch}.stat-date-range{flex-wrap:wrap}.stat-tabs{width:100%}.stat-tab{flex:0 0 auto;padding:8px 10px;font-size:.78rem}.stat-kpi-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.stat-kpi-card{padding:10px}.stat-kpi-value{font-size:1.25rem}}.stat-sub-group-row{display:grid;grid-template-columns:2fr 1fr;gap:12px;align-items:start}.stat-inline-chart{position:relative;height:200px;background:var(--color-surface, rgba(255, 255, 255, .03));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-radius:8px;padding:10px}@media (max-width: 1024px){.stat-sub-group-row{grid-template-columns:1fr}.stat-inline-chart{height:220px}}.stat-btn-refresh,.stat-btn-print{display:flex;align-items:center;gap:5px;padding:6px 14px;border:1px solid var(--color-border, rgba(255, 255, 255, .1));border-radius:6px;background:var(--color-surface, rgba(255, 255, 255, .05));color:var(--color-text, #e2e8f0);cursor:pointer;font-size:.82rem;transition:all .15s}.stat-btn-print{background:var(--color-primary, #3b82f6);color:#fff;border-color:var(--color-primary, #3b82f6)}.stat-btn-print:hover{opacity:.85}.stat-btn-refresh .material-symbols-outlined,.stat-btn-print .material-symbols-outlined{font-size:18px}.stat-print-header h1{font-size:1.5rem;margin:0 0 8px;color:#333}.stat-print-meta{display:flex;gap:18px;font-size:.85rem;color:#555;margin-bottom:16px;border-bottom:2px solid #3b82f6;padding-bottom:8px;flex-wrap:wrap}.stat-print-footer{display:flex;justify-content:space-between;margin-top:24px;padding-top:8px;border-top:1px solid #ccc;font-size:.75rem;color:#888}@media print{body *{visibility:hidden}.stat-print-area,.stat-print-area *{visibility:visible}.stat-print-area{position:absolute;left:0;top:0;width:100%}@page{size:A4 portrait;margin:15mm 12mm}.no-print{display:none!important}.print-only{display:block!important}.stat-print-meta,.stat-print-footer{display:flex!important}.statistiques-panel,.stat-print-area,.stat-content,.stat-sub-group,.stat-sub-group-card,.stat-kpi-card,.stat-inline-chart,.stat-top-item{background:#fff!important;color:#333!important;border-color:#ddd!important}.stat-sub-group-title{color:#333!important;border-bottom-color:#3b82f6!important;font-size:11pt!important;font-weight:700!important}.stat-kpi-label{color:#666!important}.stat-kpi-value{color:#1a1a1a!important}.stat-kpi-card.highlight .stat-kpi-value{color:#3b82f6!important}.stat-kpi-card.warning .stat-kpi-value{color:#f59e0b!important}.stat-kpi-card.danger .stat-kpi-value{color:#ef4444!important}.stat-top-item-label{color:#1a1a1a!important}.stat-top-item-value{color:#3b82f6!important}.stat-kpi-grid{grid-template-columns:repeat(4,1fr)!important;gap:6px!important}.stat-kpi-card{padding:6px 8px!important}.stat-kpi-value{font-size:13pt!important}.stat-kpi-label{font-size:7pt!important}.stat-inline-chart{height:150px!important;page-break-inside:avoid}.stat-sub-group{page-break-inside:avoid;margin-bottom:12px!important}.stat-sub-group-row{grid-template-columns:2fr 1fr!important}}.support-panel-v2{display:flex;flex-direction:column;height:100%;gap:0;background:var(--color-bg);color:var(--color-text);overflow:hidden}.sup-error{padding:40px;text-align:center;color:var(--color-text-muted);font-size:14px}.sup-tabs{display:flex;align-items:center;gap:2px;padding:6px 12px;border-bottom:1px solid var(--color-border);background:var(--color-bg-elevated);flex-shrink:0}.sup-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;background:transparent;color:var(--color-text-muted);font-size:13px;font-weight:500;border-radius:6px 6px 0 0;cursor:pointer;transition:all .15s;border-bottom:2px solid transparent}.sup-tab:hover{color:var(--color-text);background:var(--color-bg-hover)}.sup-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent);background:var(--color-bg-hover)}.sup-tab .material-symbols-outlined{font-size:18px}.sup-tab-badge{background:#ef4444;color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center;line-height:16px}.sup-toggle-kpi{display:flex;align-items:center;padding:6px 8px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-muted);border-radius:6px;cursor:pointer;transition:all .15s}.sup-toggle-kpi:hover,.sup-toggle-kpi.active{color:var(--color-accent);border-color:var(--color-accent);background:var(--color-accent-bg, rgba(99, 102, 241, .08))}.sup-toggle-kpi .material-symbols-outlined{font-size:18px}.sup-kpi-dashboard{padding:12px;border-bottom:1px solid var(--color-border);background:var(--color-bg-elevated);flex-shrink:0;animation:fadeInKpi .2s ease}@keyframes fadeInKpi{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sup-kpi-row{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}.sup-kpi-card{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;transition:all .15s;flex:1;min-width:130px}.sup-kpi-card:hover{border-color:var(--color-accent);box-shadow:0 2px 8px #00000026}.sup-kpi-card.active{border-color:var(--color-accent);background:var(--color-accent-bg, rgba(99, 102, 241, .08));box-shadow:0 0 0 1px var(--color-accent)}.sup-kpi-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;color:#fff;font-size:20px!important;flex-shrink:0}.sup-kpi-info{display:flex;flex-direction:column;gap:0}.sup-kpi-value{font-size:20px;font-weight:700;line-height:1.1}.sup-kpi-label{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.sup-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.sup-chart-card{border:1px solid var(--color-border);border-radius:10px;padding:10px;background:var(--color-bg)}.sup-chart-title{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0 0 6px}.sup-chart-title .material-symbols-outlined{font-size:16px;color:var(--color-accent)}.sup-chart-body{height:120px;position:relative}.sup-toolbar{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--color-border);background:var(--color-bg-elevated);flex-shrink:0;flex-wrap:wrap}.sup-search{display:flex;align-items:center;gap:6px;flex:1;min-width:180px;max-width:300px;padding:6px 10px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg);transition:border-color .15s}.sup-search:focus-within{border-color:var(--color-accent)}.sup-search .material-symbols-outlined{font-size:18px;color:var(--color-text-muted)}.sup-search input{background:none;border:none;outline:none;color:var(--color-text);font-size:13px;width:100%}.sup-search input::placeholder{color:var(--color-text-muted)}.sup-search button{border:none;background:none;color:var(--color-text-muted);cursor:pointer;padding:0;display:flex}.sup-search button:hover{color:var(--color-text)}.sup-filter-select{padding:6px 10px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg);color:var(--color-text);font-size:12px;cursor:pointer;outline:none}.sup-filter-select:focus{border-color:var(--color-accent)}.sup-toolbar-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid var(--color-border);border-radius:8px;background:transparent;color:var(--color-text-muted);font-size:12px;cursor:pointer;transition:all .15s}.sup-toolbar-btn:hover{color:var(--color-text);border-color:var(--color-text-muted)}.sup-toolbar-btn.active{color:var(--color-accent);border-color:var(--color-accent);background:var(--color-accent-bg, rgba(99, 102, 241, .08))}.sup-toolbar-btn .material-symbols-outlined{font-size:16px}.sup-btn-label{white-space:nowrap}.sup-view-toggle{display:flex;border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.sup-view-toggle button{padding:5px 8px;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;transition:all .15s}.sup-view-toggle button:first-child{border-right:1px solid var(--color-border)}.sup-view-toggle button.active{background:var(--color-accent);color:#fff}.sup-view-toggle button .material-symbols-outlined{font-size:16px}.sup-content-area{display:flex;flex:1;overflow:hidden;min-height:0}.sup-list-section{flex:1;overflow-y:auto;min-width:0}.sup-content-area.with-detail .sup-list-section{flex:0 0 55%;max-width:55%;border-right:1px solid var(--color-border)}.sup-loading{display:flex;align-items:center;gap:8px;justify-content:center;padding:60px 20px;color:var(--color-text-muted);font-size:13px}.spin{animation:spin 1s linear infinite}.sup-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:60px 20px;color:var(--color-text-muted)}.sup-empty .material-symbols-outlined{font-size:48px;opacity:.3}.sup-empty p{font-size:13px;margin:0}.sup-table-wrap{overflow-x:auto}.sup-table{width:100%;border-collapse:collapse;table-layout:auto}.sup-table thead{position:sticky;top:0;z-index:2}.sup-table th{padding:8px 10px;text-align:left;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-muted);background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border);white-space:nowrap}.sup-th-sort{cursor:pointer;-webkit-user-select:none;user-select:none}.sup-th-sort:hover{color:var(--color-accent)}.sup-th-sort span{display:inline}.sup-sort-icon{font-size:12px!important;vertical-align:middle;margin-left:2px}.sup-table td{padding:8px 10px;font-size:12px;border-bottom:1px solid var(--color-border);vertical-align:middle;white-space:nowrap}.sup-table-row{cursor:pointer;transition:background .1s}.sup-table-row:hover{background:var(--color-bg-hover)}.sup-table-row.selected{background:var(--color-accent-bg, rgba(99, 102, 241, .08))}.sup-td-title{max-width:250px;overflow:hidden;text-overflow:ellipsis;font-weight:500;color:var(--color-text)}.sup-td-author{color:var(--color-text-muted);max-width:120px;overflow:hidden;text-overflow:ellipsis}.sup-td-date{color:var(--color-text-muted)}.sup-status-chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;color:#fff;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.sup-cat-badge{display:inline-flex;align-items:center;gap:2px;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:500;white-space:nowrap}.sup-prio-badge{display:inline-flex;align-items:center;gap:2px;font-size:11px;font-weight:600;white-space:nowrap}.sup-prio-badge.sm{font-size:10px}.sup-age-badge{display:inline-flex;align-items:center;font-size:10px;font-weight:600;color:var(--color-text-muted);padding:1px 5px;border-radius:4px;background:#ffffff0d}.sup-age-badge.medium{color:#f59e0b;background:#f59e0b1f}.sup-age-badge.old{color:#ef4444;background:#ef44441f}.sup-age-badge.sm{font-size:9px;padding:0 4px}.sup-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;padding:12px}.sup-card{border:1px solid var(--color-border);border-left:3px solid;border-radius:10px;padding:12px;background:var(--color-bg-elevated);cursor:pointer;transition:all .15s}.sup-card:hover{box-shadow:0 2px 10px #00000026;transform:translateY(-1px)}.sup-card.selected{border-color:var(--color-accent);box-shadow:0 0 0 1px var(--color-accent)}.sup-card-header{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px}.sup-card-title{font-size:13px;font-weight:500;flex:1;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.sup-replied-icon{font-size:16px!important;color:#22c55e;flex-shrink:0}.sup-card-badges{display:flex;align-items:center;gap:6px;margin-bottom:8px;flex-wrap:wrap}.sup-card-footer{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--color-text-muted)}.sup-card-author{display:flex;align-items:center;gap:3px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sup-card-date{white-space:nowrap}.sup-detail-panel{flex:0 0 45%;max-width:45%;display:flex;flex-direction:column;background:var(--color-bg-elevated);overflow:hidden;animation:slideInDetail .2s ease}@keyframes slideInDetail{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.sup-detail-top{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--color-border);flex-shrink:0}.sup-detail-top h4{font-size:13px;font-weight:600;margin:0;color:var(--color-text)}.sup-detail-close{display:flex;align-items:center;padding:4px;border:none;background:none;color:var(--color-text-muted);cursor:pointer;border-radius:4px;transition:background .1s}.sup-detail-close:hover{background:var(--color-bg-hover);color:var(--color-text)}.sup-detail-scroll{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:14px}.sup-detail-header{display:flex;align-items:flex-start;gap:10px}.sup-detail-title{font-size:15px;font-weight:600;margin:0;line-height:1.3;color:var(--color-text)}.sup-detail-badges{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sup-detail-meta{display:flex;flex-direction:column;gap:6px;padding:10px;border-radius:8px;background:var(--color-bg);border:1px solid var(--color-border)}.sup-meta-item{display:flex;align-items:center;gap:8px;font-size:12px}.sup-meta-item .material-symbols-outlined{font-size:16px;color:var(--color-text-muted);flex-shrink:0}.sup-meta-label{color:var(--color-text-muted);min-width:70px;font-size:11px}.sup-bloc-tag{padding:1px 6px;border-radius:4px;background:var(--color-accent-bg, rgba(99, 102, 241, .1));color:var(--color-accent);font-family:monospace;font-size:11px}.sup-url-link{color:var(--color-accent);font-size:11px;text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.sup-url-link:hover{text-decoration:underline}.sup-detail-desc{padding:10px;border-radius:8px;background:var(--color-bg);border:1px solid var(--color-border)}.sup-detail-desc h5{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;text-transform:uppercase;color:var(--color-text-muted);margin:0 0 8px}.sup-detail-desc h5 .material-symbols-outlined{font-size:16px}.sup-detail-desc p{font-size:13px;line-height:1.6;margin:0;white-space:pre-wrap}.sup-detail-screenshot{border-radius:8px;overflow:hidden;border:1px solid var(--color-border)}.sup-detail-screenshot h5{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;text-transform:uppercase;color:var(--color-text-muted);margin:0;padding:8px 10px;border-bottom:1px solid var(--color-border);background:var(--color-bg)}.sup-detail-screenshot h5 .material-symbols-outlined{font-size:16px}.sup-detail-screenshot img{width:100%;display:block;cursor:zoom-in}.sup-reply-box{padding:10px 12px;border-radius:8px;border:1px solid rgba(59,130,246,.3);background:#3b82f60f}.sup-reply-box.resolved{border-color:#22c55e4d;background:#22c55e0f}.sup-reply-header{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:#3b82f6;margin-bottom:6px}.sup-reply-box.resolved .sup-reply-header{color:#22c55e}.sup-reply-header .material-symbols-outlined{font-size:16px}.sup-reply-date{margin-left:auto;font-weight:400;font-size:10px;opacity:.7}.sup-reply-box p{font-size:13px;line-height:1.5;margin:0;white-space:pre-wrap}.sup-admin-actions{padding:12px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-bg);display:flex;flex-direction:column;gap:12px}.sup-admin-actions h5{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;text-transform:uppercase;color:var(--color-text-muted);margin:0}.sup-admin-actions h5 .material-symbols-outlined{font-size:16px}.sup-status-section{display:flex;flex-direction:column;gap:6px}.sup-section-label{font-size:11px;color:var(--color-text-muted)}.sup-status-btns{display:flex;gap:4px;flex-wrap:wrap}.sup-status-btn{display:flex;align-items:center;gap:4px;padding:5px 10px;border:1px solid var(--btn-color, var(--color-border));border-radius:6px;background:transparent;color:var(--btn-color, var(--color-text-muted));font-size:11px;font-weight:500;cursor:pointer;transition:all .15s}.sup-status-btn:hover:not(:disabled){background:color-mix(in srgb,var(--btn-color) 15%,transparent)}.sup-status-btn.current{background:var(--btn-color);color:#fff;cursor:default}.sup-status-btn:disabled{opacity:.4;cursor:not-allowed}.sup-response-section{display:flex;flex-direction:column;gap:6px}.sup-response-section label{font-size:11px;color:var(--color-text-muted);font-weight:500}.sup-response-section textarea{width:100%;padding:8px 10px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg-elevated);color:var(--color-text);font-size:13px;font-family:inherit;resize:vertical;outline:none;transition:border-color .15s;box-sizing:border-box}.sup-response-section textarea:focus{border-color:var(--color-accent)}.sup-action-btns{display:flex;gap:6px;align-items:center}.sup-btn-primary{display:flex;align-items:center;gap:6px;padding:7px 14px;border:none;border-radius:8px;background:var(--color-accent);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}.sup-btn-primary:hover:not(:disabled){filter:brightness(1.1)}.sup-btn-primary:disabled{opacity:.5;cursor:not-allowed}.sup-btn-primary .material-symbols-outlined{font-size:16px}.sup-btn-ghost{display:flex;align-items:center;gap:4px;padding:7px 14px;border:1px solid var(--color-border);border-radius:8px;background:transparent;color:var(--color-text-muted);font-size:12px;cursor:pointer;transition:all .15s}.sup-btn-ghost:hover{color:var(--color-text);border-color:var(--color-text-muted)}.sup-btn-danger{display:flex;align-items:center;padding:7px 10px;border:1px solid rgba(239,68,68,.3);border-radius:8px;background:transparent;color:#ef4444;cursor:pointer;transition:all .15s}.sup-btn-danger:hover{background:#ef44441a}.sup-btn-danger .material-symbols-outlined{font-size:16px}.sup-create-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sup-create-modal{width:520px;max-width:90vw;max-height:80vh;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:14px;display:flex;flex-direction:column;box-shadow:0 12px 40px #0006;animation:modalIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.sup-create-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--color-border)}.sup-create-header h3{display:flex;align-items:center;gap:8px;margin:0;font-size:15px;font-weight:600}.sup-create-header h3 .material-symbols-outlined{font-size:22px;color:var(--color-accent)}.sup-create-body{padding:18px;overflow-y:auto;display:flex;flex-direction:column;gap:14px}.sup-form-field label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:6px;letter-spacing:.3px}.sup-form-field input,.sup-form-field textarea{width:100%;padding:8px 12px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg);color:var(--color-text);font-size:13px;font-family:inherit;outline:none;transition:border-color .15s;box-sizing:border-box}.sup-form-field input:focus,.sup-form-field textarea:focus{border-color:var(--color-accent)}.sup-form-field textarea{resize:vertical}.sup-selector-row{display:flex;gap:6px;flex-wrap:wrap}.sup-selector-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--color-border);border-radius:8px;background:transparent;color:var(--color-text-muted);font-size:12px;cursor:pointer;transition:all .15s}.sup-selector-btn:hover{border-color:var(--color-text-muted)}.sup-selector-btn.active{font-weight:600}.sup-selector-btn .material-symbols-outlined{font-size:16px}.sup-create-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:12px 18px;border-top:1px solid var(--color-border)}.sup-statusbar{display:flex;align-items:center;gap:10px;padding:4px 12px;border-top:1px solid var(--color-border);background:var(--color-bg-elevated);font-size:11px;color:var(--color-text-muted);flex-shrink:0}.sup-statusbar-filter{display:inline-flex;align-items:center;gap:4px;padding:1px 8px;border-radius:10px;background:var(--color-accent-bg, rgba(99, 102, 241, .1));color:var(--color-accent);font-size:10px;font-weight:500}.sup-statusbar-filter button{border:none;background:none;color:inherit;cursor:pointer;padding:0;display:flex;opacity:.7}.sup-statusbar-filter button:hover{opacity:1}.rapport-panel{display:flex;flex-direction:column;height:100%;overflow-y:auto}.rp-toolbar{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--color-border, #333);background:var(--color-surface, #1a1a2e);flex-wrap:wrap}.rp-period-selector{display:flex;gap:4px;background:var(--color-bg, #0f0f23);border-radius:8px;padding:3px}.rp-period-selector button{padding:6px 14px;border:none;border-radius:6px;background:transparent;color:var(--color-text-secondary, #888);cursor:pointer;font-size:.82rem;font-weight:500;transition:all .15s}.rp-period-selector button.active{background:var(--color-primary, #3b82f6);color:#fff}.rp-date-range{display:flex;align-items:center;gap:6px}.rp-date-range input{padding:5px 8px;border:1px solid var(--color-border, #333);border-radius:6px;background:var(--color-bg, #0f0f23);color:var(--color-text, #eee);font-size:.82rem}.rp-btn-refresh,.rp-btn-print{display:flex;align-items:center;gap:5px;padding:6px 14px;border:1px solid var(--color-border, #333);border-radius:6px;background:var(--color-surface, #1a1a2e);color:var(--color-text, #eee);cursor:pointer;font-size:.82rem;transition:all .15s}.rp-btn-print{background:var(--color-primary, #3b82f6);color:#fff;border-color:var(--color-primary, #3b82f6);margin-left:auto}.rp-btn-print:hover{opacity:.85}.rp-btn-refresh .material-symbols-outlined,.rp-btn-print .material-symbols-outlined{font-size:18px}.rp-loading,.rp-error{text-align:center;padding:40px 16px;color:var(--color-text-secondary, #888);font-size:.9rem}.rp-print-area{padding:16px}.rp-section{margin-bottom:24px}.rp-section h2{font-size:1rem;font-weight:700;color:var(--color-text, #eee);margin:0 0 12px;padding-bottom:6px;border-bottom:2px solid var(--color-primary, #3b82f6)}.rp-chart{position:relative;height:260px;background:var(--color-surface, #1a1a2e);border:1px solid var(--color-border, #333);border-radius:10px;padding:12px}.rp-chart-sm{position:relative;height:220px;background:var(--color-surface, #1a1a2e);border:1px solid var(--color-border, #333);border-radius:10px;padding:12px;min-width:200px}.rp-chart-row{display:grid;grid-template-columns:2fr 1fr;gap:12px}.rp-pie-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.rp-no-data{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-secondary, #888);font-size:.85rem}.print-only{display:none}.rp-print-header h1{font-size:1.5rem;margin:0 0 8px;color:#333}.rp-print-meta{display:flex;gap:24px;font-size:.85rem;color:#555;margin-bottom:16px;border-bottom:2px solid #3b82f6;padding-bottom:8px}.rp-print-footer{display:flex;justify-content:space-between;margin-top:24px;padding-top:8px;border-top:1px solid #ccc;font-size:.75rem;color:#888}@media print{body *{visibility:hidden}.rp-print-area,.rp-print-area *{visibility:visible}.rp-print-area{position:absolute;left:0;top:0;width:100%}@page{size:A4 portrait;margin:15mm 12mm}.no-print{display:none!important}.print-only{display:block!important}.rapport-panel,.rp-print-area,.rp-section,.rp-chart,.rp-chart-sm{background:#fff!important;color:#333!important;border-color:#ddd!important}.rp-section h2{color:#333!important;border-bottom-color:#3b82f6!important;font-size:14pt!important}.rp-print-meta,.rp-print-footer{display:flex!important}.rp-chart{height:200px!important;page-break-inside:avoid}.rp-chart-sm{height:180px!important;page-break-inside:avoid}.rp-chart-row{grid-template-columns:1.5fr 1fr!important}.rp-pie-grid{grid-template-columns:repeat(4,1fr)!important}.rp-section{page-break-inside:avoid;margin-bottom:16px!important}.page-break-before{page-break-before:always}.rp-print-area{padding:0!important}}@media (max-width: 768px){.rp-chart-row{grid-template-columns:1fr}.rp-pie-grid{grid-template-columns:repeat(2,1fr)}.rp-chart{height:200px}.rp-chart-sm{height:180px}}.gen-panel{display:flex;flex-direction:column;gap:1.25rem;max-width:100%}.gen-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.gen-toolbar-text{margin:0;max-width:42rem}.gen-alert{display:flex;align-items:center;gap:.5rem;padding:.6rem .85rem;border-radius:var(--radius, 8px);font-size:.85rem}.gen-alert-error{background:var(--color-danger-subtle, rgba(239, 68, 68, .12));color:var(--color-danger, #ef4444)}.gen-alert-success{background:var(--color-success-subtle, rgba(34, 197, 94, .12));color:var(--color-success, #22c55e)}.gen-alert .btn-flat{margin-left:auto}.gen-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media (max-width: 960px){.gen-grid{grid-template-columns:1fr}}.gen-section{background:var(--color-surface, rgba(255, 255, 255, .04));border:1px solid var(--color-border, rgba(255, 255, 255, .08));border-radius:var(--radius, 8px);overflow:hidden}.gen-section-header{display:flex;align-items:center;gap:.5rem;padding:.85rem 1rem;background:var(--color-surface-hover, rgba(255, 255, 255, .06));border-bottom:1px solid var(--color-border, rgba(255, 255, 255, .08))}.gen-section-header .material-symbols-outlined{font-size:1.25rem;color:var(--color-primary)}.gen-section-header h3{margin:0;font-size:.95rem;font-weight:600}.gen-section-body{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.gen-logo-row{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--color-surface-hover, rgba(255, 255, 255, .04));border-radius:var(--radius, 8px)}.gen-logo-box{width:64px;height:64px;border-radius:var(--radius, 8px);border:2px dashed var(--color-border, rgba(255, 255, 255, .12));display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;background:var(--color-surface, rgba(255, 255, 255, .04))}.gen-logo-box img{width:100%;height:100%;object-fit:cover}.gen-logo-box .material-symbols-outlined{font-size:28px;color:var( --text-tertiary, var(--color-text-tertiary, rgba(255, 255, 255, .35)) )}.gen-logo-actions{display:flex;flex-direction:column;gap:4px}.gen-color-pick{display:flex;align-items:center;gap:.5rem}.gen-color-pick input[type=color]{width:36px;height:36px;border:none;border-radius:6px;cursor:pointer;padding:2px}.gen-limits-bar{display:flex;flex-wrap:wrap;gap:.75rem;padding:.75rem;background:var(--color-surface-hover, rgba(255, 255, 255, .04));border-radius:var(--radius, 8px);margin-top:.25rem}.gen-limit-item{display:flex;align-items:center;gap:.35rem}.gen-limit-item .material-symbols-outlined{color:var(--text-tertiary, var(--color-text-tertiary))}.gen-divider{border:none;border-top:1px solid var(--color-border, rgba(255, 255, 255, .08));margin:.5rem 0}.gen-subsection-title{display:flex;align-items:center;gap:.35rem;font-size:.85rem;font-weight:600;color:var(--color-text-secondary, var(--text-secondary));margin-bottom:.25rem}.gen-toggle-list{display:flex;flex-direction:column;gap:.6rem}.gen-toggle-item{display:flex;align-items:flex-start;gap:.65rem;padding:.6rem .75rem;background:var(--color-surface-hover, rgba(255, 255, 255, .04));border-radius:var(--radius, 8px);cursor:pointer;transition:background .15s}.gen-toggle-item:hover{background:var(--color-surface-hover, rgba(255, 255, 255, .08))}.gen-toggle-item input[type=checkbox]{margin-top:2px;flex-shrink:0}.gen-toggle-label{display:block;font-size:.85rem;font-weight:500}.gen-toggle-desc{display:block;font-size:.75rem;color:var( --text-tertiary, var(--color-text-tertiary, rgba(255, 255, 255, .45)) );margin-top:2px}.gen-footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--color-border, rgba(255, 255, 255, .08))}.sso-status-row{display:flex;gap:8px;margin:12px 0 8px;flex-wrap:wrap}.sso-status-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:.72rem;font-weight:600;background:var(--color-bg-elevated, #f1f5f9);color:var(--color-text-secondary, #64748b);border:1px solid var(--color-border, #e2e8f0);text-transform:uppercase;letter-spacing:.3px}.sso-status-pill.on{background:#10b9811f;color:#059669;border-color:#10b98159}.sso-modal-tabs{display:flex;gap:4px;border-bottom:1px solid var(--color-border);margin-bottom:16px}.sso-modal-tabs button{display:flex;align-items:center;gap:6px;padding:10px 16px;border:none;background:transparent;border-bottom:2px solid transparent;color:var(--color-text-secondary);cursor:pointer;font-weight:500;font-size:.875rem}.sso-modal-tabs button:hover{background:var(--color-bg-elevated, rgba(0, 0, 0, .03))}.sso-modal-tabs button.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.sso-toggle-modern{display:flex;align-items:center;gap:12px;cursor:pointer;padding:12px 0;font-size:.875rem}.sso-toggle-modern input{display:none}.sso-toggle-track{position:relative;width:40px;height:22px;background:var(--color-border, #cbd5e1);border-radius:11px;transition:background .2s;flex-shrink:0}.sso-toggle-thumb{position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0003}.sso-toggle-modern input:checked+.sso-toggle-track{background:var(--color-primary, #3b82f6)}.sso-toggle-modern input:checked+.sso-toggle-track .sso-toggle-thumb{transform:translate(18px)}.sso-section-title{display:flex;align-items:center;gap:6px;margin:20px 0 8px;font-size:.85rem;font-weight:600;text-transform:uppercase;color:var(--color-text-secondary);letter-spacing:.5px}.sso-info-card{background:var(--color-bg-elevated, #f8fafc);border:1px solid var(--color-border);border-radius:8px;padding:14px 16px;margin:12px 0 16px}.sso-info-card-header{display:flex;align-items:center;gap:6px;margin-bottom:10px;font-size:.8rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.sso-url-line{display:flex;align-items:center;gap:10px;padding:6px 0;border-top:1px solid var(--color-border)}.sso-url-line:first-of-type{border-top:none}.sso-url-line label{min-width:160px;font-size:.72rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px}.sso-url-line code{flex:1;background:var(--color-bg-card, white);padding:6px 10px;border-radius:4px;font-size:.72rem;border:1px solid var(--color-border);word-break:break-all}.sso-token-card{background:var(--color-bg-elevated, #f8fafc);border:1px solid var(--color-border);border-radius:8px;padding:16px;margin-bottom:16px}.sso-token-current{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.sso-token-label{font-size:.7rem;text-transform:uppercase;color:var(--color-text-secondary);letter-spacing:.5px;margin-bottom:4px}.sso-token-prefix{background:var(--color-bg-card, white);padding:6px 12px;border-radius:4px;border:1px solid var(--color-border);font-family:monospace;font-size:.85rem}.sso-token-display{display:flex;align-items:center;gap:12px;background:#0f172a;padding:12px;border-radius:6px;margin-top:8px}.sso-token-display code{flex:1;color:#4ade80;font-family:Menlo,Consolas,monospace;font-size:.78rem;word-break:break-all;background:transparent}.sso-warning-banner{display:flex;align-items:center;gap:8px;background:#f59e0b1f;color:#b45309;border:1px solid rgba(245,158,11,.35);padding:10px 14px;border-radius:6px;font-size:.82rem;margin-bottom:8px}.sso-logs-table{width:100%;border-collapse:collapse}.sso-logs-table th,.sso-logs-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--color-border);font-size:.82rem}.sso-logs-table th{font-size:.7rem;text-transform:uppercase;color:var(--color-text-secondary);letter-spacing:.5px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid var(--color-border);background:var(--color-bg-elevated, transparent)}.comm-panel{display:flex;flex-direction:column;gap:1rem;height:100%}.comm-header{display:flex;align-items:center;justify-content:space-between}.comm-header-title{display:flex;align-items:center;gap:.75rem}.comm-header-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;flex-shrink:0}.comm-header-icon .material-symbols-outlined{font-size:1.4rem}.comm-header h2{font-size:1.15rem;font-weight:700;margin:0;line-height:1.2}.comm-header-desc{font-size:.82rem;color:var(--color-text-secondary);margin:.1rem 0 0}.comm-stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.75rem}.comm-stat-card{display:flex;align-items:center;gap:.75rem;padding:.65rem .9rem;background:var(--color-surface);border-radius:10px;border-left:3px solid var(--color-primary);box-shadow:0 1px 3px #0000000f}.comm-stat-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.comm-stat-icon .material-symbols-outlined{font-size:1.15rem}.comm-stat-value{font-size:1.25rem;font-weight:700;line-height:1.1}.comm-stat-label{font-size:.75rem;color:var(--color-text-secondary);margin-top:.1rem}.comm-tabs{display:flex;gap:.25rem;border-bottom:2px solid var(--color-border);padding-bottom:0}.comm-tab{display:flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:.9rem;font-weight:500;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.comm-tab:hover{color:var(--color-text)}.comm-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.comm-tab .material-symbols-outlined{font-size:1.1rem}.comm-content{flex:1;overflow-y:auto}.comm-smtp,.comm-quotas{display:grid;grid-template-columns:260px 1fr;gap:1.5rem;min-height:400px}.comm-smtp-list{border-right:1px solid var(--color-border);padding-right:1rem;overflow-y:auto;max-height:70vh}.comm-smtp-list h3{display:flex;align-items:center;gap:.4rem;font-size:.95rem;margin-bottom:.75rem;color:var(--color-text-secondary)}.comm-smtp-list h3 .material-symbols-outlined{font-size:1.1rem}.comm-tenant-btn{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;border:none;background:transparent;color:var(--color-text);cursor:pointer;border-radius:6px;font-size:.85rem;text-align:left;transition:background .15s}.comm-tenant-btn:hover{background:var(--color-surface-hover)}.comm-tenant-btn.active{background:var(--color-primary-alpha, rgba(59,130,246,.12));color:var(--color-primary);font-weight:600}.comm-tenant-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comm-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.comm-status-dot.status-none{background:var(--color-border)}.comm-status-dot.status-inactive{background:var(--color-text-secondary)}.comm-status-dot.status-ok{background:var(--color-success)}.comm-status-dot.status-error{background:var(--color-danger)}.comm-status-dot.status-untested{background:var(--color-warning)}.comm-smtp-form{padding:0 .5rem}.comm-smtp-form h3{font-size:1rem;margin-bottom:1rem}.comm-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:var(--color-text-secondary);gap:.5rem}.comm-placeholder .material-symbols-outlined{font-size:3rem;opacity:.3}.comm-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1.25rem}.comm-form-grid label{display:flex;flex-direction:column;gap:.25rem;font-size:.82rem;font-weight:500;color:var(--color-text-secondary)}.comm-form-grid input,.comm-form-grid select,.comm-form-grid textarea{padding:.45rem .6rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface);color:var(--color-text);font-size:.85rem}.comm-form-grid input:focus,.comm-form-grid select:focus,.comm-form-grid textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-alpha, rgba(59,130,246,.15))}.comm-form-grid .span-2{grid-column:span 2}.comm-checkbox{flex-direction:row!important;align-items:center!important;gap:.5rem!important}.comm-checkbox input[type=checkbox]{width:auto;accent-color:var(--color-primary)}.comm-pct-input{display:flex;align-items:center;gap:.3rem}.comm-pct-input input{width:80px}.comm-actions{display:flex;gap:.75rem;margin-top:1.25rem}.comm-msg{padding:.5rem .75rem;border-radius:6px;font-size:.85rem;margin-bottom:.75rem}.comm-msg.success{background:var(--color-success-bg, rgba(34,197,94,.1));color:var(--color-success)}.comm-msg.error{background:var(--color-danger-bg, rgba(239,68,68,.1));color:var(--color-danger)}.comm-loading{padding:2rem;text-align:center;color:var(--color-text-secondary)}.comm-quota-badge{font-size:.75rem;padding:.1rem .4rem;border-radius:4px;background:var(--color-surface-hover);color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.comm-quota-badge.warning{background:var(--color-warning-bg, rgba(234,179,8,.15));color:var(--color-warning);font-weight:600}.comm-quota-bar{display:flex;align-items:center;gap:.5rem;margin-top:.75rem}.comm-quota-bar.compact{margin-top:0}.comm-quota-track{flex:1;height:8px;background:var(--color-surface-hover);border-radius:4px;position:relative;overflow:visible}.comm-quota-fill{height:100%;border-radius:4px;background:var(--color-primary);transition:width .4s ease}.comm-quota-fill.warning{background:var(--color-warning)}.comm-quota-fill.critical{background:var(--color-danger)}.comm-quota-marker{position:absolute;top:-3px;width:2px;height:14px;background:var(--color-danger);border-radius:1px;opacity:.6}.comm-quota-pct{font-size:.8rem;font-weight:600;min-width:3em;text-align:right;font-variant-numeric:tabular-nums}.comm-quota-pct.warning{color:var(--color-warning)}.comm-quota-pct.critical{color:var(--color-danger)}.comm-dashboard h3{display:flex;align-items:center;gap:.4rem;font-size:1rem;margin-bottom:1rem}.comm-dashboard h4{font-size:.95rem;margin:1.5rem 0 .75rem;color:var(--color-text-secondary)}.comm-kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.comm-kpi-card{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--color-surface);border-radius:8px;border-left:3px solid var(--color-primary);box-shadow:0 1px 3px #0000000f}.comm-kpi-card .material-symbols-outlined{font-size:1.5rem}.comm-kpi-value{font-size:1.25rem;font-weight:700}.comm-kpi-label{font-size:.78rem;color:var(--color-text-secondary)}.comm-table-wrap{overflow-x:auto}.comm-table{width:100%;border-collapse:collapse;font-size:.85rem}.comm-table th{text-align:left;padding:.5rem .75rem;background:var(--color-surface-hover);color:var(--color-text-secondary);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;border-bottom:2px solid var(--color-border)}.comm-table td{padding:.5rem .75rem;border-bottom:1px solid var(--color-border);vertical-align:middle}.comm-table tr.warning-row{background:var(--color-warning-bg, rgba(234,179,8,.08))}.comm-empty{text-align:center;color:var(--color-text-secondary);padding:1.5rem!important}.comm-sms-config{max-width:700px}.comm-sms-config h3{display:flex;align-items:center;gap:.4rem;margin-bottom:.5rem}.comm-hint{font-size:.82rem;color:var(--color-text-secondary);margin-bottom:1rem}.presence-sign-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-app);padding:var(--sp-4)}.presence-sign-container{width:100%;max-width:440px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.presence-sign-header{padding:var(--sp-5) var(--sp-5) var(--sp-4);text-align:center;border-bottom:1px solid var(--color-border)}.presence-sign-header .presence-sign-logo{font-size:1.1rem;font-weight:700;color:var(--color-primary);letter-spacing:.04em;margin-bottom:var(--sp-3)}.presence-sign-header h2{font-size:1.25rem;margin-bottom:var(--sp-2)}.presence-sign-session-info{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--sp-2);margin-top:var(--sp-2)}.presence-sign-body{padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-4)}.presence-sign-canvas-wrap{position:relative;border:2px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;background:#fff;touch-action:none}.presence-sign-canvas-wrap canvas{display:block;width:100%;cursor:crosshair}.presence-sign-canvas-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;color:#ccc;font-size:.9rem;font-style:italic}.presence-sign-canvas-wrap.has-drawn .presence-sign-canvas-placeholder{display:none}.presence-sign-canvas-actions{display:flex;justify-content:flex-end;margin-top:var(--sp-1)}.presence-sign-gps{display:flex;align-items:center;gap:var(--sp-2);font-size:.85rem;padding:var(--sp-2) var(--sp-3);border-radius:var(--radius);background:var(--color-surface-variant)}.presence-sign-gps.gps-capturing{color:var(--color-warning)}.presence-sign-gps.gps-ok{color:var(--color-success)}.presence-sign-gps.gps-unavailable{color:var(--color-text-secondary)}.presence-sign-success{padding:var(--sp-10) var(--sp-5);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--sp-3)}.presence-sign-success .success-icon{width:72px;height:72px;border-radius:50%;background:var(--color-success-subtle);display:flex;align-items:center;justify-content:center}.presence-sign-success .success-icon .material-symbols-outlined{font-size:36px;color:var(--color-success)}.presence-sign-success h3{font-size:1.25rem;color:var(--color-success)}.presence-sign-success p{color:var(--color-text-secondary);font-size:.9rem}.presence-sign-error{padding:var(--sp-10) var(--sp-5);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--sp-3)}.presence-sign-error .error-icon{width:72px;height:72px;border-radius:50%;background:var(--color-danger-subtle);display:flex;align-items:center;justify-content:center}.presence-sign-error .error-icon .material-symbols-outlined{font-size:36px;color:var(--color-danger)}.presence-sign-error h3{font-size:1.15rem;color:var(--color-danger)}.presence-sign-error p{color:var(--color-text-secondary);font-size:.9rem;max-width:320px}.presence-sign-loading{padding:var(--sp-12) var(--sp-5);text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);color:var(--color-text-secondary)}@media (max-width: 480px){.presence-sign-page{padding:0;align-items:flex-start}.presence-sign-container{max-width:100%;border-radius:0;border:none;min-height:100vh;box-shadow:none}}.usb{position:fixed;right:0;top:48px;bottom:0;width:42px;z-index:400;background:var(--color-surface, #fff);border-left:1px solid var(--color-border, #e2e8f0);display:flex;flex-direction:column;transition:width .22s ease;overflow:hidden}.usb-expanded{width:280px;box-shadow:-2px 0 12px #00000014}.usb-icons{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 0;flex:1}.usb-icon-btn{position:relative;width:36px;height:36px;border:none;background:transparent;color:var(--color-text-secondary, #64748b);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.usb-icon-btn:hover{background:var(--color-hover, #f1f5f9);color:var(--color-text, #1e293b)}.usb-icon-logout{margin-top:auto}.usb-icon-logout:hover{color:var(--color-danger, #ef4444)}.usb-icon-sep{width:24px;height:1px;background:var(--color-border, #e2e8f0);margin:6px 0}.usb-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;font-size:10px;font-weight:600;line-height:16px;text-align:center;border-radius:8px;background:var(--color-primary, #6366f1);color:#fff;padding:0 4px}.usb-badge-warn{background:var(--color-warning, #f59e0b)}.usb-badge-info{background:var(--color-info, #3b82f6)}.usb-expanded-content{display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.usb-close-btn{position:absolute;top:8px;right:8px;z-index:2;width:28px;height:28px;border:none;background:transparent;color:var(--color-text-secondary, #64748b);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s,color .15s}.usb-close-btn:hover{background:var(--color-hover, #f1f5f9);color:var(--color-text, #1e293b)}[data-theme=dark] .usb-close-btn:hover{background:var(--color-hover, #334155)}.usb-user-header{display:flex;align-items:center;gap:10px;padding:12px 14px;border:none;background:transparent;cursor:pointer;text-align:left;width:100%;border-bottom:1px solid var(--color-border, #e2e8f0);transition:background .15s}.usb-user-header:hover{background:var(--color-hover, #f1f5f9)}.usb-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;background:var(--color-bg-tertiary, #e2e8f0);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--color-text-secondary, #64748b)}.usb-avatar img{width:100%;height:100%;object-fit:cover}.usb-user-info{display:flex;flex-direction:column;min-width:0}.usb-username{font-size:13px;font-weight:600;color:var(--color-text, #1e293b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.usb-role{font-size:11px;color:var(--color-text-secondary, #64748b);text-transform:uppercase}.usb-sections{flex:1;overflow-y:auto;padding:4px 0}.usb-section-header{display:flex;align-items:center;gap:8px;width:100%;padding:8px 14px;border:none;background:transparent;cursor:pointer;font-size:12px;font-weight:600;color:var(--color-text-secondary, #64748b);text-transform:uppercase;letter-spacing:.3px;transition:background .15s,color .15s}.usb-section-header:hover{background:var(--color-hover, #f1f5f9);color:var(--color-text, #1e293b)}.usb-section-open{color:var(--color-primary, #6366f1)}.usb-section-label{flex:1;text-align:left}.usb-count{min-width:18px;height:18px;font-size:10px;font-weight:600;line-height:18px;text-align:center;border-radius:9px;background:var(--color-bg-tertiary, #e2e8f0);color:var(--color-text-secondary, #64748b);padding:0 5px}.usb-count-warn{background:var(--color-warning, #f59e0b);color:#fff}.usb-count-info{background:var(--color-info, #3b82f6);color:#fff}.usb-section-body{padding:4px 10px 8px}.usb-item{display:flex;align-items:center;gap:6px;padding:5px 8px;border-radius:6px;cursor:pointer;font-size:12px;color:var(--color-text, #1e293b);transition:background .12s}.usb-item:hover{background:var(--color-hover, #f1f5f9)}.usb-item-icon{flex-shrink:0;color:var(--color-text-secondary, #64748b)}.usb-item-label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.usb-note-text{font-style:italic;color:var(--color-text-secondary, #64748b)}.usb-badge-statut{font-size:9px;font-weight:600;padding:1px 6px;border-radius:4px;text-transform:uppercase;background:var(--color-bg-tertiary, #e2e8f0);color:var(--color-text-secondary, #64748b)}.usb-badge-en_cours{background:#dbeafe;color:#1d4ed8}.usb-badge-termine{background:#dcfce7;color:#15803d}.usb-badge-clos{background:#f3f4f6;color:#6b7280}.usb-badge-tk{font-size:9px;font-weight:600;padding:1px 6px;border-radius:4px;text-transform:uppercase}.usb-badge-tk-open{background:#fef3c7;color:#92400e}.usb-badge-tk-in_progress{background:#dbeafe;color:#1d4ed8}.usb-badge-tk-closed{background:#f3f4f6;color:#6b7280}.usb-badge-tk-resolved{background:#dcfce7;color:#15803d}.usb-item-tags{display:flex;align-items:center;gap:3px;flex-shrink:0}.usb-tag-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.usb-tag-more{font-size:9px;color:var(--color-text-secondary, #64748b)}.usb-bm-item{padding-right:4px}.usb-bm-link{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--color-primary, #6366f1);text-decoration:none;font-size:12px}.usb-bm-link:hover{text-decoration:underline}.usb-bm-form{display:flex;flex-direction:column;gap:6px;padding:6px 0}.usb-bm-form-actions{display:flex;gap:6px}.usb-btn-sm{border:none;background:transparent;cursor:pointer;color:var(--color-text-secondary, #64748b);padding:3px;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s,color .12s}.usb-btn-sm:hover{background:var(--color-hover, #f1f5f9)}.usb-btn-danger:hover{color:var(--color-danger, #ef4444)}.usb-btn-primary{background:var(--color-primary, #6366f1);color:#fff;padding:3px 10px;font-size:12px;font-weight:500}.usb-btn-primary:hover{opacity:.9;background:var(--color-primary, #6366f1)}.usb-add-btn{display:flex;align-items:center;gap:6px;width:100%;padding:6px 8px;border:1px dashed var(--color-border, #e2e8f0);background:transparent;color:var(--color-text-secondary, #64748b);border-radius:6px;cursor:pointer;font-size:12px;margin-top:4px;transition:border-color .15s,color .15s}.usb-add-btn:hover{border-color:var(--color-primary, #6366f1);color:var(--color-primary, #6366f1)}.usb-input{width:100%;padding:5px 8px;border:1px solid var(--color-border, #e2e8f0);border-radius:6px;font-size:12px;background:var(--color-surface, #fff);color:var(--color-text, #1e293b);outline:none;transition:border-color .15s}.usb-input:focus{border-color:var(--color-primary, #6366f1)}.usb-rename-input{flex:1;min-width:0}.usb-pj-size{font-size:10px;color:var(--color-text-secondary, #64748b);flex-shrink:0}.usb-pj-name{cursor:text}.usb-empty{padding:8px 0;font-size:12px;color:var(--color-text-secondary, #64748b);font-style:italic;text-align:center}.usb-footer-link{display:block;width:100%;padding:10px 14px;border:none;background:transparent;color:var(--color-primary, #6366f1);font-size:12px;font-weight:500;text-align:center;cursor:pointer;border-top:1px solid var(--color-border, #e2e8f0);transition:background .15s}.usb-footer-link:hover{background:var(--color-hover, #f1f5f9)}.usb-tooltip{position:fixed;z-index:9999;background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:8px;padding:10px 14px;box-shadow:0 4px 16px #0000001f;min-width:180px;max-width:300px;font-size:12px;color:var(--color-text, #1e293b);pointer-events:auto}.usb-tt-row{margin-bottom:4px}.usb-tt-row strong{color:var(--color-text-secondary, #64748b);margin-right:6px}.usb-tt-content{margin-bottom:6px;white-space:pre-wrap;max-height:120px;overflow-y:auto}.usb-tt-date{font-size:10px;color:var(--color-text-secondary, #64748b);margin-top:4px}.usb-tt-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.usb-tt-tag{font-size:10px;font-weight:500;color:#fff;padding:1px 8px;border-radius:10px}.usb-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#0009;display:flex;align-items:center;justify-content:center}.usb-preview-panel{position:relative;max-width:90vw;max-height:90vh;background:var(--color-surface, #fff);border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #0003}.usb-preview-close{position:absolute;top:8px;right:8px;z-index:1;width:32px;height:32px;border:none;background:#00000080;color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.usb-preview-img{max-width:90vw;max-height:90vh;display:block}.usb-preview-iframe{width:80vw;height:85vh;border:none}[data-theme=dark] .usb{background:var(--color-surface, #1e293b);border-left-color:var(--color-border, #334155)}[data-theme=dark] .usb-icon-btn:hover,[data-theme=dark] .usb-user-header:hover,[data-theme=dark] .usb-section-header:hover,[data-theme=dark] .usb-item:hover{background:var(--color-hover, #334155)}[data-theme=dark] .usb-tooltip{background:var(--color-surface, #1e293b);border-color:var(--color-border, #334155)}[data-theme=dark] .usb-input{background:var(--color-bg, #0f172a);border-color:var(--color-border, #334155)}[data-theme=dark] .usb-preview-panel{background:var(--color-surface, #1e293b)}.up-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;background:#00000080}.up-panel{position:fixed;right:0;top:0;bottom:0;width:580px;max-width:100vw;z-index:9001;background:var(--color-surface, #fff);display:flex;flex-direction:column;box-shadow:-4px 0 24px #00000026;animation:up-slide-in .25s ease}@keyframes up-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.up-header{display:flex;align-items:center;gap:16px;padding:24px;border-bottom:1px solid var(--color-border, #e2e8f0);flex-shrink:0;background:var(--color-bg-alt, linear-gradient(135deg, var(--color-surface, #fff), var(--color-hover, #f8fafc)))}.up-avatar-zone{position:relative}.up-avatar{width:64px;height:64px;border-radius:50%;overflow:hidden;background:var(--color-bg-tertiary, #e2e8f0);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary, #64748b);position:relative}.up-avatar-profile{width:72px;height:72px;border:3px solid var(--color-primary, #6366f1);box-shadow:0 0 0 3px #6366f126}.up-avatar-initials{font-size:22px;font-weight:700;text-transform:uppercase;color:var(--color-primary, #6366f1);-webkit-user-select:none;user-select:none}.up-avatar img{width:100%;height:100%;object-fit:cover}.up-avatar-actions{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:4px;background:#00000080;border-radius:50%;opacity:0;transition:opacity .2s}.up-avatar:hover .up-avatar-actions{opacity:1}.up-avatar-btn{width:26px;height:26px;border:none;background:#fff3;color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.up-avatar-btn:hover{background:#ffffff59}.up-avatar-btn-danger:hover{background:#ef4444b3}.up-header-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.up-header-fullname{font-size:18px;font-weight:700;color:var(--color-text, #1e293b);line-height:1.2}.up-header-username{font-size:13px;color:var(--color-text-secondary, #64748b);font-family:var(--font-mono, monospace)}.up-header-meta{display:flex;align-items:center;gap:8px;margin-top:4px;flex-wrap:wrap}.up-header-role-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;background:var(--color-primary, #6366f1);color:#fff}.up-header-email{font-size:12px;color:var(--color-text-secondary, #64748b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-header-role{font-size:12px;color:var(--color-text-secondary, #64748b);text-transform:uppercase}.up-close-btn{width:36px;height:36px;border:none;background:transparent;color:var(--color-text-secondary, #64748b);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}.up-close-btn:hover{background:var(--color-hover, #f1f5f9);color:var(--color-text, #1e293b)}.up-hidden-input{display:none}.up-tabs{display:flex;border-bottom:1px solid var(--color-border, #e2e8f0);padding:0 20px;flex-shrink:0;overflow-x:auto;gap:2px;background:var(--color-surface, #fff)}.up-tab{display:flex;align-items:center;gap:6px;padding:12px 14px;border:none;background:transparent;color:var(--color-text-secondary, #64748b);cursor:pointer;font-size:13px;font-weight:500;white-space:nowrap;border-bottom:2.5px solid transparent;transition:color .15s,border-color .15s,background .15s;border-radius:6px 6px 0 0}.up-tab:hover{color:var(--color-text, #1e293b);background:var(--color-hover, rgba(0,0,0,.03))}.up-tab-active{color:var(--color-primary, #6366f1);border-bottom-color:var(--color-primary, #6366f1);font-weight:600}.up-body{flex:1;overflow-y:auto;padding:0}.up-tab-content{padding:20px 24px}.up-pref-group{margin-bottom:20px;padding:14px 16px;background:var(--color-bg-tertiary, rgba(0,0,0,.02));border-radius:12px;border:1px solid var(--color-border, #e2e8f0)}.up-pref-label{display:block;font-size:11px;font-weight:600;color:var(--color-text-secondary, #64748b);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.up-pref-toggle{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border:1px solid var(--color-border, #e2e8f0);background:var(--color-surface, #fff);color:var(--color-text, #1e293b);border-radius:10px;cursor:pointer;font-size:13px;font-weight:500;transition:background .15s,border-color .15s,box-shadow .15s}.up-pref-toggle:hover{background:var(--color-hover, #f1f5f9);border-color:var(--color-primary, #6366f1);box-shadow:0 0 0 2px #6366f11a}.up-pref-chips{display:flex;gap:8px}.up-pref-chip{padding:7px 18px;border:1.5px solid var(--color-border, #e2e8f0);background:transparent;color:var(--color-text, #1e293b);border-radius:20px;cursor:pointer;font-size:13px;font-weight:500;transition:all .15s}.up-pref-chip:hover{border-color:var(--color-primary, #6366f1);background:#6366f10d}.up-pref-chip-active{background:var(--color-primary, #6366f1);color:#fff;border-color:var(--color-primary, #6366f1);box-shadow:0 2px 8px #6366f140}.up-pref-autosave{font-size:12px;color:var(--color-text-secondary, #64748b);font-style:italic;padding:8px 0;border-top:1px solid var(--color-border, #e2e8f0);margin-top:8px}.up-zoom-control{display:inline-flex;align-items:center;border:1.5px solid var(--color-border, #e2e8f0);border-radius:10px;overflow:hidden;background:var(--color-surface, #fff)}.up-zoom-btn{width:38px;height:38px;border:none;background:transparent;color:var(--color-text, #1e293b);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.up-zoom-btn:hover:not(:disabled){background:var(--color-primary, #6366f1);color:#fff}.up-zoom-btn:disabled{opacity:.3;cursor:default}.up-zoom-value{min-width:56px;height:38px;border:none;border-left:1.5px solid var(--color-border, #e2e8f0);border-right:1.5px solid var(--color-border, #e2e8f0);background:transparent;color:var(--color-text, #1e293b);font-size:14px;font-weight:600;text-align:center;cursor:pointer}.up-tag-manager{margin-top:20px;padding-top:20px;border-top:1px solid var(--color-border, #e2e8f0)}.up-tag-manager-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--color-text, #1e293b);margin:0 0 14px}.up-tag-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--color-bg-tertiary, #e2e8f0);color:var(--color-text-secondary, #64748b);font-size:11px;font-weight:600}.up-tag-add-card{display:flex;flex-direction:column;gap:10px;padding:14px;background:var(--color-bg-tertiary, rgba(0,0,0,.02));border:1px dashed var(--color-border, #e2e8f0);border-radius:10px;margin-bottom:14px}.up-tag-add-row{display:flex;align-items:center;gap:8px}.up-tag-add-preview{width:18px;height:18px;border-radius:50%;flex-shrink:0;box-shadow:0 1px 3px #00000026;transition:background .15s}.up-tag-add-input{flex:1;min-width:0}.up-tag-add{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:12px}.up-color-swatches{display:flex;gap:5px;flex-wrap:wrap}.up-color-swatches-sm{gap:4px}.up-color-swatch{width:24px;height:24px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;transition:transform .12s,border-color .12s,box-shadow .12s}.up-color-swatch:hover{transform:scale(1.15);box-shadow:0 2px 6px #0003}.up-color-swatch-active{border-color:var(--color-text, #1e293b);transform:scale(1.15);box-shadow:0 0 0 2px var(--color-surface, #fff),0 0 0 4px var(--color-text, #1e293b)}.up-color-swatch-sm{width:20px;height:20px}.up-tag-list{display:flex;flex-direction:column;gap:6px}.up-tag-card{border:1px solid var(--color-border, #e2e8f0);border-radius:10px;padding:10px 14px;background:var(--color-surface, #fff);transition:border-color .15s,box-shadow .15s}.up-tag-card:hover{border-color:var(--color-border-hover, #cbd5e1);box-shadow:0 1px 4px #0000000f}.up-tag-card-row{display:flex;align-items:center;gap:10px}.up-tag-card-actions{display:flex;align-items:center;gap:2px;margin-left:auto;opacity:.5;transition:opacity .15s}.up-tag-card:hover .up-tag-card-actions{opacity:1}.up-tag-edit-form{display:flex;flex-direction:column;gap:8px}.up-tag-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--color-border-light, #f1f5f9)}.up-tag-dot-lg{width:14px;height:14px;border-radius:50%;flex-shrink:0;box-shadow:0 1px 3px #00000026}.up-tag-label{flex:1;font-size:13px;font-weight:500;color:var(--color-text, #1e293b)}.up-tag-filter-bar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--color-border-light, #f1f5f9)}.up-tag-chip{padding:3px 12px;border:1px solid var(--color-border, #e2e8f0);background:transparent;border-radius:14px;cursor:pointer;font-size:12px;font-weight:500;transition:all .15s}.up-tag-chip:hover{opacity:.85}.up-tag-chip-active{background:var(--color-primary, #6366f1);color:#fff;border-color:var(--color-primary, #6366f1)}.up-tag-selector{position:relative;display:inline-flex}.up-tag-selector-btn{border:none;background:transparent;color:var(--color-text-secondary, #64748b);cursor:pointer;padding:2px;border-radius:4px;display:flex;align-items:center;transition:color .12s}.up-tag-selector-btn:hover{color:var(--color-primary, #6366f1)}.up-tag-selector-dropdown{position:absolute;top:100%;left:0;z-index:100;background:var(--color-surface, #fff);border:1px solid var(--color-border, #e2e8f0);border-radius:8px;padding:6px;min-width:160px;box-shadow:0 4px 12px #0000001a}.up-tag-selector-item{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:4px;cursor:pointer;font-size:12px;color:var(--color-text, #1e293b);transition:background .12s}.up-tag-selector-item:hover{background:var(--color-hover, #f1f5f9)}.up-tag-selector-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--color-primary, #6366f1)}.up-tag-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.up-tag-badges{display:inline-flex;gap:4px;flex-wrap:wrap}.up-tag-badge{font-size:10px;font-weight:500;color:#fff;padding:1px 8px;border-radius:10px}.up-input{width:100%;padding:8px 12px;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:13px;background:var(--color-surface, #fff);color:var(--color-text, #1e293b);outline:none;transition:border-color .15s}.up-input:focus{border-color:var(--color-primary, #6366f1)}.up-input-sm{padding:5px 8px;font-size:12px}.up-textarea{width:100%;padding:8px 12px;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:13px;font-family:inherit;background:var(--color-surface, #fff);color:var(--color-text, #1e293b);outline:none;resize:vertical;transition:border-color .15s}.up-textarea:focus{border-color:var(--color-primary, #6366f1)}.up-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--color-border, #e2e8f0);background:var(--color-surface, #fff);color:var(--color-text, #1e293b);border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;transition:all .15s}.up-btn:hover{background:var(--color-hover, #f1f5f9)}.up-btn-primary{background:var(--color-primary, #6366f1);color:#fff;border-color:var(--color-primary, #6366f1)}.up-btn-primary:hover{opacity:.9;background:var(--color-primary, #6366f1)}.up-btn-sm{padding:5px 12px;font-size:12px}.up-btn-icon{border:none;background:transparent;color:var(--color-text-secondary, #64748b);cursor:pointer;padding:4px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;transition:background .12s,color .12s}.up-btn-icon:hover{background:var(--color-hover, #f1f5f9);color:var(--color-text, #1e293b)}.up-btn-icon-danger:hover{color:var(--color-danger, #ef4444)}.up-empty{padding:16px 0;font-size:13px;color:var(--color-text-secondary, #64748b);font-style:italic;text-align:center}.up-section-title{font-size:16px;font-weight:600;color:var(--color-text, #1e293b);margin:0 0 16px}.up-form-group{margin-bottom:14px}.up-form-label{display:block;font-size:13px;font-weight:500;color:var(--color-text, #1e293b);margin-bottom:4px}.up-form-hint{font-size:11px;color:var(--color-text-secondary, #64748b);margin-top:2px;display:block}.up-pwd-msg{padding:8px 12px;border-radius:6px;font-size:13px;margin-bottom:12px}.up-pwd-success{background:#dcfce7;color:#15803d}.up-pwd-error{background:#fef2f2;color:#dc2626}.up-fav-card{border:1px solid var(--color-border, #e2e8f0);border-radius:8px;padding:12px;margin-bottom:10px;transition:border-color .15s}.up-fav-card:hover{border-color:var(--color-primary, #6366f1)}.up-fav-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.up-fav-star{color:var(--color-warning, #f59e0b);flex-shrink:0}.up-fav-drm{font-weight:600;font-size:13px;color:var(--color-text, #1e293b)}.up-fav-badge{font-size:9px;font-weight:600;padding:1px 6px;border-radius:4px;text-transform:uppercase}.up-fav-badge-en_cours{background:#dbeafe;color:#1d4ed8}.up-fav-badge-termine{background:#dcfce7;color:#15803d}.up-fav-badge-clos{background:#f3f4f6;color:#6b7280}.up-fav-chip{font-size:10px;padding:1px 8px;border-radius:10px;background:var(--color-bg-tertiary, #e2e8f0);color:var(--color-text-secondary, #64748b)}.up-fav-prio{font-size:10px;font-weight:600;color:var(--color-text-secondary, #64748b)}.up-fav-detail{font-size:12px;color:var(--color-text-secondary, #64748b);margin-bottom:4px}.up-fav-comment{font-size:12px;color:var(--color-text, #1e293b);font-style:italic;padding:4px 0}.up-fav-comment-edit{display:flex;gap:6px;align-items:center;padding:4px 0}.up-fav-actions{display:flex;align-items:center;gap:4px;margin-top:6px}.up-fav-date{font-size:10px;color:var(--color-text-secondary, #64748b);margin-left:auto}.up-fav-navigate{border:none;background:var(--color-primary, #6366f1);color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.up-note-add{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.up-note-card{border:1px solid var(--color-border, #e2e8f0);border-radius:8px;padding:10px 12px;margin-bottom:8px}.up-note-meta{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}.up-note-date{font-size:10px;color:var(--color-text-secondary, #64748b)}.up-note-edited{font-size:10px;color:var(--color-text-secondary, #64748b);font-style:italic}.up-note-content{font-size:13px;color:var(--color-text, #1e293b);white-space:pre-wrap;line-height:1.5}.up-note-edit{display:flex;flex-direction:column;gap:6px}.up-note-edit-actions{display:flex;gap:6px}.up-note-actions{display:flex;align-items:center;gap:4px;margin-top:6px}.up-pj-card{border:1px solid var(--color-border, #e2e8f0);border-radius:8px;padding:10px 12px;margin-bottom:8px}.up-pj-info{display:flex;align-items:center;gap:8px}.up-pj-icon{color:var(--color-text-secondary, #64748b);flex-shrink:0}.up-pj-name{flex:1;min-width:0;font-size:13px;font-weight:500;color:var(--color-text, #1e293b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-pj-size{font-size:11px;color:var(--color-text-secondary, #64748b);flex-shrink:0}.up-pj-meta{display:flex;gap:12px;margin:4px 0}.up-pj-date{font-size:10px;color:var(--color-text-secondary, #64748b)}.up-pj-mime{font-size:10px;color:var(--color-text-secondary, #64748b);font-family:monospace}.up-pj-actions{display:flex;align-items:center;gap:4px;margin-top:4px}.up-avlib-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9500;background:#00000080;display:flex;align-items:center;justify-content:center}.up-avlib-modal{background:var(--color-surface, #fff);border-radius:12px;width:480px;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003}.up-avlib-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border, #e2e8f0)}.up-avlib-header h3{margin:0;font-size:16px;color:var(--color-text, #1e293b)}.up-avlib-search{padding:12px 20px}.up-avlib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px;padding:0 20px 20px;overflow-y:auto;flex:1}.up-avlib-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;border:1px solid var(--color-border, #e2e8f0);border-radius:8px;background:transparent;cursor:pointer;transition:border-color .15s,background .15s}.up-avlib-item:hover{border-color:var(--color-primary, #6366f1);background:var(--color-hover, #f1f5f9)}.up-avlib-item img{width:52px;height:52px;border-radius:50%;object-fit:cover}.up-avlib-item span{font-size:10px;color:var(--color-text-secondary, #64748b);text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.up-preview-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#0009;display:flex;align-items:center;justify-content:center}.up-preview-panel{position:relative;max-width:90vw;max-height:90vh;background:var(--color-surface, #fff);border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #0003}.up-preview-close{position:absolute;top:8px;right:8px;z-index:1;width:32px;height:32px;border:none;background:#00000080;color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.up-preview-img{max-width:90vw;max-height:90vh;display:block}.up-preview-iframe{width:80vw;height:85vh;border:none}[data-theme=dark] .up-panel{background:var(--color-surface, #1e293b)}[data-theme=dark] .up-overlay{background:#000000a6}[data-theme=dark] .up-pref-toggle,[data-theme=dark] .up-input,[data-theme=dark] .up-textarea{background:var(--color-bg, #0f172a);border-color:var(--color-border, #334155)}[data-theme=dark] .up-fav-card,[data-theme=dark] .up-note-card,[data-theme=dark] .up-pj-card{border-color:var(--color-border, #334155)}[data-theme=dark] .up-tag-selector-dropdown{background:var(--color-surface, #1e293b);border-color:var(--color-border, #334155)}[data-theme=dark] .up-avlib-modal,[data-theme=dark] .up-preview-panel{background:var(--color-surface, #1e293b)}[data-theme=dark] .up-pwd-success{background:#064e3b;color:#6ee7b7}[data-theme=dark] .up-pwd-error{background:#450a0a;color:#fca5a5}.chat-panel{position:fixed;top:0;right:0;bottom:0;width:340px;display:flex;flex-direction:column;background:var(--bg-surface, #fff);border-left:1px solid var(--border-color, #e5e7eb);box-shadow:-4px 0 24px #0000001f;z-index:600;animation:chatSlideIn .2s ease-out}.chat-panel-inline{position:relative!important;width:100%!important;height:100%!important;box-shadow:none!important;animation:none!important;border-left:none!important}@keyframes chatSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@media (min-width: 3441px){.chat-panel:not(.chat-panel-inline){display:none!important}}.chat-header{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-header, #1e40af);color:#fff;min-height:44px;flex-shrink:0}.chat-header-title{font-weight:600;font-size:.95rem;flex:1}.chat-header-user{display:flex;flex-direction:column;flex:1;min-width:0}.chat-header-name{font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-header-role{font-size:.7rem;opacity:.7}.chat-back-btn,.chat-close-btn,.chat-delete-btn,.chat-spy-toggle{background:none;border:none;color:#fff;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;opacity:.8;transition:opacity .15s}.chat-back-btn:hover,.chat-close-btn:hover,.chat-delete-btn:hover,.chat-spy-toggle:hover{opacity:1}.chat-spy-toggle-active{opacity:1;background:#fff3}.chat-admin-badge{background:#f59e0b;color:#000;font-size:.6rem;font-weight:700;padding:1px 6px;border-radius:8px;letter-spacing:.05em}.chat-hidden-badge{font-size:.65rem;opacity:.7}.chat-avatar{position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;flex-shrink:0;-webkit-user-select:none;user-select:none}.chat-avatar-status{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-surface, #fff)}.chat-online{background-color:#22c55e}.chat-offline{background-color:#9ca3af}.chat-ghost-banner{background:#ef4444;color:#fff;text-align:center;font-size:.75rem;font-weight:500;padding:4px 8px;flex-shrink:0}.chat-ghost-btn{background:none;border:1px solid var(--border-color, #d1d5db);color:var(--color-text, #374151);cursor:pointer;padding:4px 6px;border-radius:6px;display:flex;align-items:center;font-size:.8rem;transition:all .15s}.chat-ghost-btn:hover{background:var(--bg-surface-hover, #f3f4f6)}.chat-ghost-active{background:#ef4444!important;border-color:#ef4444!important;color:#fff!important}.chat-filters{display:flex;gap:6px;padding:8px 12px;border-bottom:1px solid var(--border-color, #e5e7eb);flex-shrink:0}.chat-role-filter{flex:1;padding:4px 8px;border:1px solid var(--border-color, #d1d5db);border-radius:6px;background:var(--bg-surface, #fff);color:var(--color-text, #374151);font-size:.8rem;cursor:pointer}.chat-spy-label{background:#f59e0b;color:#000;text-align:center;font-size:.7rem;font-weight:600;padding:3px;letter-spacing:.05em}.chat-user-list{flex:1;overflow-y:auto;padding:4px 0}.chat-user-item{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .12s}.chat-user-item:hover{background:var(--bg-surface-hover, #f3f4f6)}.chat-user-info{flex:1;min-width:0;display:flex;flex-direction:column}.chat-user-name{font-weight:500;font-size:.85rem;color:var(--color-text, #1f2937);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-user-role{font-size:.7rem;color:var(--color-text-secondary, #6b7280)}.chat-group{margin-bottom:4px}.chat-group-header{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:.75rem;font-weight:600;color:var(--color-text-secondary, #6b7280);text-transform:uppercase;letter-spacing:.04em}.chat-group-toggle{cursor:pointer;-webkit-user-select:none;user-select:none}.chat-group-toggle:hover{color:var(--color-text, #374151)}.chat-group-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.chat-group-chevron{margin-left:auto;font-size:18px;transition:transform .2s;transform:rotate(-90deg)}.chat-group-chevron-open{transform:rotate(0)}.chat-unread-badge{background:#ef4444;color:#fff;font-size:.65rem;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center;flex-shrink:0}.chat-messages{flex:1;overflow-y:auto;padding:12px 8px;display:flex;flex-direction:column;gap:2px}.chat-msg{display:flex;margin-bottom:2px}.chat-msg-mine{justify-content:flex-end}.chat-msg-other{justify-content:flex-start}.chat-msg-bubble{max-width:75%;padding:8px 12px;border-radius:12px;font-size:.85rem;line-height:1.4;position:relative}.chat-msg-mine .chat-msg-bubble{background:var(--color-primary, #3b82f6);color:#fff;border-bottom-right-radius:4px}.chat-msg-other .chat-msg-bubble{background:var(--bg-surface-hover, #f3f4f6);color:var(--color-text, #1f2937);border-bottom-left-radius:4px}.chat-msg-text{white-space:pre-wrap;word-break:break-word}.chat-msg-time{display:block;font-size:.65rem;opacity:.6;margin-top:2px;text-align:right}.chat-date-sep{display:flex;align-items:center;justify-content:center;margin:12px 0 8px;font-size:.7rem;color:var(--color-text-secondary, #9ca3af);font-weight:500}.chat-date-sep:before,.chat-date-sep:after{content:"";flex:0 0 30%;height:1px;background:var(--border-color, #e5e7eb)}.chat-date-sep:before{margin-right:8px}.chat-date-sep:after{margin-left:8px}.chat-typing-bubble{padding:8px 14px;background:var(--bg-surface-hover, #f3f4f6);border-radius:12px 12px 12px 4px;display:inline-block}.chat-typing-dots{display:flex;gap:4px;align-items:center;height:16px}.chat-typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--color-text-secondary, #9ca3af);animation:chatTypingBounce 1.2s infinite}.chat-typing-dots span:nth-child(2){animation-delay:.2s}.chat-typing-dots span:nth-child(3){animation-delay:.4s}@keyframes chatTypingBounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.chat-input-area{display:flex;gap:6px;padding:8px 10px;border-top:1px solid var(--border-color, #e5e7eb);background:var(--bg-surface, #fff);flex-shrink:0}.chat-input{flex:1;padding:8px 14px;border:1px solid var(--border-color, #d1d5db);border-radius:20px;background:var(--bg-main, #f9fafb);color:var(--color-text, #1f2937);font-size:.85rem;resize:none;outline:none;max-height:80px;line-height:1.4;font-family:inherit}.chat-input:focus{border-color:var(--color-primary, #3b82f6);box-shadow:0 0 0 2px #3b82f626}.chat-send-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--color-primary, #3b82f6);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .15s}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-send-btn:not(:disabled):hover{opacity:.85}.chat-send-btn .material-symbols-outlined{font-size:18px}.chat-confirm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10;animation:chatFadeIn .15s ease-out}@keyframes chatFadeIn{0%{opacity:0}to{opacity:1}}.chat-confirm-box{background:var(--bg-surface, #fff);border-radius:12px;padding:20px;width:260px;display:flex;flex-direction:column;gap:8px;box-shadow:0 8px 32px #0003}.chat-confirm-box p{font-size:.85rem;color:var(--color-text, #374151);margin:0 0 4px;text-align:center}.chat-confirm-hard,.chat-confirm-hide,.chat-confirm-cancel{width:100%;padding:8px;border:none;border-radius:8px;font-size:.82rem;font-weight:500;cursor:pointer;transition:opacity .15s}.chat-confirm-hard{background:#ef4444;color:#fff}.chat-confirm-hide{background:#f59e0b;color:#000}.chat-confirm-cancel{background:var(--bg-surface-hover, #f3f4f6);color:var(--color-text, #374151)}.chat-confirm-hard:hover,.chat-confirm-hide:hover,.chat-confirm-cancel:hover{opacity:.85}.chat-pair-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .12s;border-bottom:1px solid var(--border-color, #e5e7eb)}.chat-pair-item:hover{background:var(--bg-surface-hover, #f3f4f6)}.chat-pair-avatars{display:flex;align-items:center;gap:4px;flex-shrink:0}.chat-pair-arrow{font-size:.7rem;color:var(--color-text-secondary, #9ca3af)}.chat-pair-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.chat-pair-names{font-size:.8rem;font-weight:500;color:var(--color-text, #1f2937);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-pair-count{font-size:.7rem;color:var(--color-text-secondary, #9ca3af)}.chat-pair-preview{font-size:.72rem;color:var(--color-text-secondary, #6b7280);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-spy-author{display:block;font-size:.65rem;font-weight:600;margin-bottom:2px;opacity:.7}.chat-empty{text-align:center;padding:32px 16px;font-size:.82rem;color:var(--color-text-secondary, #9ca3af)}.chat-loading{display:flex;justify-content:center;padding:24px}.chat-loading .spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.topbar-chat-btn{position:relative;background:none;border:none;color:var(--color-text, #374151);cursor:pointer;padding:4px 8px;border-radius:6px;display:flex;align-items:center}.topbar-chat-btn:hover{background:var(--bg-surface-hover, #f3f4f6)}.topbar-chat-badge{position:absolute;top:-2px;right:-2px;background:#ef4444;color:#fff;font-size:.6rem;font-weight:700;padding:0 5px;border-radius:8px;min-width:16px;text-align:center;line-height:16px}[data-theme=dark] .chat-panel{background:var(--bg-surface, #1f2937);border-left-color:var(--border-color, #374151)}[data-theme=dark] .chat-msg-other .chat-msg-bubble{background:var(--bg-surface-hover, #374151);color:var(--color-text, #e5e7eb)}[data-theme=dark] .chat-input,[data-theme=dark] .chat-role-filter{background:var(--bg-main, #111827);color:var(--color-text, #e5e7eb);border-color:var(--border-color, #4b5563)}[data-theme=dark] .chat-confirm-box{background:var(--bg-surface, #1f2937)}[data-theme=dark] .chat-confirm-cancel{background:var(--bg-surface-hover, #374151);color:var(--color-text, #e5e7eb)}[data-theme=dark] .chat-pair-item{border-bottom-color:var(--border-color, #374151)}[data-theme=dark] .chat-typing-bubble{background:var(--bg-surface-hover, #374151)}[data-theme=dark] .chat-ghost-btn{border-color:var(--border-color, #4b5563);color:var(--color-text, #e5e7eb)}[data-theme=dark] .topbar-chat-btn{color:var(--color-text, #e5e7eb)}.ticket-panel{position:fixed;top:0;right:0;width:400px;max-width:100vw;height:100vh;z-index:1100;background:var(--color-bg-primary, #fff);border-left:1px solid var(--color-border, #e0e0e0);display:flex;flex-direction:column;box-shadow:-4px 0 20px #0000001a;animation:tpSlideIn .25s ease-out}@keyframes tpSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.tp-header{display:flex;align-items:center;padding:14px 16px;border-bottom:1px solid var(--color-border);gap:8px;flex-shrink:0}.tp-back-btn{background:none;border:none;cursor:pointer;padding:4px;color:var(--color-text-secondary);display:flex;border-radius:6px}.tp-back-btn:hover{background:var(--color-bg-hover)}.tp-title{flex:1;font-size:1rem;font-weight:700;margin:0;color:var(--color-text-primary)}.tp-header-actions{display:flex;gap:4px}.tp-create-btn,.tp-close-btn{background:none;border:none;cursor:pointer;padding:6px;color:var(--color-text-secondary);border-radius:6px;display:flex}.tp-create-btn:hover,.tp-close-btn:hover{background:var(--color-bg-hover)}.tp-stat-bar{display:flex;gap:6px;padding:10px 16px;border-bottom:1px solid var(--color-border);flex-shrink:0}.tp-stat-card{flex:1;display:flex;flex-direction:column;align-items:center;padding:6px 4px;border:2px solid var(--color-border);border-radius:8px;background:var(--color-bg-primary);cursor:pointer;transition:all .15s}.tp-stat-card:hover{background:var(--color-bg-hover)}.tp-stat-card.active{background:var(--color-bg-tertiary)}.tp-stat-count{font-size:1.1rem;font-weight:700}.tp-stat-label{font-size:.62rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.tp-toolbar{display:flex;align-items:center;gap:8px;padding:8px 16px;border-bottom:1px solid var(--color-border);flex-shrink:0}.tp-sort-select{flex:1;padding:6px 8px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.78rem}.tp-history-btn{display:flex;align-items:center;gap:4px;padding:5px 10px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-primary);cursor:pointer;font-size:.72rem;color:var(--color-text-secondary);white-space:nowrap}.tp-history-btn:hover{background:var(--color-bg-hover)}.tp-history-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.tp-history-btn .material-symbols-outlined{font-size:16px}.tp-loading,.tp-empty{padding:40px 16px;text-align:center;color:var(--color-text-tertiary);font-size:.85rem}.tp-list{flex:1;overflow-y:auto;padding:8px 12px}.tp-card{padding:12px;margin-bottom:8px;border-radius:10px;background:var(--color-bg-secondary, #f9fafb);border-left:4px solid var(--color-border);cursor:pointer;transition:background .15s}.tp-card:hover{background:var(--color-bg-hover)}.tp-card[data-priority=urgente]{border-left-color:#ef4444}.tp-card[data-priority=haute]{border-left-color:#f59e0b}.tp-card[data-priority=normale]{border-left-color:#3b82f6}.tp-card[data-priority=basse]{border-left-color:#9ca3af}.tp-card-top{display:flex;align-items:center;gap:8px;margin-bottom:4px}.tp-card-cat-icon{font-size:18px}.tp-card-title{flex:1;font-size:.85rem;font-weight:600;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-status-chip{padding:2px 8px;border-radius:10px;font-size:.65rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.tp-card-meta{display:flex;justify-content:space-between;font-size:.7rem;color:var(--color-text-tertiary);margin-bottom:4px}.tp-card-desc{font-size:.78rem;color:var(--color-text-secondary);line-height:1.4;margin:0}.tp-create-form{flex:1;overflow-y:auto;padding:16px}.tp-form-field{margin-bottom:16px}.tp-form-field label{display:block;font-size:.78rem;font-weight:600;margin-bottom:6px;color:var(--color-text-secondary)}.tp-form-field input,.tp-form-field textarea{width:100%;padding:8px 10px;border:1px solid var(--color-border);border-radius:8px;font-size:.85rem;background:var(--color-bg-primary);color:var(--color-text-primary);font-family:inherit;box-sizing:border-box}.tp-form-field input:focus,.tp-form-field textarea:focus{outline:none;border-color:var(--color-primary)}.tp-cat-selector,.tp-prio-selector{display:flex;gap:6px;flex-wrap:wrap}.tp-cat-btn{display:flex;align-items:center;gap:4px;padding:6px 10px;border:2px solid var(--color-border);border-radius:8px;background:var(--color-bg-primary);cursor:pointer;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);transition:all .15s}.tp-cat-btn:hover{background:var(--color-bg-hover)}.tp-cat-btn.active{background:var(--color-bg-tertiary)}.tp-cat-btn .material-symbols-outlined{font-size:16px}.tp-prio-btn{padding:5px 12px;border:2px solid var(--color-border);border-radius:8px;background:var(--color-bg-primary);cursor:pointer;font-size:.75rem;font-weight:600;color:var(--color-text-secondary);transition:all .15s}.tp-prio-btn:hover{background:var(--color-bg-hover)}.tp-prio-btn.active{font-weight:700}.tp-submit-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border:none;border-radius:10px;background:var(--color-primary, #3b82f6);color:#fff;font-size:.88rem;font-weight:600;cursor:pointer;margin-top:8px}.tp-submit-btn:disabled{opacity:.5;cursor:not-allowed}.tp-submit-btn .material-symbols-outlined{font-size:18px}.tp-detail{flex:1;overflow-y:auto;padding:16px}.tp-detail-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}.tp-detail-title{font-size:1rem;font-weight:700;margin:0 0 6px;color:var(--color-text-primary)}.tp-detail-meta{display:flex;align-items:center;gap:8px}.tp-prio-chip{font-size:.72rem;font-weight:600}.tp-detail-info{margin-bottom:16px}.tp-detail-row{display:flex;justify-content:space-between;padding:4px 0;font-size:.78rem;color:var(--color-text-primary);border-bottom:1px solid var(--color-border-light, rgba(0, 0, 0, .05))}.tp-detail-label{color:var(--color-text-tertiary);font-weight:600}.tp-detail-desc{margin-bottom:16px;padding:10px 12px;background:var(--color-bg-tertiary, #f0f0f0);border-radius:8px;font-size:.85rem;line-height:1.5;color:var(--color-text-primary)}.tp-detail-desc p{margin:0}.tp-detail-screenshot{margin-bottom:16px}.tp-detail-screenshot img{max-width:100%;border-radius:8px;border:1px solid var(--color-border)}.tp-admin-reply-box{margin-bottom:16px;padding:12px;background:var(--color-bg-tertiary, #f0f0f0);border-radius:10px;border-left:3px solid var(--color-primary)}.tp-admin-reply-header{display:flex;align-items:center;gap:6px;font-size:.78rem;font-weight:600;color:var(--color-primary);margin-bottom:6px}.tp-admin-reply-header .material-symbols-outlined{font-size:18px}.tp-admin-reply-date{margin-left:auto;color:var(--color-text-tertiary);font-weight:400;font-size:.7rem}.tp-admin-reply-text{margin:0;font-size:.82rem;color:var(--color-text-primary);line-height:1.4}.tp-admin-section{margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border)}.tp-admin-section h5{margin:0 0 12px;font-size:.82rem;font-weight:700;color:var(--color-text-primary)}.tp-status-actions{margin-bottom:16px}.tp-action-label{display:block;font-size:.72rem;color:var(--color-text-tertiary);margin-bottom:6px}.tp-quick-actions{display:flex;gap:6px;flex-wrap:wrap}.tp-status-action-btn{padding:5px 12px;border:2px solid;border-radius:8px;font-size:.72rem;font-weight:600;cursor:pointer;transition:all .15s;background:transparent}.tp-status-action-btn:hover:not(:disabled){opacity:.8}.tp-status-action-btn:disabled{cursor:default}.tp-status-action-btn.current{cursor:default}.tp-response-field{margin-bottom:12px}.tp-response-field label{display:block;font-size:.78rem;font-weight:600;margin-bottom:6px;color:var(--color-text-secondary)}.tp-response-field textarea{width:100%;padding:8px 10px;border:1px solid var(--color-border);border-radius:8px;font-size:.82rem;background:var(--color-bg-primary);color:var(--color-text-primary);font-family:inherit;resize:vertical;box-sizing:border-box}.tp-response-field textarea:focus{outline:none;border-color:var(--color-primary)}.tp-reply-btn{margin-top:8px;padding:8px 16px;border:none;border-radius:8px;background:var(--color-primary, #3b82f6);color:#fff;font-size:.82rem;font-weight:600;cursor:pointer}.tp-reply-btn:disabled{opacity:.5;cursor:not-allowed}.tp-reopen-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;margin-top:16px;border:2px solid #f59e0b;border-radius:10px;background:transparent;color:#f59e0b;font-size:.85rem;font-weight:600;cursor:pointer}.tp-reopen-btn:hover{background:#f59e0b14}.tp-reopen-btn:disabled{opacity:.5;cursor:not-allowed}.tp-reopen-btn .material-symbols-outlined{font-size:18px}[data-theme=dark] .ticket-panel{background:var(--color-bg-secondary);border-left-color:var(--color-border)}[data-theme=dark] .tp-card,[data-theme=dark] .tp-detail-desc,[data-theme=dark] .tp-admin-reply-box{background:var(--color-bg-tertiary)}.rappel-panel{position:fixed;top:0;right:0;width:400px;height:100vh;z-index:1100;background:var(--color-surface, var(--bg-surface, #fff));border-left:1px solid var(--color-border);display:flex;flex-direction:column;box-shadow:-4px 0 20px #0000001a;animation:rplSlideIn .25s ease-out}@keyframes rplSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.rpl-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--color-border);min-height:48px}.rpl-title{flex:1;font-size:1rem;font-weight:600;color:var(--color-text-primary)}.rpl-header-actions{display:flex;gap:4px}.rpl-back-btn,.rpl-close-btn,.rpl-create-btn{background:none;border:none;cursor:pointer;padding:4px;border-radius:6px;color:var(--color-text-secondary);display:flex;align-items:center}.rpl-back-btn:hover,.rpl-close-btn:hover,.rpl-create-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.rpl-tabs{display:flex;border-bottom:1px solid var(--color-border)}.rpl-tab{flex:1;padding:8px 12px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:.85rem;font-weight:500;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s}.rpl-tab:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.rpl-tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.rpl-tab-badge{background:var(--color-danger, #ef4444);color:#fff;font-size:.7rem;padding:1px 6px;border-radius:10px;font-weight:600}.rpl-list{flex:1;overflow-y:auto;padding:8px}.rpl-empty{text-align:center;color:var(--color-text-secondary);padding:32px 16px;font-size:.85rem}.rpl-card{display:flex;border-radius:8px;border:1px solid var(--color-border);overflow:hidden;cursor:pointer;margin-bottom:6px;transition:all .15s;background:var(--color-surface, var(--bg-surface, #fff))}.rpl-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #0000000f}.rpl-card-unacked{background:var(--color-bg-secondary, #f8fafc)}.rpl-card-prio{width:4px;flex-shrink:0}.rpl-card-body{flex:1;padding:10px 12px;min-width:0}.rpl-card-top{display:flex;align-items:center;gap:6px;margin-bottom:4px}.rpl-card-icon{font-size:16px;flex-shrink:0}.rpl-card-title{font-size:.85rem;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rpl-card-meta{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--color-text-secondary);flex-wrap:wrap}.rpl-ack-btn-mini{background:none;border:1px solid var(--color-success, #22c55e);color:var(--color-success, #22c55e);font-size:.7rem;padding:2px 8px;border-radius:12px;cursor:pointer;display:flex;align-items:center;gap:3px;transition:all .15s}.rpl-ack-btn-mini .material-symbols-outlined{font-size:12px}.rpl-ack-btn-mini:hover{background:var(--color-success, #22c55e);color:#fff}.rpl-ack-badge{color:var(--color-success, #22c55e);display:flex;align-items:center}.rpl-ack-badge .material-symbols-outlined{font-size:14px}.rpl-ack-progress{color:var(--color-text-secondary);font-size:.75rem}.rpl-create-form{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px}.rpl-form-field{display:flex;flex-direction:column;gap:6px}.rpl-form-field>label{font-size:.8rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em}.rpl-prio-selector,.rpl-target-selector{display:flex;gap:6px;flex-wrap:wrap}.rpl-prio-btn,.rpl-target-btn{flex:1;min-width:80px;padding:6px 10px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface, var(--bg-surface, #fff));color:var(--color-text-secondary);cursor:pointer;font-size:.78rem;display:flex;align-items:center;justify-content:center;gap:4px;transition:all .15s}.rpl-prio-btn:hover,.rpl-target-btn:hover{border-color:var(--color-primary)}.rpl-prio-btn-active{border-color:var(--prio-color);background:var(--prio-color);color:#fff}.rpl-prio-btn .material-symbols-outlined{font-size:14px}.rpl-target-btn-active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.rpl-input,.rpl-select,.rpl-textarea{padding:8px 12px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface, var(--bg-surface, #fff));color:var(--color-text-primary);font-size:.85rem;font-family:inherit;outline:none;transition:border-color .15s}.rpl-input:focus,.rpl-select:focus,.rpl-textarea:focus{border-color:var(--color-primary)}.rpl-textarea{resize:vertical;min-height:80px}.rpl-user-search{margin-bottom:6px}.rpl-user-select{max-height:200px;overflow-y:auto;border:1px solid var(--color-border);border-radius:6px;padding:4px}.rpl-user-option{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:.82rem;color:var(--color-text-primary)}.rpl-user-option:hover{background:var(--color-bg-hover)}.rpl-user-option input[type=checkbox]{accent-color:var(--color-primary)}.rpl-user-role{margin-left:auto;font-size:.7rem;color:var(--color-text-secondary);opacity:.7}.rpl-selected-count{font-size:.78rem;color:var(--color-primary);font-weight:500;margin-top:4px}.rpl-submit-btn{padding:10px;border:none;border-radius:8px;background:var(--color-primary);color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s}.rpl-submit-btn:hover:not(:disabled){opacity:.9}.rpl-submit-btn:disabled{opacity:.5;cursor:not-allowed}.rpl-detail{flex:1;overflow-y:auto;padding:16px}.rpl-detail-header{display:flex;gap:12px;align-items:flex-start;margin-bottom:16px}.rpl-detail-icon{font-size:28px;flex-shrink:0}.rpl-detail-title{margin:0 0 4px;font-size:1.05rem;color:var(--color-text-primary)}.rpl-detail-meta{display:flex;gap:6px;font-size:.78rem;color:var(--color-text-secondary);flex-wrap:wrap}.rpl-detail-prio{font-weight:600}.rpl-detail-content{font-size:.88rem;color:var(--color-text-primary);line-height:1.5;white-space:pre-wrap;margin-bottom:20px;padding:12px;background:var(--color-bg-secondary, #f8fafc);border-radius:8px}.rpl-ack-btn-big{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;border:2px solid var(--color-success, #22c55e);border-radius:8px;background:none;color:var(--color-success, #22c55e);font-size:.95rem;font-weight:600;cursor:pointer;margin-bottom:20px;transition:all .15s}.rpl-ack-btn-big:hover{background:var(--color-success, #22c55e);color:#fff}.rpl-ack-done{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;background:#22c55e1a;color:var(--color-success, #22c55e);font-size:.85rem;font-weight:500;margin-bottom:20px}.rpl-ack-done .material-symbols-outlined{font-size:18px}.rpl-recipients{margin-bottom:20px}.rpl-recipients h4{font-size:.82rem;font-weight:600;color:var(--color-text-secondary);margin:0 0 8px;text-transform:uppercase;letter-spacing:.03em}.rpl-recipients-list{display:flex;flex-direction:column;gap:4px}.rpl-recipient{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;border:1px solid var(--color-border);font-size:.82rem}.rpl-recipient-acked{background:#22c55e0d}.rpl-recipient-icon{font-size:16px;color:var(--color-text-secondary)}.rpl-recipient-acked .rpl-recipient-icon{color:var(--color-success, #22c55e)}.rpl-recipient-name{flex:1;color:var(--color-text-primary)}.rpl-recipient-role{font-size:.7rem;color:var(--color-text-secondary);opacity:.7}.rpl-recipient-date{font-size:.7rem;color:var(--color-success, #22c55e)}.rpl-delete-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--color-danger, #ef4444);border-radius:6px;background:none;color:var(--color-danger, #ef4444);font-size:.82rem;cursor:pointer;transition:all .15s}.rpl-delete-btn:hover{background:var(--color-danger, #ef4444);color:#fff}[data-theme=dark] .rappel-panel{box-shadow:-4px 0 20px #0006}[data-theme=dark] .rpl-card-unacked{background:#ffffff08}[data-theme=dark] .rpl-detail-content{background:#ffffff0a}@media (max-width: 480px){.rappel-panel{width:100vw}}@font-face{font-family:Material Symbols Outlined;font-style:normal;font-weight:100 700;font-display:block;src:url(/assets/material-symbols-outlined-crADkEM7.woff2) format("woff2")}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"liga"}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:confirmFadeIn .15s ease}.confirm-dialog{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius);padding:var(--sp-6);min-width:340px;max-width:440px;box-shadow:var(--shadow-lg, 0 8px 32px rgba(0, 0, 0, .25));animation:confirmSlideIn .15s ease}.confirm-header{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-3)}.confirm-icon{font-size:28px}.confirm-title{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-primary)}.confirm-message{margin:0 0 var(--sp-5);font-size:var(--font-size-md);color:var(--text-secondary);line-height:1.5}.confirm-actions{display:flex;justify-content:flex-end;gap:var(--sp-2)}@keyframes confirmFadeIn{0%{opacity:0}to{opacity:1}}@keyframes confirmSlideIn{0%{transform:scale(.95) translateY(-10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}@font-face{font-family:OpenDyslexic;src:url(https://cdn.jsdelivr.net/npm/open-dyslexic@1.0.3/woff/OpenDyslexic-Regular.woff) format("woff");font-weight:400}@font-face{font-family:OpenDyslexic;src:url(https://cdn.jsdelivr.net/npm/open-dyslexic@1.0.3/woff/OpenDyslexic-Bold.woff) format("woff");font-weight:700}:root,[data-theme=light]{--color-primary: #1976d2;--color-primary-hover: #1565c0;--color-primary-light: #e3f2fd;--color-primary-dark: #0d47a1;--color-primary-subtle: rgba(25, 118, 210, .08);--color-primary-text: #1976d2;--color-success: #2e7d32;--color-success-light: #e8f5e9;--color-success-hover: #1b5e20;--color-success-subtle: rgba(46, 125, 50, .08);--color-warning: #ed6c02;--color-warning-light: #fff3e0;--color-warning-subtle: rgba(237, 108, 2, .08);--color-danger: #d32f2f;--color-danger-light: #ffebee;--color-danger-hover: #c62828;--color-danger-subtle: rgba(211, 47, 47, .08);--color-info: #0288d1;--color-info-light: #e1f5fe;--color-info-subtle: rgba(2, 136, 209, .08);--color-accent: #7c4dff;--color-accent-light: #ede7f6;--color-accent-subtle: rgba(124, 77, 255, .08);--bg-app: #f5f5f5;--bg-main: #f5f5f5;--bg-surface: #ffffff;--bg-surface-elevated: #ffffff;--bg-surface-hover: #f0f0f0;--bg-header: #1976d2;--bg-sidebar: #fafafa;--bg-input: #ffffff;--bg-disabled: #e0e0e0;--bg-code: #f5f5f5;--text-primary: #212121;--text-secondary: #616161;--text-tertiary: #9e9e9e;--text-disabled: #9e9e9e;--text-inverse: #ffffff;--text-link: #1976d2;--text-on-primary: #ffffff;--border-color: #e0e0e0;--border-color-hover: #bdbdbd;--border-color-focus: #1976d2;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .12);--shadow-focus: 0 0 0 3px rgba(25, 118, 210, .25);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-xxl: 48px;--font-family: "Inter", "Segoe UI", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace;--font-zoom: 1;--font-size-xs: calc(11px * var(--font-zoom));--font-size-sm: calc(13px * var(--font-zoom));--font-size-md: calc(14px * var(--font-zoom));--font-size-lg: calc(16px * var(--font-zoom));--font-size-xl: calc(20px * var(--font-zoom));--font-size-xxl: calc(24px * var(--font-zoom));--font-size-h1: calc(28px * var(--font-zoom));--line-height: 1.5;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-bold: 600;--border-radius-sm: 4px;--border-radius-md: 8px;--border-radius-lg: 12px;--transition-fast: .15s ease;--transition-normal: .25s ease;--color-p0: #d32f2f;--color-p1: #f57c00;--color-p2: #fbc02d;--color-p3: #388e3c;--color-p0-bg: #ffebee;--color-p1-bg: #fff3e0;--color-p2-bg: #fffde7;--color-p3-bg: #e8f5e9;--color-status-actif: #1976d2;--color-status-en-regulation: #f57c00;--color-status-attente-moyen: #8e24aa;--color-status-decision: #7b1fa2;--color-status-attente-bilan: #0891b2;--color-status-attente-orientation: #0d9488;--color-status-cloture: #388e3c;--color-status-archive: #757575;--color-status-planifiee: #1976d2;--color-status-en-cours: #ed6c02;--color-status-terminee: #2e7d32;--color-status-archivee: #757575;--color-status-annulee: #d32f2f;--color-bg: var(--bg-app);--color-bg-alt: var(--bg-sidebar);--color-surface: var(--bg-surface);--color-surface-hover: var(--bg-surface-hover);--color-surface-active: #eeeeee;--color-surface-variant: #fafafa;--color-border: var(--border-color);--color-border-subtle: #eeeeee;--color-overlay: rgba(0, 0, 0, .4);--color-text: var(--text-primary);--color-text-secondary: var(--text-secondary);--color-text-tertiary: var(--text-tertiary);--color-text-inverse: var(--text-inverse);--sp-1: var(--space-xs);--sp-2: var(--space-sm);--sp-3: 12px;--sp-4: var(--space-md);--sp-5: 20px;--sp-6: var(--space-lg);--sp-8: var(--space-xl);--sp-10: 40px;--sp-12: var(--space-xxl);--radius-sm: var(--border-radius-sm);--radius: var(--border-radius-md);--radius-md: var(--border-radius-lg);--radius-lg: 16px;--radius-full: 9999px;--shadow: var(--shadow-md);--font-sans: var(--font-family);--transition: var(--transition-fast);--transition-slow: var(--transition-normal);--sidebar-width: 260px;--sidebar-collapsed: 64px;--topbar-height: 56px;--bg-primary: var(--bg-surface);--bg-secondary: var(--bg-app);--bg-card: var(--bg-surface);--bg-section: #f8f9fa;--bg-hover: var(--bg-surface-hover);--border: var(--border-color)}[data-theme=dark]{--color-primary: #64b5f6;--color-primary-hover: #90caf9;--color-primary-light: #1a237e;--color-primary-dark: #bbdefb;--color-primary-subtle: rgba(100, 181, 246, .12);--color-primary-text: #64b5f6;--color-success: #66bb6a;--color-success-light: #1b2e1b;--color-success-hover: #81c784;--color-success-subtle: rgba(102, 187, 106, .12);--color-warning: #ffa726;--color-warning-light: #2e2010;--color-warning-subtle: rgba(255, 167, 38, .12);--color-danger: #ef5350;--color-danger-light: #2e1010;--color-danger-hover: #f44336;--color-danger-subtle: rgba(239, 83, 80, .12);--color-info: #4fc3f7;--color-info-light: #102e3e;--color-info-subtle: rgba(79, 195, 247, .12);--color-accent: #b388ff;--color-accent-light: #1a0e33;--color-accent-subtle: rgba(179, 136, 255, .12);--bg-app: #121212;--bg-main: #121212;--bg-surface: #1e1e1e;--bg-surface-elevated: #2d2d2d;--bg-surface-hover: #333333;--bg-header: #1e1e1e;--bg-sidebar: #1a1a1a;--bg-input: #2d2d2d;--bg-disabled: #424242;--bg-code: #2d2d2d;--text-primary: #e0e0e0;--text-secondary: #9e9e9e;--text-tertiary: #757575;--text-disabled: #616161;--text-inverse: #121212;--text-link: #64b5f6;--text-on-primary: #121212;--border-color: #424242;--border-color-hover: #616161;--border-color-focus: #64b5f6;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 2px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .5);--shadow-focus: 0 0 0 3px rgba(100, 181, 246, .3);--color-p0: #ef5350;--color-p1: #ffa726;--color-p2: #ffee58;--color-p3: #66bb6a;--color-p0-bg: #3e1010;--color-p1-bg: #3e2a10;--color-p2-bg: #3e3a10;--color-p3-bg: #103e10;--color-status-actif: #64b5f6;--color-status-en-regulation: #ffa726;--color-status-attente-moyen: #ba68c8;--color-status-decision: #ce93d8;--color-status-attente-bilan: #22d3ee;--color-status-attente-orientation: #2dd4bf;--color-status-cloture: #66bb6a;--color-status-archive: #9e9e9e;--color-status-planifiee: #64b5f6;--color-status-en-cours: #ffa726;--color-status-terminee: #66bb6a;--color-status-archivee: #9e9e9e;--color-status-annulee: #ef5350;--color-bg: var(--bg-app);--color-bg-alt: var(--bg-sidebar);--color-surface: var(--bg-surface);--color-surface-hover: var(--bg-surface-hover);--color-surface-active: #2f3440;--color-surface-variant: #252830;--color-border: var(--border-color);--color-border-subtle: #252830;--color-overlay: rgba(0, 0, 0, .6);--color-text: var(--text-primary);--color-text-secondary: var(--text-secondary);--color-text-tertiary: var(--text-tertiary);--color-text-inverse: var(--text-inverse);--shadow: var(--shadow-md);--bg-primary: var(--bg-surface);--bg-secondary: var(--bg-app);--bg-card: var(--bg-surface);--bg-section: #252530;--bg-hover: var(--bg-surface-hover);--border: var(--border-color)}html.dyslexic,html.dyslexic body,html.dyslexic input,html.dyslexic select,html.dyslexic textarea,html.dyslexic button{font-family:OpenDyslexic,sans-serif!important;letter-spacing:.05em;word-spacing:.12em;line-height:1.6}body{transition:background-color var(--transition-normal),color var(--transition-normal)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:var(--font-size-md);line-height:var(--line-height);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--bg-app);color:var(--text-primary);line-height:var(--line-height);min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:1.3}h1{font-size:var(--font-size-h1)}h2{font-size:var(--font-size-xxl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}a{color:var(--text-link);text-decoration:none;transition:color var(--transition-fast)}a:hover{text-decoration:underline}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 24;font-size:20px;vertical-align:middle;-webkit-user-select:none;user-select:none}.icon-sm{font-size:16px}.icon-md{font-size:20px}.icon-lg{font-size:24px}.icon-xl{font-size:32px}.icon-filled{font-variation-settings:"FILL" 1,"wght" 300,"GRAD" 0,"opsz" 24}button{cursor:pointer;border:none;border-radius:var(--radius);font-family:var(--font-sans);font-size:.875rem;font-weight:500;padding:var(--sp-2) var(--sp-4);display:inline-flex;align-items:center;gap:var(--sp-2);transition:all var(--transition);line-height:1.5}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-sm)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.9}.btn-ghost{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-ghost:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-text-secondary)}.btn-flat{background:transparent;color:var(--color-text-secondary);padding:var(--sp-2);border-radius:var(--radius-full)}.btn-flat:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text)}.btn-soft{background:var(--color-primary-subtle);color:var(--color-primary);border:none}.btn-soft:hover:not(:disabled){background:var(--color-primary);color:var(--color-text-inverse)}.btn-sm{padding:var(--sp-1) var(--sp-2);font-size:.8rem}.btn-lg{padding:var(--sp-3) var(--sp-6);font-size:1rem}input,select,textarea{background:var(--color-surface-variant);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--sp-2) var(--sp-3);font-family:var(--font-sans);font-size:.875rem;outline:none;transition:border-color var(--transition),box-shadow var(--transition);width:100%}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}input::placeholder,textarea::placeholder{color:var(--color-text-tertiary)}input[type=checkbox],input[type=radio]{width:auto;padding:0;border:revert;border-radius:revert;background:revert;box-shadow:none;cursor:pointer;flex-shrink:0;margin:0}select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%239aa0a6'%3E%3Cpath d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}select option{background:var(--color-surface-variant);color:var(--color-text);padding:6px 10px}textarea{resize:vertical;min-height:80px}label{display:block;font-size:.8rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--sp-1);text-transform:uppercase;letter-spacing:.04em}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition)}.card:hover{box-shadow:var(--shadow)}.card-flat{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4)}.card-interactive{cursor:pointer}.card-interactive:hover{border-color:var(--color-primary);box-shadow:var(--shadow),0 0 0 1px var(--color-primary-subtle)}.badge{display:inline-flex;align-items:center;gap:var(--sp-1);padding:2px var(--sp-2);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;letter-spacing:.02em;white-space:nowrap}.badge-primary{background:var(--color-primary-subtle);color:var(--color-primary)}.badge-success{background:var(--color-success-subtle);color:var(--color-success)}.badge-warning{background:var(--color-warning-subtle);color:var(--color-warning)}.badge-danger{background:var(--color-danger-subtle);color:var(--color-danger)}.badge-info{background:var(--color-info-subtle);color:var(--color-info)}.badge-accent{background:var(--color-accent-subtle);color:var(--color-accent)}.badge-neutral{background:var(--color-surface-hover);color:var(--color-text-secondary)}.chip{display:inline-flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1) var(--sp-3);border-radius:var(--radius-full);font-size:.8rem;font-weight:500;border:1px solid var(--color-border);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition)}.chip:hover,.chip-active{background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary)}table{width:100%;border-collapse:separate;border-spacing:0}th{text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--color-border);background:var(--color-surface-variant);white-space:nowrap}th:first-child{border-radius:var(--radius) 0 0 0}th:last-child{border-radius:0 var(--radius) 0 0}td{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--color-border-subtle);font-size:.875rem;vertical-align:middle}tr:hover td{background:var(--color-surface-hover)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.modal-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:520px;max-width:95vw;max-height:85vh;overflow-y:auto;animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--color-border)}.modal-body{padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-4)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--sp-2);padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--color-border)}@keyframes fadeIn{0%{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}}@keyframes spin{to{transform:rotate(360deg)}}.btn-flat-active{background:var(--color-primary-subtle);color:var(--color-primary)}.a11y-panel{position:fixed;top:var(--topbar-height, 56px);right:12px;width:260px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-lg, 12px);box-shadow:var(--shadow-lg);padding:var(--space-sm, 8px);z-index:9999;animation:fadeIn .15s ease}.a11y-section{padding:var(--space-sm, 8px);border-bottom:1px solid var(--border-color)}.a11y-section:last-child{border-bottom:none}.a11y-label{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);margin-bottom:var(--space-sm, 8px)}.a11y-zoom-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-xs, 4px)}.a11y-zoom-value{min-width:52px;text-align:center;font-size:.9rem;font-weight:700;color:var(--text-primary);background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius-sm, 4px);padding:4px 8px;cursor:pointer}.a11y-zoom-value:hover{background:var(--bg-surface-hover)}.a11y-slider{width:100%;margin-top:var(--space-sm, 8px);accent-color:var(--color-primary);height:4px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border-color);border-radius:2px;border:none;padding:0}.a11y-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid var(--bg-surface);box-shadow:0 1px 3px #0000004d}.a11y-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:var(--border-radius-sm, 4px);background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s ease}.a11y-option:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.a11y-option-active{background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary)}.a11y-presets{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-xs, 4px)}.a11y-preset{padding:4px;border-radius:var(--border-radius-sm, 4px);border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s ease}.a11y-preset:hover{background:var(--bg-surface-hover);color:var(--text-primary)}.a11y-preset-active{background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary)}.view-toggle{display:inline-flex;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.view-toggle-btn{display:flex;align-items:center;justify-content:center;width:34px;height:30px;padding:0;border:none;border-radius:0;background:transparent;color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition)}.view-toggle-btn:not(:last-child){border-right:1px solid var(--color-border)}.view-toggle-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.view-toggle-active{background:var(--color-primary-subtle);color:var(--color-primary)}.list-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-4);border-bottom:1px solid var(--color-border-subtle);transition:background var(--transition)}.list-row:hover{background:var(--color-surface-hover)}.list-row:last-child{border-bottom:none}.grid{display:grid;gap:var(--sp-4)}.grid-2{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.grid-3{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.grid-4{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--sp-4);display:flex;align-items:center;gap:var(--sp-4)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-value{font-size:1.75rem;font-weight:700;line-height:1}.stat-label{font-size:.8rem;color:var(--color-text-secondary);margin-top:2px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-12) var(--sp-4);color:var(--color-text-tertiary);text-align:center}.empty-state .material-symbols-outlined{font-size:48px;margin-bottom:var(--sp-3);opacity:.5}.placeholder-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--sp-12) var(--sp-6);min-height:400px}.placeholder-icon-wrap{width:80px;height:80px;border-radius:50%;background:var(--color-primary-subtle);display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-4)}.placeholder-icon-wrap .material-symbols-outlined{font-size:36px;color:var(--color-primary);font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 24}.placeholder-panel h3{font-size:var(--font-size-xl);color:var(--text-primary);margin-bottom:var(--sp-2)}.placeholder-panel p{color:var(--text-tertiary);font-size:var(--font-size-md);max-width:360px;margin-bottom:var(--sp-4)}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:var(--sp-10);color:var(--color-text-secondary);gap:var(--sp-2)}.tab-bar{display:flex;gap:var(--sp-1);border-bottom:1px solid var(--color-border);margin-bottom:var(--sp-4);overflow-x:auto}.tab-item{padding:var(--sp-2) var(--sp-4);font-size:.875rem;font-weight:500;color:var(--color-text-secondary);background:transparent;border:none;border-bottom:2px solid transparent;border-radius:0;cursor:pointer;white-space:nowrap;transition:all var(--transition)}.tab-item:hover{color:var(--color-text);background:var(--color-surface-hover)}.tab-item-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4)}.form-group{display:flex;flex-direction:column}.form-full{grid-column:1 / -1}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-sm{font-size:.8rem}.text-xs{font-size:.75rem}.text-secondary{color:var(--color-text-secondary)}.text-center{text-align:center}.mt-2{margin-top:var(--sp-2)}.mt-4{margin-top:var(--sp-4)}.mb-2{margin-bottom:var(--sp-2)}.mb-4{margin-bottom:var(--sp-4)}.w-full{width:100%}.progress-bar{height:6px;background:var(--color-surface-hover);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow)}.search-input{position:relative}.search-input .material-symbols-outlined{position:absolute;left:var(--sp-3);top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);pointer-events:none}.search-input input{padding-left:var(--sp-10)}fieldset{border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:var(--space-md);margin-top:var(--space-sm);background-color:var(--bg-surface)}legend{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--text-primary);padding:0 var(--space-sm)}.input-with-suffix{display:flex;align-items:center;gap:0}.input-with-suffix input{flex:1;border-top-right-radius:0;border-bottom-right-radius:0;border-right:none}.input-suffix-text{padding:var(--space-sm);background-color:var(--bg-disabled);border:1px solid var(--border-color);border-left:none;border-top-right-radius:var(--border-radius-sm);border-bottom-right-radius:var(--border-radius-sm);font-size:var(--font-size-sm);color:var(--text-secondary)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.status-dot-connected{background-color:var(--color-success)}.status-dot-disconnected{background-color:var(--color-danger)}.badge-planifiee{background:var(--color-status-planifiee);color:#fff}.badge-en-cours{background:var(--color-status-en-cours);color:#fff}.badge-terminee{background:var(--color-status-terminee);color:#fff}.badge-archivee{background:var(--color-status-archivee);color:#fff}.badge-annulee{background:var(--color-status-annulee);color:#fff}.badge-prio-P0{background:#dc2626;color:#fff}.badge-prio-P1{background:#eab308;color:#000}.badge-prio-P2{background:#22c55e;color:#fff}.badge-prio-P3{background:#3b82f6;color:#fff}.badge-prio-P4{background:#6b7280;color:#fff}.badge-actif{background:var(--color-status-actif);color:#fff}.badge-en-regulation{background:var(--color-status-en-regulation);color:#fff}.badge-attente-moyen{background:var(--color-status-attente-moyen);color:#fff}.badge-decision{background:var(--color-status-decision);color:#fff}.badge-attente-bilan{background:var(--color-status-attente-bilan);color:#fff}.badge-attente-orientation{background:var(--color-status-attente-orientation);color:#fff}.badge-cloture{background:var(--color-status-cloture);color:#fff}.badge-archive{background:var(--color-status-archive);color:#fff}.bilan-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:11px;font-weight:700;color:#fff;background:#ef4444;border-radius:10px}.filiere-select{font-weight:var(--font-weight-bold)}.filiere-AMU{color:#dc2626}.filiere-SNP{color:#2563eb}.filiere-PSY{color:#7c3aed}.filiere-GER{color:#d97706}.filiere-PED{color:#059669}.filiere-CAP{color:#be185d}.filiere-GYN{color:#ec4899}@keyframes inactivity-slide-in{0%{transform:translate(-50%) translateY(20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.inactivity-warning{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:10000;display:flex;align-items:center;gap:var(--space-md);padding:12px 24px;background:var(--color-warning);color:#1a1a1a;border-radius:var(--border-radius-md);box-shadow:0 4px 20px #00000040;font-weight:var(--font-weight-bold);font-size:var(--font-size-md);animation:inactivity-slide-in .3s ease-out}#root{width:100vw;height:100vh;overflow-x:hidden;overflow-y:auto}#root:has(.app-layout.externe){overflow:hidden}
