:root{--ui-primary-color: #667eea;--ui-secondary-color: #764ba2;--ui-success-color: #28a745;--ui-warning-color: #ffc107;--ui-danger-color: #dc3545;--ui-info-color: #17a2b8;--ui-white: #ffffff;--ui-gray-50: #f9fafb;--ui-gray-100: #f3f4f6;--ui-gray-200: #e5e7eb;--ui-gray-300: #d1d5db;--ui-gray-400: #9ca3af;--ui-gray-500: #6b7280;--ui-gray-600: #4b5563;--ui-gray-700: #374151;--ui-gray-800: #1f2937;--ui-gray-900: #111827;--ui-spacing-xs: .25rem;--ui-spacing-sm: .5rem;--ui-spacing-md: 1rem;--ui-spacing-lg: 1.5rem;--ui-spacing-xl: 2rem;--ui-spacing-2xl: 3rem;--ui-border-radius-sm: 4px;--ui-border-radius-md: 8px;--ui-border-radius-lg: 12px;--ui-border-radius-xl: 16px;--ui-border-radius-round: 50%;--ui-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--ui-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--ui-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--ui-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--ui-transition-fast: .15s ease-out;--ui-transition-normal: .25s ease-out;--ui-transition-slow: .35s ease-out;--ui-transition-complex: .4s cubic-bezier(.25, .46, .45, .94);--ui-font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;--ui-font-size-xs: .75rem;--ui-font-size-sm: .875rem;--ui-font-size-base: 1rem;--ui-font-size-lg: 1.125rem;--ui-font-size-xl: 1.25rem;--ui-font-size-2xl: 1.5rem;--ui-font-size-3xl: 1.875rem}*,*:before,*:after{box-sizing:border-box}html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--ui-font-family);font-size:var(--ui-font-size-base);line-height:1.6;color:var(--ui-gray-800);background-color:var(--ui-gray-50);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.ui-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--ui-spacing-sm) var(--ui-spacing-md);border:none;border-radius:var(--ui-border-radius-md);font-size:var(--ui-font-size-sm);font-weight:600;cursor:pointer;transition:var(--ui-transition-normal);text-decoration:none;user-select:none;white-space:nowrap;gap:var(--ui-spacing-sm)}.ui-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--ui-shadow-md)}.ui-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.ui-btn-primary{background:linear-gradient(135deg,var(--ui-primary-color),var(--ui-secondary-color));color:var(--ui-white)}.ui-btn-success{background:linear-gradient(135deg,var(--ui-success-color),#20914b);color:var(--ui-white)}.ui-btn-warning{background:linear-gradient(135deg,var(--ui-warning-color),#e0a800);color:var(--ui-gray-800)}.ui-btn-danger{background:linear-gradient(135deg,var(--ui-danger-color),#c82333);color:var(--ui-white)}.ui-btn-gray{background:linear-gradient(135deg,var(--ui-gray-500),#5a6268);color:var(--ui-white)}.ui-btn-outline{background:var(--ui-white);color:var(--ui-gray-700);border:2px solid var(--ui-gray-200)}.ui-btn-outline:hover:not(:disabled){border-color:var(--ui-gray-300);background:var(--ui-gray-50)}.ui-card{background:var(--ui-white);border-radius:var(--ui-border-radius-lg);box-shadow:var(--ui-shadow-sm);overflow:hidden;transition:var(--ui-transition-normal)}.ui-card:hover{box-shadow:var(--ui-shadow-md);transform:translateY(-2px)}.ui-card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--ui-spacing-lg);border-bottom:1px solid var(--ui-gray-200);background:var(--ui-gray-50)}.ui-card-body{padding:var(--ui-spacing-lg)}.ui-card-title{font-size:var(--ui-font-size-xl);font-weight:700;color:var(--ui-gray-900);margin:0}.ui-card-form{padding:var(--ui-spacing-xl) var(--ui-spacing-lg);max-width:90%;width:100%}.ui-card-wide{padding:var(--ui-spacing-lg) var(--ui-spacing-xl);max-width:95%;width:100%}.ui-container{max-width:100%;margin:0 auto;padding:0 var(--ui-spacing-md)}.ui-container-center{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 48px);background:var(--ui-gray-50);padding:var(--ui-spacing-lg)}.ui-input{padding:var(--ui-spacing-sm) var(--ui-spacing-md);border:2px solid var(--ui-gray-200);border-radius:var(--ui-border-radius-md);font-size:var(--ui-font-size-base);transition:border-color var(--ui-transition-fast);background:var(--ui-white);width:100%}.ui-input:focus{outline:none;border-color:var(--ui-primary-color);box-shadow:0 0 0 3px #667eea1a}.ui-input::placeholder{color:var(--ui-gray-400)}.ui-label{display:flex;align-items:center;gap:var(--ui-spacing-sm);font-weight:600;color:var(--ui-gray-700);font-size:var(--ui-font-size-base)}.ui-flex{display:flex}.ui-flex-col{flex-direction:column}.ui-flex-wrap{flex-wrap:wrap}.ui-items-center{align-items:center}.ui-justify-center{justify-content:center}.ui-justify-between{justify-content:space-between}.ui-gap-xs{gap:var(--ui-spacing-xs)}.ui-gap-sm{gap:var(--ui-spacing-sm)}.ui-gap-md{gap:var(--ui-spacing-md)}.ui-gap-lg{gap:var(--ui-spacing-lg)}.ui-gap-xl{gap:var(--ui-spacing-xl)}.ui-grid{display:grid}.ui-grid-cols-2{grid-template-columns:repeat(2,1fr)}.ui-grid-cols-3{grid-template-columns:repeat(3,1fr)}.ui-grid-cols-4{grid-template-columns:repeat(4,1fr)}.ui-grid-cols-auto{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.ui-stat-box{padding:var(--ui-spacing-md) var(--ui-spacing-lg);border-radius:var(--ui-border-radius-md);display:flex;flex-direction:column;justify-content:center;box-shadow:var(--ui-shadow-sm);transition:var(--ui-transition-fast);background:var(--ui-white)}.ui-stat-box:hover{transform:translateY(-2px);box-shadow:var(--ui-shadow-md)}.ui-stat-label{font-size:var(--ui-font-size-sm);color:var(--ui-gray-600);margin-bottom:var(--ui-spacing-sm);font-weight:500}.ui-stat-value{font-size:var(--ui-font-size-2xl);font-weight:700;line-height:1;color:var(--ui-gray-800)}.ui-stat-gray{background:linear-gradient(135deg,var(--ui-gray-100),#e9ecef);color:var(--ui-gray-700)}.ui-stat-green{background:linear-gradient(135deg,#d9fdd3,#c3f7b7);color:#2d5016}.ui-stat-yellow{background:linear-gradient(135deg,#fff7c2,#ffeb85);color:#8b6914}.ui-stat-blue{background:linear-gradient(135deg,#e0f2fe,#b3e5fc);color:#0c4a6e}.ui-power-switch{width:40px;height:40px;border:none;border-radius:var(--ui-border-radius-round);cursor:pointer;transition:var(--ui-transition-normal);position:relative;box-shadow:var(--ui-shadow-sm);flex-shrink:0}.ui-power-switch:hover{transform:scale(1.1);box-shadow:var(--ui-shadow-md)}.ui-power-switch-on{background:var(--ui-success-color)}.ui-power-switch-off{background:var(--ui-gray-400)}.ui-power-icon{width:14px;height:14px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border:2px solid var(--ui-white);border-radius:var(--ui-border-radius-round);border-top-color:transparent}.ui-power-icon:after{content:"";position:absolute;top:-4px;left:50%;transform:translate(-50%);width:2px;height:6px;background:var(--ui-white);border-radius:1px}@keyframes ui-fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes ui-slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes ui-pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes ui-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ui-animate-fadeIn{animation:ui-fadeIn .3s ease-out}.ui-animate-slideIn{animation:ui-slideIn .3s ease-out}.ui-animate-pulse{animation:ui-pulse 2s infinite}.ui-animate-spin{animation:ui-spin 1s linear infinite}.ui-text-center{text-align:center}.ui-text-left{text-align:left}.ui-text-right{text-align:right}.ui-text-xs{font-size:var(--ui-font-size-xs)}.ui-text-sm{font-size:var(--ui-font-size-sm)}.ui-text-base{font-size:var(--ui-font-size-base)}.ui-text-lg{font-size:var(--ui-font-size-lg)}.ui-text-xl{font-size:var(--ui-font-size-xl)}.ui-text-2xl{font-size:var(--ui-font-size-2xl)}.ui-font-normal{font-weight:400}.ui-font-medium{font-weight:500}.ui-font-semibold{font-weight:600}.ui-font-bold{font-weight:700}.ui-text-primary{color:var(--ui-primary-color)}.ui-text-success{color:var(--ui-success-color)}.ui-text-warning{color:var(--ui-warning-color)}.ui-text-danger{color:var(--ui-danger-color)}.ui-text-muted{color:var(--ui-gray-500)}.ui-m-0{margin:0}.ui-m-1{margin:var(--ui-spacing-xs)}.ui-m-2{margin:var(--ui-spacing-sm)}.ui-m-3{margin:var(--ui-spacing-md)}.ui-m-4{margin:var(--ui-spacing-lg)}.ui-m-5{margin:var(--ui-spacing-xl)}.ui-p-0{padding:0}.ui-p-1{padding:var(--ui-spacing-xs)}.ui-p-2{padding:var(--ui-spacing-sm)}.ui-p-3{padding:var(--ui-spacing-md)}.ui-p-4{padding:var(--ui-spacing-lg)}.ui-p-5{padding:var(--ui-spacing-xl)}.ui-mb-0{margin-bottom:0}.ui-mb-1{margin-bottom:var(--ui-spacing-xs)}.ui-mb-2{margin-bottom:var(--ui-spacing-sm)}.ui-mb-3{margin-bottom:var(--ui-spacing-md)}.ui-mb-4{margin-bottom:var(--ui-spacing-lg)}.ui-mb-5{margin-bottom:var(--ui-spacing-xl)}.ui-hidden{display:none}.ui-block{display:block}.ui-inline{display:inline}.ui-inline-block{display:inline-block}.ui-rounded{border-radius:var(--ui-border-radius-md)}.ui-rounded-lg{border-radius:var(--ui-border-radius-lg)}.ui-rounded-xl{border-radius:var(--ui-border-radius-xl)}.ui-rounded-full{border-radius:var(--ui-border-radius-round)}.ui-border{border:1px solid var(--ui-gray-200)}.ui-border-t{border-top:1px solid var(--ui-gray-200)}.ui-border-b{border-bottom:1px solid var(--ui-gray-200)}.ui-shadow-sm{box-shadow:var(--ui-shadow-sm)}.ui-shadow{box-shadow:var(--ui-shadow-md)}.ui-shadow-lg{box-shadow:var(--ui-shadow-lg)}.ui-shadow-xl{box-shadow:var(--ui-shadow-xl)}.ui-shadow-none{box-shadow:none}@media (max-width: 768px){.ui-container{padding:0 var(--ui-spacing-sm)}.ui-grid-cols-4,.ui-grid-cols-3{grid-template-columns:repeat(2,1fr)}.ui-power-switch{width:36px;height:36px}.ui-power-icon{width:12px;height:12px}}@media (max-width: 480px){.ui-grid-cols-4,.ui-grid-cols-3,.ui-grid-cols-2{grid-template-columns:1fr}.ui-btn{padding:var(--ui-spacing-md);font-size:var(--ui-font-size-base)}.ui-power-switch{width:32px;height:32px}}h1,h2,h3,h4,h5,h6{margin:0 0 var(--ui-spacing-md) 0;font-weight:600;line-height:1.25;color:var(--ui-gray-900)}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1.125rem}p{margin:0 0 var(--ui-spacing-md) 0}a{color:var(--ui-primary-color);text-decoration:none;transition:color var(--ui-transition-fast)}a:hover{color:var(--ui-secondary-color);text-decoration:underline}.container{width:100%;max-width:none!important;margin:0 auto;padding:0 var(--ui-spacing-md)}.row{display:flex;flex-wrap:wrap;margin:0 calc(-1 * var(--ui-spacing-sm))}.col{flex:1;padding:0 var(--ui-spacing-sm)}.col-auto{flex:0 0 auto}.app-error{max-width:600px;margin:20px auto;padding:30px;background:linear-gradient(135deg,#f8d7da,#f5c6cb);border:1px solid #f5c6cb;border-radius:12px;text-align:center;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;box-shadow:0 4px 20px #0000001a;color:#721c24}.app-error h3{margin:0 0 15px;font-size:1.5rem;font-weight:600}.app-error p{margin:0 0 20px;font-size:1.1rem;line-height:1.5}.app-error-reload{background:#721c24;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s ease;display:inline-flex;align-items:center;gap:8px}.app-error-reload:hover{background:#5a1419;transform:translateY(-1px);box-shadow:0 4px 12px #721c244d}.app-error-reload:active{transform:translateY(0)}.browser-fallback{max-width:600px;margin:50px auto;padding:40px;text-align:center;font-family:Arial,sans-serif;background:#f8f9fa;border-radius:12px;box-shadow:0 4px 20px #0000001a;color:#495057}.browser-fallback h2{color:#dc3545;margin-bottom:20px;font-size:1.75rem;font-weight:600}.fallback-description{color:#6c757d;font-size:1.1rem;line-height:1.6;margin-bottom:25px}.fallback-browsers{margin:30px 0;padding:20px;background:#6c757d1a;border-radius:8px;font-size:1rem;line-height:1.6}.fallback-browsers strong{color:#495057;font-weight:600}.fallback-action{color:#28a745;font-size:1rem;font-weight:500;margin:25px 0 0}.app-loading{text-align:center;padding:40px 20px;color:#6c757d;font-size:1.1rem;font-weight:500}.app-loading:after{content:"";display:inline-block;width:20px;height:20px;margin-left:10px;border:2px solid #dee2e6;border-top:2px solid #6c757d;border-radius:50%;animation:app-loading-spin 1s linear infinite}@keyframes app-loading-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.container{padding:0 var(--ui-spacing-sm)}.row{margin:0}.col{padding:0;margin-bottom:var(--ui-spacing-md)}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}h4{font-size:1.25rem}.app-error,.browser-fallback{margin:20px;padding:25px}.app-error h3,.browser-fallback h2{font-size:1.4rem}.fallback-description,.app-error p{font-size:1rem}.app-error-reload{padding:10px 20px;font-size:.9rem}}@media (max-width: 480px){h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}.app-error,.browser-fallback{margin:15px;padding:20px}.fallback-browsers{padding:15px;font-size:.9rem}}.main-app-header{background:#fff;padding:24px 20px;border-bottom:1px solid #e5e7eb;text-align:center}.main-app-title{font-size:1.75rem;font-weight:700;color:#1f2937;margin:0 0 20px}.main-app-description-container{max-width:80%;margin:0 auto}.main-app-description{font-size:1rem;color:#6b7280;line-height:1.6;margin:0}.tiroir-navigation{width:100%;height:auto;min-height:80px;background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d}.nav-container{height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 20px;gap:16px}.nav-tabs{display:flex;gap:8px;flex:1}.nav-actions{display:flex;align-items:center;gap:32px;flex-shrink:0;margin-left:16px}.nav-action-btn{padding:16px 20px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#374151;min-width:56px;position:relative}.nav-action-btn:hover{background:#f3f4f6;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.nav-export-btn:hover{background:#dbeafe;border-color:#3b82f6}.nav-delete-btn:hover{background:#fef2f2;border-color:#ef4444}.nav-tab{flex:1;padding:16px 20px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .3s ease;position:relative}.nav-tab:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.nav-tab-active{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border-color:#3b82f6;box-shadow:0 4px 16px #3b82f64d}.nav-tab-active:hover{transform:translateY(-1px);box-shadow:0 6px 20px #3b82f666}.tab-content{display:flex;flex-direction:column;align-items:center;gap:4px}.tab-title{font-weight:600;color:#374151;font-size:1rem}.tab-percentage{font-size:.85rem;color:#6b7280;font-weight:500}.nav-tab-active .tab-title{color:#fff}.nav-tab-active .tab-percentage{color:#ffffffe6;font-weight:600}.modules-view{height:auto;overflow-y:auto;background:#fafafa}.modules-container{padding:20px;max-width:1400px;margin:0 auto}.modules-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#6b7280;font-size:1.1rem}.power-switch{width:32px;height:32px;border:none;border-radius:50%;cursor:pointer;transition:all .3s ease;position:relative;box-shadow:0 2px 6px #0000001a}.power-switch-on{background:#10b981}.power-switch-off{background:#9ca3af}.power-switch:hover{transform:scale(1.1);box-shadow:0 4px 12px #00000026}.power-icon{width:16px;height:16px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border:2px solid white;border-radius:50%;border-top-color:transparent}.power-icon:after{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%);width:2px;height:8px;background:#fff;border-radius:1px}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.module-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;transition:all .2s ease;box-shadow:0 1px 3px #0000000d}.module-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.module-card-disabled{opacity:.5;pointer-events:none}.module-card-disabled:hover{transform:none;box-shadow:0 1px 3px #0000000d}.module-card-disabled .power-switch{pointer-events:auto}.module-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.module-info{flex:1}.module-title{font-size:1.1rem;font-weight:700;color:#1f2937;margin:0 0 4px}.module-subtitle{font-size:.85rem;color:#6b7280;margin:0}.module-controls{display:flex;align-items:center;gap:8px}.module-edit-btn{width:32px;height:32px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-size:14px}.module-edit-btn:hover:not(:disabled){background:#f3f4f6;border-color:#d1d5db;transform:translateY(-1px)}.module-edit-btn-disabled{opacity:.3;cursor:not-allowed}.module-stats{display:flex;flex-direction:column;gap:12px}.stat-item{display:flex;align-items:center;gap:8px}.stat-label{font-size:.9rem;color:#6b7280;font-weight:500}.stat-value{font-size:.9rem;font-weight:600;color:#374151}.stat-row{display:flex;gap:20px}.stat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.stat-libre .stat-dot{background:#10b981}.stat-occupee .stat-dot{background:#f59e0b}.stat-count{font-weight:600;color:#374151;min-width:20px}.stat-text{font-size:.85rem;color:#6b7280}@media (max-width: 1024px){.modules-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}.main-app-description-container{max-width:90%}}@media (max-width: 768px){.nav-container{padding:0 10px;gap:12px}.nav-tab{padding:12px 16px}.tab-title{font-size:.9rem}.tab-percentage{font-size:.8rem}.modules-container{padding:15px}.modules-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.module-card{padding:16px}.tiroir-header{margin-bottom:15px}.main-app-description-container{max-width:95%}.main-app-description{font-size:.9rem}.nav-actions{gap:20px;margin-left:12px}.nav-action-btn{padding:12px 16px;font-size:1.1rem;min-width:48px}}@media (max-width: 640px){.nav-tabs{gap:4px}.nav-tab{padding:10px 8px}.tab-title{font-size:.8rem}.tab-percentage{font-size:.75rem}.modules-grid{grid-template-columns:1fr}.stat-row{gap:16px}.nav-container{gap:8px}.nav-actions{gap:16px;margin-left:8px}.nav-action-btn{padding:10px 8px;font-size:1rem;min-width:40px}}@media (max-width: 480px){.tiroir-navigation{min-height:70px}.nav-tab{padding:8px 6px}.tab-content{gap:2px}.modules-container{padding:10px}.module-card{padding:12px}.module-card-header{margin-bottom:12px}.module-controls{gap:6px}.power-switch{width:28px;height:28px}.power-switch .power-icon{width:14px;height:14px}.power-icon{width:18px;height:18px}.main-app-description-container{max-width:100%}.nav-container{gap:6px;padding:0 8px}.nav-actions{gap:12px;margin-left:6px}.nav-action-btn{padding:8px 6px;font-size:.9rem;min-width:36px}}.welcome-header{margin-bottom:var(--ui-spacing-2xl);text-align:center;max-width:1200px;margin-left:auto;margin-right:auto}.welcome-title{font-size:2.2rem;font-weight:600;color:var(--ui-gray-800);margin:0 0 var(--ui-spacing-xl) 0;line-height:1.3;text-align:center}.welcome-subtitle{font-size:var(--ui-font-size-base);color:var(--ui-gray-600);margin:0 0 var(--ui-spacing-2xl) 0;line-height:1.6;text-align:center;max-width:1100px;margin-left:auto;margin-right:auto}.welcome-how-it-works{margin:var(--ui-spacing-2xl) 0;text-align:center}.how-it-works-title{font-size:var(--ui-font-size-lg);color:var(--ui-danger-color);margin:0 0 var(--ui-spacing-lg) 0;font-weight:600}.how-it-works-text{font-size:var(--ui-font-size-base);color:var(--ui-gray-600);line-height:1.6;max-width:1000px;margin:0 auto}.welcome-actions{display:flex;justify-content:center;margin:var(--ui-spacing-2xl) 0;gap:var(--ui-spacing-2xl)}.welcome-single-btn{padding:var(--ui-spacing-md) var(--ui-spacing-2xl);font-size:var(--ui-font-size-base);min-width:200px}.welcome-footer{text-align:center;margin-top:var(--ui-spacing-2xl);padding-top:var(--ui-spacing-2xl)}.footer-links{margin-bottom:var(--ui-spacing-sm);display:flex;flex-direction:column;gap:var(--ui-spacing-xs);align-items:center}.footer-link{color:var(--ui-primary-color);text-decoration:none;transition:color var(--ui-transition-fast);margin:0;font-size:.9rem}.footer-link:hover{color:var(--ui-secondary-color);text-decoration:underline}.footer-version{color:var(--ui-gray-400);font-size:.9rem;margin-top:var(--ui-spacing-sm)}@media (max-width: 768px){.welcome-title{font-size:var(--ui-font-size-2xl)}.welcome-subtitle{font-size:var(--ui-font-size-sm);padding:0 var(--ui-spacing-md)}.how-it-works-text{padding:0 var(--ui-spacing-md)}.welcome-actions{flex-direction:column;align-items:center}.welcome-single-btn{width:100%;max-width:300px}}@media (max-width: 480px){.welcome-title{font-size:var(--ui-font-size-xl);padding:0 var(--ui-spacing-sm)}}.creator-header{text-align:center;margin-bottom:var(--ui-spacing-2xl)}.creator-title{font-size:var(--ui-font-size-3xl);font-weight:700;color:var(--ui-gray-900);margin:0 0 var(--ui-spacing-sm) 0}.creator-subtitle{font-size:var(--ui-font-size-base);color:var(--ui-gray-500);margin:0}.creator-form{display:flex;flex-direction:column;gap:var(--ui-spacing-2xl)}.form-section{display:flex;flex-direction:column;gap:var(--ui-spacing-sm)}.form-section.form-section-inline{flex-direction:row;align-items:center;gap:var(--ui-spacing-lg)}.form-section.form-section-inline .ui-label{flex-shrink:0;min-width:150px}.form-section.form-section-inline .ui-input{flex:1;max-width:200px}.label-icon{font-size:var(--ui-font-size-lg)}.radio-group{display:grid;grid-template-columns:1fr 1fr;gap:var(--ui-spacing-lg);max-width:50%;margin:0}.radio-option{display:flex;align-items:flex-start;gap:var(--ui-spacing-sm);padding:var(--ui-spacing-xl) var(--ui-spacing-lg);border:2px solid var(--ui-gray-200);border-radius:var(--ui-border-radius-xl);cursor:pointer;transition:var(--ui-transition-normal);background:var(--ui-white);text-align:left;flex-direction:column;min-height:180px;justify-content:flex-start;position:relative;overflow:hidden}.radio-option:hover{border-color:var(--ui-primary-color);background:#f8faff;transform:translateY(-4px);box-shadow:0 8px 25px #3b82f626}.radio-option:has(input:checked){border-color:var(--ui-primary-color);background:linear-gradient(135deg,#f0f9ff,#e0f2fe);box-shadow:0 8px 32px #3b82f640;transform:translateY(-2px)}.radio-option input[type=radio],.radio-custom{display:none}.radio-number{font-size:4rem;font-weight:900;color:#1e40af;line-height:.9;margin-bottom:var(--ui-spacing-sm);text-shadow:0 2px 4px rgba(30,64,175,.1)}.radio-text{font-weight:600;color:var(--ui-gray-700);margin-bottom:var(--ui-spacing-sm);font-size:var(--ui-font-size-lg)}.radio-modules{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-start;margin-top:4px}.radio-modules.modules-12{max-width:200px}.radio-module{background:#e0f2fe;color:#0c4a6e;padding:4px 8px;border-radius:var(--ui-border-radius-sm);font-size:var(--ui-font-size-xs);font-weight:700;min-width:24px;text-align:center;border:1px solid #bae6fd;box-shadow:var(--ui-shadow-sm)}.tiroirs-switches-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--ui-spacing-md);max-width:100%}.tiroir-switch-item{display:flex;align-items:center;justify-content:space-between;padding:var(--ui-spacing-md) var(--ui-spacing-lg);border:2px solid var(--ui-gray-200);border-radius:var(--ui-border-radius-lg);background:var(--ui-white);transition:var(--ui-transition-normal);min-height:70px}.tiroir-switch-item:hover{border-color:var(--ui-gray-300);background:var(--ui-gray-50);transform:translateY(-2px);box-shadow:var(--ui-shadow-md)}.tiroir-label{font-weight:600;color:var(--ui-gray-700);font-size:var(--ui-font-size-base)}.tiroir-power-switch{width:40px;height:40px;border:none;border-radius:var(--ui-border-radius-round);cursor:pointer;transition:var(--ui-transition-normal);position:relative;box-shadow:var(--ui-shadow-sm);flex-shrink:0}.power-switch-on{background:var(--ui-success-color)}.power-switch-off{background:var(--ui-gray-400)}.tiroir-power-switch:hover{transform:scale(1.1);box-shadow:var(--ui-shadow-md)}.power-icon{width:14px;height:14px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border:2px solid var(--ui-white);border-radius:var(--ui-border-radius-round);border-top-color:transparent}.power-icon:after{content:"";position:absolute;top:-4px;left:50%;transform:translate(-50%);width:2px;height:6px;background:var(--ui-white);border-radius:1px}.form-actions{display:flex;gap:var(--ui-spacing-md);justify-content:flex-end;padding-top:var(--ui-spacing-lg);border-top:1px solid var(--ui-gray-200)}@media (max-width: 768px){.creator-title{font-size:var(--ui-font-size-2xl)}.radio-group{grid-template-columns:1fr;max-width:100%}.tiroirs-switches-grid{grid-template-columns:repeat(3,1fr)}.form-section.form-section-inline{flex-direction:column;align-items:flex-start}.form-section.form-section-inline .ui-input{max-width:100%;width:100%}.form-actions{flex-direction:column-reverse}}@media (max-width: 480px){.radio-option{padding:var(--ui-spacing-lg) var(--ui-spacing-md);min-height:160px}.radio-number{font-size:3rem}.tiroir-switch-item{padding:14px var(--ui-spacing-md);min-height:60px}.tiroir-power-switch{width:36px;height:36px}.power-icon{width:12px;height:12px}.tiroirs-switches-grid{grid-template-columns:repeat(2,1fr)}}:root{--ribbon-closed-width: 40px;--ribbon-open-width: 95vw;--ribbon-height-closed: 300px;--ribbon-shadow-closed: 0 10px 40px rgba(0, 0, 0, .15);--ribbon-shadow-open: 0 20px 60px rgba(0, 0, 0, .25)}.riban-config{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:9999;font-family:var(--ui-font-family);transition:var(--ui-transition-complex)}.riban-config.riban-closed{width:var(--ribbon-closed-width);height:var(--ribbon-height-closed)}.riban-content-closed{width:100%;height:100%;background:linear-gradient(135deg,var(--ui-primary-color),var(--ui-secondary-color));border-radius:var(--ui-border-radius-lg) 0 0 var(--ui-border-radius-lg);box-shadow:var(--ribbon-shadow-closed);display:flex;align-items:center;justify-content:center;cursor:default;transition:var(--ui-transition-complex)}.riban-content-closed:hover{box-shadow:var(--ribbon-shadow-open);transform:translate(-2px)}.riban-text-vertical{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--ui-white);font-weight:600;font-size:var(--ui-font-size-xs);letter-spacing:2px}.riban-text-vertical span{display:block;text-shadow:0 1px 3px rgba(0,0,0,.3);transition:var(--ui-transition-fast)}.riban-content-closed:hover .riban-text-vertical span{transform:scale(1.1);text-shadow:0 2px 6px rgba(0,0,0,.4)}.riban-config.riban-open{width:95vw;max-width:1600px}.riban-content-open{width:100%;height:100%;background:var(--ui-white);border-radius:var(--ui-border-radius-lg) 0 0 var(--ui-border-radius-lg);box-shadow:var(--ribbon-shadow-open);display:flex;flex-direction:column;overflow:hidden}.riban-header{background:linear-gradient(135deg,var(--ui-primary-color),var(--ui-secondary-color));color:var(--ui-white);padding:var(--ui-spacing-lg) var(--ui-spacing-xl);display:flex;justify-content:flex-start;align-items:center;box-shadow:var(--ui-shadow-sm)}.riban-title{font-size:var(--ui-font-size-2xl);font-weight:700;margin:0;color:var(--ui-white);text-shadow:0 2px 4px rgba(0,0,0,.3)}.riban-module-container{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--ui-gray-100)}.riban-module-container::-webkit-scrollbar{width:8px}.riban-module-container::-webkit-scrollbar-track{background:var(--ui-gray-200);border-radius:var(--ui-border-radius-sm)}.riban-module-container::-webkit-scrollbar-thumb{background:var(--ui-gray-600);border-radius:var(--ui-border-radius-sm);transition:background var(--ui-transition-normal)}.riban-module-container::-webkit-scrollbar-thumb:hover{background:var(--ui-gray-800)}@keyframes ribanSlideIn{0%{transform:translate(100%) translateY(-50%);opacity:0}to{transform:translate(0) translateY(-50%);opacity:1}}.riban-config{animation:ribanSlideIn .6s cubic-bezier(.25,.46,.45,.94)}.riban-content-closed:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);transform:rotate(45deg);animation:ribanShine 3s ease-in-out infinite}@keyframes ribanShine{0%,to{transform:translate(-100%) translateY(-100%) rotate(45deg)}50%{transform:translate(100%) translateY(100%) rotate(45deg)}}@media (max-width: 1024px){.riban-config.riban-open{width:85vw}}@media (max-width: 768px){.riban-config.riban-open{width:95vw;height:95vh;right:2.5vw;border-radius:var(--ui-border-radius-lg)}.riban-content-open{border-radius:var(--ui-border-radius-lg)}.riban-header{padding:var(--ui-spacing-md) var(--ui-spacing-lg)}.riban-title{font-size:var(--ui-font-size-xl)}}@media (max-width: 480px){.riban-config.riban-closed{width:35px;height:250px}.riban-text-vertical{font-size:.6rem;gap:3px}.riban-config.riban-open{width:100vw;height:100vh;right:0;top:0;transform:none;border-radius:0}.riban-content-open{border-radius:0}.riban-header{padding:var(--ui-spacing-md)}.riban-title{font-size:var(--ui-font-size-lg)}}.module-container{background:var(--ui-white);border-radius:var(--ui-border-radius-lg);padding:30px;box-shadow:var(--ui-shadow-md);margin:0;width:fit-content;min-width:fit-content;display:block;text-align:center}.module-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--ui-spacing-lg);width:100%;text-align:left}.module-title{font-size:var(--ui-font-size-2xl);font-weight:700;color:var(--ui-gray-900);margin:0;flex:1}.module-vocal-toggle-btn{width:48px;height:48px;border:none;border-radius:var(--ui-border-radius-md);background:linear-gradient(135deg,#e3f2fd,#bbdefb);color:#1976d2;font-size:var(--ui-font-size-2xl);cursor:pointer;transition:var(--ui-transition-normal);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 8px #1976d233;position:relative;overflow:hidden;border:2px solid rgba(25,118,210,.3)}.module-vocal-toggle-btn:hover{background:linear-gradient(135deg,#bbdefb,#90caf9);transform:translateY(-2px);box-shadow:0 6px 16px #1976d24d;border-color:#1976d280}.module-vocal-toggle-btn.vocal-active{background:linear-gradient(135deg,var(--ui-danger-color),#c82333);color:var(--ui-white);animation:vocal-pulse 2s ease-in-out infinite}.module-vocal-toggle-btn.vocal-active:hover{background:linear-gradient(135deg,#c82333,#a71e2a)}@keyframes vocal-pulse{0%,to{box-shadow:0 2px 4px #0000001a}50%{box-shadow:0 2px 4px #0000001a,0 0 20px #dc354566}}.vocal-icon{font-size:1.4rem;line-height:1;transition:var(--ui-transition-fast);filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.module-vocal-toggle-btn:hover .vocal-icon{transform:scale(1.1)}.module-vocal-toggle-btn.vocal-active .vocal-icon{animation:vocal-icon-bounce 1s ease-in-out infinite}@keyframes vocal-icon-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.module-stats-row{display:flex;justify-content:center;gap:var(--ui-spacing-md);margin-bottom:var(--ui-spacing-lg);flex-wrap:wrap;width:100%}.module-stat-configured,.module-stat-libres,.module-stat-occupees{flex:1;max-width:220px;min-width:180px;height:80px}.module-stat-configured .ui-stat-label,.module-stat-libres .ui-stat-label,.module-stat-occupees .ui-stat-label{text-align:center;white-space:nowrap}.module-stat-configured .ui-stat-value,.module-stat-libres .ui-stat-value,.module-stat-occupees .ui-stat-value{text-align:center}.module-fiber-grid{display:grid;grid-template-columns:repeat(24,55px);gap:10px;margin:5px auto;padding-left:2px;padding-right:2px;padding-top:var(--ui-spacing-lg);padding-bottom:var(--ui-spacing-lg);background:var(--ui-gray-50);border-radius:var(--ui-border-radius-md);width:fit-content;box-sizing:border-box}.module-fiber-card{display:flex;flex-direction:column;align-items:center;padding:6px;background:var(--ui-white);border-radius:var(--ui-border-radius-sm);box-shadow:var(--ui-shadow-sm);transition:var(--ui-transition-fast);min-width:45px;max-width:55px}.module-fiber-card:hover{transform:translateY(-1px);box-shadow:var(--ui-shadow-md)}.module-fiber-num{width:35px;height:35px;text-align:center;line-height:35px;font-weight:700;font-size:var(--ui-font-size-sm);border-radius:var(--ui-border-radius-sm);background:linear-gradient(135deg,var(--ui-gray-100),#e8eaed);color:var(--ui-gray-600);margin-bottom:4px}.module-fiber-img-wrapper{width:40px;height:120px;display:flex;align-items:center;justify-content:center;margin-bottom:4px;overflow:hidden;background:var(--ui-gray-50);border-radius:var(--ui-border-radius-sm)}.module-fiber-img{width:100%;max-height:100%;object-fit:contain;display:block}.module-fiber-status{width:40px;height:auto;text-align:center;font-size:.5rem;font-weight:700;border-radius:var(--ui-border-radius-sm);padding:4px;margin-bottom:4px;color:#000;text-shadow:0 1px 2px rgba(0,0,0,.3);line-height:1;overflow:hidden;white-space:nowrap}.module-fiber-btn-wrapper{height:30px;width:40px;display:flex;justify-content:center;align-items:center}.module-fiber-btn{width:30px;height:30px;border:none;border-radius:var(--ui-border-radius-sm);background:linear-gradient(135deg,var(--ui-primary-color),#1a73e8);color:var(--ui-white);font-size:var(--ui-font-size-sm);cursor:pointer;transition:var(--ui-transition-fast);display:flex;align-items:center;justify-content:center}.module-fiber-btn:hover:not(:disabled){background:linear-gradient(135deg,#1a73e8,#1557b0);transform:scale(1.05)}.module-fiber-btn:disabled{background:var(--ui-gray-300);color:var(--ui-gray-500);cursor:not-allowed;transform:none}.module-actions{display:flex;gap:var(--ui-spacing-md);margin-bottom:0;flex-wrap:wrap;justify-content:flex-start;align-items:center;width:100%}.module-btn-back{margin-left:auto;min-width:160px}.module-vocal-status{display:none;margin-top:var(--ui-spacing-md);padding:var(--ui-spacing-md);background:var(--ui-gray-50);border-radius:var(--ui-border-radius-md);text-align:left}.speech-main-status{font-size:var(--ui-font-size-sm);font-weight:600;color:var(--ui-gray-700);margin-bottom:var(--ui-spacing-sm)}.speech-heard-text{font-size:var(--ui-font-size-sm);color:var(--ui-gray-600);margin-bottom:var(--ui-spacing-xs)}.speech-last-command{font-size:var(--ui-font-size-sm);color:var(--ui-success-color);font-weight:500}@media (max-width: 768px){.module-container{padding:15px}.module-header{margin-bottom:15px}.module-title{font-size:var(--ui-font-size-xl)}.module-vocal-toggle-btn{width:44px;height:44px;font-size:var(--ui-font-size-xl)}.module-stats-row{flex-direction:column;gap:.75rem}.module-stat-configured,.module-stat-libres,.module-stat-occupees{width:100%;height:70px}.module-fiber-grid{grid-template-columns:repeat(auto-fit,minmax(45px,1fr));gap:6px}.module-actions{flex-direction:column;align-items:stretch}}@media (max-width: 480px){.module-fiber-grid{grid-template-columns:repeat(6,1fr)}}
