*{box-sizing:border-box;margin:0;padding:0}:root{--primary: #b42500;--primary-dark: #8a1c00;--primary-light: rgba(180, 37, 0, .1);--primary-hover: #9d1f00;--secondary: #6B7280;--success: #10B981;--success-light: #D1FAE5;--danger: #EF4444;--danger-light: #FEE2E2;--warning: #F59E0B;--warning-light: #FEF3C7;--info: #3B82F6;--info-light: #DBEAFE;--bg: #F3F4F6;--bg-secondary: #E5E7EB;--bg-white: #FFFFFF;--bg-hover: #F9FAFB;--text: #1F2937;--text-secondary: #4B5563;--text-light: #6B7280;--text-lighter: #9CA3AF;--border: #E5E7EB;--border-light: #F3F4F6;--border-dark: #D1D5DB;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--radius-sm: 4px;--radius: 8px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--font-family-base: "Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", sans-serif;--font-family-heading: "harman-sans", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", sans-serif;--font-family-mono: SFMono-Regular, Menlo, Consolas, "PT Mono", "Liberation Mono", Courier, monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2rem;--font-size-5xl: 2.5rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 999;--z-modal: 1000;--z-toast: 1100;--event-reunion: #3B82F6;--event-atelier: #10B981;--event-repetition: #84CC16;--event-concert: #EF4444;--event-stage: #8B5CF6;--event-salon: #F59E0B;--event-fete: #EC4899;--event-maintenance: #6B7280;--event-reunion_ca: #0EA5E9}[data-theme=dark]{--primary: #ff6b4a;--primary-dark: #ff5533;--primary-light: rgba(255, 107, 74, .1);--primary-hover: #ff7d5c;--bg: #111827;--bg-secondary: #1F2937;--bg-white: #1F2937;--bg-hover: #374151;--text: #F9FAFB;--text-secondary: #E5E7EB;--text-light: #D1D5DB;--text-lighter: #9CA3AF;--border: #374151;--border-light: #2D3748;--border-dark: #4B5563;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow: 0 2px 4px rgba(0, 0, 0, .5);--shadow-md: 0 4px 6px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .6);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .7);--success: #34D399;--success-light: rgba(52, 211, 153, .1);--danger: #F87171;--danger-light: rgba(248, 113, 113, .1);--warning: #FBBF24;--warning-light: rgba(251, 191, 36, .1);--info: #60A5FA;--info-light: rgba(96, 165, 250, .1)}[data-theme=dark] .pedagogie-content pre,[data-theme=dark] .pedagogie-content .music-notation,[data-theme=dark] .pedagogie-content pre.music-notation{background:#1a1d23;border-color:#2d3748;border-left-color:var(--primary);color:#e2e8f0}[data-theme=dark] .pedagogie-content pre::-webkit-scrollbar-thumb,[data-theme=dark] .pedagogie-content .music-notation::-webkit-scrollbar-thumb{background:#4b5563}[data-theme=dark] .pedagogie-content pre::-webkit-scrollbar-thumb:hover,[data-theme=dark] .pedagogie-content .music-notation::-webkit-scrollbar-thumb:hover{background:#6b7280}[data-theme=dark] .pedagogie-content .media-container{background:var(--bg-secondary);border-color:var(--border)}[data-theme=dark] .pedagogie-content .media-caption{color:var(--text-light)}body{font-family:var(--font-family-base);background:var(--bg);color:var(--text);line-height:var(--line-height-normal);transition:background-color var(--transition-slow),color var(--transition-slow)}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-heading);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--text)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}code,pre,kbd,samp{font-family:var(--font-family-mono)}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}*:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:var(--radius-sm)}.app-layout{display:flex;min-height:100vh;position:relative}.pedagogie-cover-global{height:clamp(200px,30vh,400px);overflow:hidden}.pedagogie-cover-global.desktop-only{display:block;position:absolute;top:0;left:0;right:0;z-index:1;pointer-events:none}.pedagogie-cover-global.mobile-only{display:none}.pedagogie-cover-global img{width:100%;height:100%;object-fit:cover;object-position:center}.pedagogie-cover-global .pedagogie-cover-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,#0000004d,#00000080);pointer-events:none}.sidebar{width:250px;background:var(--bg-white);border-right:1px solid var(--border);padding:1rem;position:fixed;height:100vh;overflow-y:auto;display:flex;flex-direction:column;transition:width .3s ease;z-index:100}.sidebar-nav-container{flex:1}.sidebar-bottom{margin-top:auto}.sidebar-logo{display:flex;flex-direction:column;align-items:center;margin-bottom:2rem;padding:.5rem;text-align:center;transition:opacity .2s ease}.sidebar-logo:hover{opacity:.8}.sidebar-nav{list-style:none}.sidebar-nav a{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:var(--text);text-decoration:none;border-radius:var(--radius);margin-bottom:.25rem;transition:background .2s}.sidebar-nav a:hover,.sidebar-nav a.active{background:var(--bg)}.sidebar-nav a.active{color:var(--primary);font-weight:500}.sidebar-nav .nav-back{font-size:.9rem;opacity:.7;transition:opacity .2s}.sidebar-nav .nav-back:hover{opacity:1}.sidebar-nav .nav-section-title{display:flex;align-items:center;padding:.75rem 1rem;font-weight:600;font-size:1rem;color:var(--text);border-bottom:1px solid var(--border);margin-bottom:.5rem}.sidebar-nav .nav-category-child{margin-left:1rem}.sidebar-nav .nav-category-child a{font-size:.9rem}.sidebar.collapsed{width:80px;overflow-x:hidden}.sidebar.collapsed .sidebar-logo img{width:48px}.sidebar.collapsed .sidebar-nav a span,.sidebar.collapsed .sidebar-nav .nav-section-title{display:none}.sidebar.collapsed .sidebar-nav a{justify-content:center;padding:.75rem .5rem}.sidebar.collapsed .user-menu{justify-content:center}.sidebar-toggle-btn{position:absolute;top:1rem;right:1rem;background:var(--bg-white);border:1px solid var(--border);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-light);transition:all .2s ease;z-index:10}.sidebar-toggle-btn:hover{color:var(--primary);background:var(--bg-secondary);border-color:var(--primary)}.sidebar-logo{margin-top:3rem}.main-content{flex:1;margin-left:250px;padding:2rem;transition:margin-left .3s ease;display:flex;flex-direction:column}.main-content.has-pedagogie-cover{padding-top:calc(clamp(200px,30vh,400px) + 3.5rem)}.sidebar.collapsed~.main-content{margin-left:80px}@media (max-width: 768px){.main-content{padding:0!important}.sidebar-toggle-btn{display:none}.sidebar.collapsed{width:250px}.main-content{margin-left:0}.sidebar.collapsed~.main-content{margin-left:0}}.global-footer{margin-top:auto;padding:2rem 1.5rem 1.5rem;background:var(--color-background-secondary);border-top:1px solid var(--color-border);font-size:.875rem;color:var(--color-text-secondary)}.global-footer-content{max-width:1200px;margin:0 auto;text-align:center}.global-footer-text{margin:0;font-weight:400}.global-footer-separator{opacity:.5;margin:0 .5rem}.global-footer-link{color:var(--color-primary);text-decoration:none;transition:opacity .2s}.global-footer-link:hover{opacity:.8;text-decoration:underline}.global-footer-claude{font-weight:600;color:var(--color-primary)}@media (max-width: 768px){.global-footer{padding:1.5rem 1rem 1rem;font-size:.8125rem}.global-footer-copyright,.global-footer-credits{line-height:1.6}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.page-title{font-family:var(--font-family-heading);font-size:var(--font-size-3xl);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--text);margin:0;word-break:break-word}.page-title:not(.page-header *){margin-bottom:1.5rem}.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;padding:.5rem 1.5rem;font-size:var(--font-size-sm);color:var(--text-light);background:var(--bg);border-bottom:1px solid var(--border);gap:.125rem}.breadcrumb-item{display:flex;align-items:center;gap:.125rem}.breadcrumb a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}.breadcrumb a:hover{color:var(--primary-dark);text-decoration:underline}.breadcrumb-sep{color:var(--text-lighter);padding:0 .25rem;-webkit-user-select:none;user-select:none}.breadcrumb-current{color:var(--text);font-weight:var(--font-weight-medium)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border:none;transition:all var(--transition-base);text-decoration:none;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width var(--transition-slow),height var(--transition-slow)}.btn:active:before{width:300px;height:300px}.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-dark);box-shadow:var(--shadow-sm)}.btn-danger{background:var(--danger);color:#fff;box-shadow:var(--shadow-sm)}.btn-danger:hover{background:#dc2626;box-shadow:var(--shadow-md);transform:translateY(-1px)}[data-theme=dark] .btn-danger:hover{background:#ef4444}.btn-danger:active{transform:translateY(0)}.btn-sm{padding:.375rem .75rem;font-size:var(--font-size-xs)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-group{display:flex;gap:.5rem}.view-toggle{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--bg-white);box-shadow:var(--shadow-xs)}.view-toggle-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;background:transparent;color:var(--text);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.view-toggle-btn:not(:first-child){border-left:1px solid var(--border)}.view-toggle-btn:hover{background:var(--bg-hover)}.view-toggle-btn.active{background:var(--primary);color:#fff}.view-toggle-btn.active:hover{background:var(--primary-hover)}@media (max-width: 640px){.view-toggle-btn span{display:none}.view-toggle-btn{padding:.5rem .75rem}}.card{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1.5rem;margin-bottom:1rem;transition:all var(--transition-base);border:1px solid transparent}.card:hover{box-shadow:var(--shadow-md);border-color:var(--border-light)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.card-title{font-size:1.125rem;font-weight:600}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.375rem;font-weight:500;font-size:.875rem}.form-input,.form-select,.form-textarea{width:100%;padding:.625rem .875rem;border:1px solid var(--border);border-radius:var(--radius);font-size:.875rem;transition:border-color .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary)}.form-textarea{resize:vertical;min-height:100px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-error{color:var(--danger);font-size:.8125rem;margin-top:.25rem}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.auth-card{width:100%;max-width:400px;background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:2rem}.auth-title{font-size:1.5rem;font-weight:600;text-align:center;margin-bottom:1.5rem}.auth-footer{text-align:center;margin-top:1.5rem;color:var(--text-light);font-size:.875rem}.auth-footer a{color:var(--primary);text-decoration:none}.auth-footer a:hover{text-decoration:underline}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.calendar-nav{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.calendar-nav-center{display:flex;align-items:center;gap:.375rem}.calendar-nav-btn{background:var(--bg-white)!important}.calendar-views{margin-left:auto}.calendar-title{font-size:1.125rem;font-weight:700;text-transform:capitalize;min-width:160px;text-align:center;margin:0}.calendar-views{display:flex;gap:.25rem;background:var(--bg);padding:.25rem;border-radius:var(--radius)}.calendar-views button{padding:.5rem 1rem;border:none;background:transparent;border-radius:calc(var(--radius) - 2px);cursor:pointer;font-size:.875rem;color:var(--text-light);transition:all .2s}.calendar-views button.active{background:var(--bg-white);color:var(--text);box-shadow:var(--shadow)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.calendar-day-header{padding:.75rem;text-align:center;font-weight:600;font-size:.75rem;text-transform:uppercase;color:var(--text-light);background:var(--bg)}.calendar-day{min-height:120px;padding:.5rem;background:var(--bg-white);cursor:pointer;transition:background .2s}.calendar-day:hover{background:var(--bg)}.calendar-day.other-month{background:var(--bg);opacity:.5}.calendar-day.today{background:var(--info-light)}[data-theme=dark] .calendar-day.today{background:#3b82f626}.calendar-day-number{font-size:.875rem;font-weight:500;margin-bottom:.25rem}.calendar-day.today .calendar-day-number{background:var(--primary);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center}.calendar-week{display:grid;grid-template-columns:60px repeat(7,1fr);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.calendar-week-header{display:contents}.calendar-week-header>div{padding:.75rem;text-align:center;background:var(--bg);border-bottom:1px solid var(--border);font-size:.75rem}.calendar-week-header>div:first-child{border-right:1px solid var(--border)}.calendar-week-day-name{text-transform:uppercase;color:var(--text-light);font-weight:600}.calendar-week-day-number{font-size:1.25rem;font-weight:600;margin-top:.25rem}.calendar-week-body{display:contents}.calendar-week-time{padding:.5rem;font-size:.75rem;color:var(--text-light);text-align:right;border-right:1px solid var(--border);background:var(--bg-white)}.calendar-week-cell{min-height:60px;padding:.25rem;background:var(--bg-white);border-bottom:1px solid var(--border);border-right:1px solid var(--border)}.calendar-week-cell:last-child{border-right:none}.event-item{padding:.25rem .5rem;margin-bottom:.25rem;border-radius:4px;font-size:.75rem;color:#fff;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-item.event-reunion{background:var(--event-reunion)}.event-item.event-atelier{background:var(--event-atelier)}.event-item.event-repetition{background:var(--event-repetition)}.event-item.event-concert{background:var(--event-concert)}.event-item.event-stage{background:var(--event-stage)}.event-item.event-salon{background:var(--event-salon)}.event-item.event-fete{background:var(--event-fete)}.event-item.event-maintenance{background:var(--event-maintenance)}.event-item.event-reunion_ca{background:var(--event-reunion_ca)}.events-list{display:flex;flex-direction:column;gap:.75rem}.event-list-item{display:flex;gap:1rem;padding:1rem;background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;transition:box-shadow .2s,background .2s}.event-list-item:hover{box-shadow:var(--shadow-lg)}.event-list-item.not-responded{background:var(--warning-light)}[data-theme=dark] .event-list-item.not-responded{background:#f59e0b1a}.event-list-item.not-responded:hover{background:var(--warning-light)}[data-theme=dark] .event-list-item.not-responded:hover{background:#f59e0b26}.event-quick-response{display:flex;align-items:center}.atelier-availability{display:flex;align-items:center;margin-bottom:1.5rem}.atelier-presence-tag{display:inline-flex;align-items:center;font-size:.8rem;font-weight:600;color:#059669;background:#d1fae5;padding:.2rem .6rem;border-radius:999px;margin-right:.75rem}.atelier-presence-tag:before{content:"✓ "}.atelier-absence-tag{display:inline-flex;align-items:center;font-size:.8rem;font-weight:600;color:#b45309;background:#fef3c7;padding:.2rem .6rem;border-radius:999px;margin-right:.75rem}.atelier-absence-tag:before{content:"– "}.quick-response-btn{transition:transform .15s,opacity .15s}.quick-response-btn:hover:not(:disabled){transform:scale(1.1)}.quick-response-btn:disabled{opacity:.6;cursor:not-allowed}.event-list-date{text-align:center;padding:.5rem 1rem;background:var(--bg);border-radius:var(--radius);min-width:70px}.event-list-date-day{font-size:1.5rem;font-weight:700}.event-list-date-month{font-size:.75rem;text-transform:uppercase;color:var(--text-light)}.event-list-content{flex:1}.event-list-title{font-weight:600;margin-bottom:.25rem}.event-list-meta{font-size:.875rem;color:var(--text-light)}.event-list-type{display:inline-block;padding:.125rem .5rem;border-radius:4px;font-size:.75rem;color:#fff;margin-right:.5rem}.event-list-status{display:inline-block;padding:.125rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.event-detail{max-width:800px}.event-detail-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}.event-type-badge{padding:.375rem .75rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;color:#fff}.event-status-badge{padding:.375rem .75rem;border-radius:var(--radius);font-size:.875rem;font-weight:500}.event-info{display:grid;gap:1rem;margin-bottom:1.5rem}.event-info-item{display:flex;gap:.75rem;min-width:0}.event-info-icon{color:var(--text-light);flex-shrink:0}.event-info-content{min-width:0;flex:1}.event-info-content p{word-wrap:break-word;overflow-wrap:break-word;white-space:pre-wrap}.event-info-content h4{font-size:.75rem;text-transform:uppercase;color:var(--text-light);margin-bottom:.25rem}.availability-section{margin-top:2rem}.availability-buttons{display:flex;gap:.75rem;margin-bottom:1.5rem}.availability-btn{flex:1;padding:1rem;border:2px solid var(--border);border-radius:var(--radius);background:var(--bg-white);color:var(--text);cursor:pointer;transition:all .2s;font-size:1rem;font-weight:500}.availability-btn:hover{border-color:var(--primary)}.availability-btn.selected{border-color:var(--primary);background:var(--primary);color:#fff}.availability-btn.yes.selected{background:var(--success);border-color:var(--success)}.availability-btn.no.selected{background:var(--danger);border-color:var(--danger)}.availability-btn.maybe.selected{background:var(--warning);border-color:var(--warning)}.availability-stats{display:flex;gap:1.5rem;padding:1rem;background:var(--bg);border-radius:var(--radius);margin-bottom:1.5rem}.stat-item{text-align:center}.stat-value{font-size:1.5rem;font-weight:700}.stat-label{font-size:.75rem;color:var(--text-light);text-transform:uppercase}.stat-item.yes .stat-value{color:var(--success)}.stat-item.no .stat-value{color:var(--danger)}.stat-item.maybe .stat-value{color:var(--warning)}.stat-item.pending .stat-value{color:var(--text-light)}.availability-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.member-availability{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg);border-radius:var(--radius)}.member-avatar{width:36px;height:36px;min-width:36px;min-height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;object-fit:cover;flex-shrink:0}.member-info{flex:1}.member-name{font-weight:500;font-size:.875rem}.member-instrument{font-size:.75rem;color:var(--text-light)}.response-badge{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem}.response-badge.yes{background:var(--success)}.response-badge.no{background:var(--danger)}.response-badge.maybe{background:var(--warning)}.response-badge.pending{background:var(--text-light)}.members-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:1rem}.member-card{display:flex;align-items:center;gap:1rem;padding:1rem}.member-card .member-avatar{width:48px;height:48px;min-width:48px;min-height:48px;font-size:1rem;flex-shrink:0}.member-role{font-size:.75rem;padding:.125rem .5rem;background:var(--bg);border-radius:4px;color:var(--text-light)}.member-role.admin{background:var(--primary);color:#fff}.member-role.invite{background:var(--bg-light);color:var(--text-light);border:1px solid var(--border)}.badge-ca{display:inline-block;font-size:.7rem;padding:.15rem .4rem;border-radius:4px;font-weight:600;background-color:#7c3aed;color:#fff;vertical-align:middle}.notifications-dropdown{position:relative}.notifications-btn{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--bg);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-base);color:var(--text)}.notifications-btn:hover{background:var(--bg-hover);border-color:var(--primary);color:var(--primary)}.notifications-btn:active{transform:scale(.95)}.notifications-btn svg{color:currentColor}[data-theme=dark] .notifications-btn svg{color:currentColor}.notifications-badge{position:absolute;top:0;right:0;min-width:18px;height:18px;background:var(--danger);color:#fff;font-size:.625rem;font-weight:600;border-radius:9px;display:flex;align-items:center;justify-content:center}.notifications-panel{position:absolute;top:100%;right:0;width:320px;max-height:400px;overflow-y:auto;background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:100}.notification-item{padding:1rem;border-bottom:1px solid var(--border);cursor:pointer}.notification-item:hover{background:var(--bg)}.notification-item.unread{background:var(--info-light)}[data-theme=dark] .notification-item.unread{background:#3b82f626}.notification-title{font-weight:500;margin-bottom:.25rem}.notification-message{font-size:.875rem;color:var(--text-light)}.notification-time{font-size:.75rem;color:var(--text-light);margin-top:.25rem}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--bg);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-base);color:var(--text)}.theme-toggle:hover{background:var(--bg-hover);border-color:var(--primary);color:var(--primary);transform:rotate(20deg)}.theme-toggle:active{transform:rotate(20deg) scale(.95)}.user-menu{display:flex;align-items:center;gap:.75rem;padding:1rem;margin-top:auto;border-top:1px solid var(--border)}.user-menu .member-avatar{width:40px;height:40px;min-width:40px;min-height:40px;flex-shrink:0}.user-menu-info{flex:1}.user-menu-name{font-weight:500;font-size:.875rem}.user-menu-email{font-size:.75rem;color:var(--text-light)}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1;white-space:nowrap;transition:all var(--transition-base)}.badge-sm{padding:.125rem .5rem;font-size:.6875rem}.badge-lg{padding:.375rem 1rem;font-size:var(--font-size-sm)}.badge-default{background:var(--bg);color:var(--text)}.badge-primary{background:var(--primary);color:#fff}.badge-success{background:var(--success);color:#fff}.badge-danger{background:var(--danger);color:#fff}.badge-warning{background:var(--warning);color:#fff}.badge-info{background:var(--info);color:#fff}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}.skeleton{animation:skeleton-pulse 2s cubic-bezier(.4,0,.6,1) infinite;background:var(--bg-secondary);border-radius:var(--radius)}.skeleton-line{height:1rem;margin-bottom:.5rem}.skeleton-line.short{width:60%}.skeleton-title{height:1.5rem;width:40%;margin-bottom:.75rem}.skeleton-circle{width:48px;height:48px;border-radius:50%;flex-shrink:0}.skeleton-card{min-height:150px}.skeleton-event{display:flex;gap:1rem;padding:1rem;background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin-bottom:.75rem}.skeleton-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.skeleton-calendar-day{min-height:120px;background:var(--bg-white)}.tooltip-wrapper{position:relative;display:inline-flex}.tooltip{position:absolute;background:var(--text);color:var(--bg-white);padding:.5rem .75rem;border-radius:var(--radius);font-size:var(--font-size-xs);white-space:nowrap;z-index:var(--z-dropdown);pointer-events:none;animation:tooltip-fade-in var(--transition-fast);box-shadow:var(--shadow-lg)}@keyframes tooltip-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tooltip-top{bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip-top:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--text)}.tooltip-bottom{top:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip-bottom:after{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-bottom-color:var(--text)}.tooltip-left{right:calc(100% + 8px);top:50%;transform:translateY(-50%)}.tooltip-left:after{content:"";position:absolute;left:100%;top:50%;transform:translateY(-50%);border:4px solid transparent;border-left-color:var(--text)}.tooltip-right{left:calc(100% + 8px);top:50%;transform:translateY(-50%)}.tooltip-right:after{content:"";position:absolute;right:100%;top:50%;transform:translateY(-50%);border:4px solid transparent;border-right-color:var(--text)}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--text-light)}.alert{padding:1rem;border-radius:var(--radius);margin-bottom:1rem}.alert-error{background:var(--danger-light);color:var(--danger)}[data-theme=dark] .alert-error{background:#ef444433;color:#fca5a5}.alert-success{background:var(--success-light);color:var(--success)}[data-theme=dark] .alert-success{background:#10b98133;color:#6ee7b7}.alert-info{background:var(--info-light);color:var(--info)}[data-theme=dark] .alert-info{background:#3b82f633;color:#93c5fd}.search-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);display:flex;align-items:flex-start;justify-content:center;padding:10vh 1rem 1rem;animation:fade-in var(--transition-fast)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.search-modal{background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:600px;max-height:70vh;display:flex;flex-direction:column;overflow:hidden;animation:slide-up var(--transition-base)}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.search-header{display:flex;align-items:center;gap:.75rem;padding:1rem;border-bottom:1px solid var(--border)}.search-icon{color:var(--text-light);flex-shrink:0}.search-input{flex:1;border:none;background:transparent;font-size:var(--font-size-base);color:var(--text);outline:none}.search-input::placeholder{color:var(--text-lighter)}.search-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-light);cursor:pointer;border-radius:var(--radius);transition:all var(--transition-fast)}.search-close:hover{background:var(--bg);color:var(--text)}.search-results{flex:1;overflow-y:auto;padding:.5rem}.search-loading,.search-empty{padding:2rem;text-align:center;color:var(--text-light)}.search-section{margin-bottom:.5rem}.search-section-title{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-light);text-transform:uppercase}.search-result-item{display:block;width:100%;text-align:left;padding:.75rem;border:none;background:transparent;border-radius:var(--radius);cursor:pointer;transition:background var(--transition-fast)}.search-result-item:hover{background:var(--bg)}.search-result-title{font-weight:var(--font-weight-medium);color:var(--text);margin-bottom:.25rem}.search-result-meta{font-size:var(--font-size-sm);color:var(--text-light)}.search-result-badge{display:inline-block;padding:.125rem .5rem;background:var(--color-primary-light);color:var(--color-primary);border-radius:.25rem;font-size:.75rem;font-weight:500;margin-top:.25rem}.search-footer{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-top:1px solid var(--border);font-size:var(--font-size-xs);color:var(--text-light)}.search-footer kbd{padding:.25rem .5rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-family-mono);font-size:.6875rem}.stats-card{display:flex;gap:1rem;padding:1.5rem;background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:all var(--transition-base);border:1px solid transparent}.stats-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-light);transform:translateY(-2px)}.stats-icon{width:56px;height:56px;min-width:56px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;transition:transform var(--transition-base)}.stats-card:hover .stats-icon{transform:scale(1.1)}.stats-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.stats-label{font-size:var(--font-size-sm);color:var(--text-light);font-weight:var(--font-weight-medium)}.stats-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text);line-height:var(--line-height-tight)}.stats-subtitle{font-size:var(--font-size-xs);color:var(--text-lighter)}.stats-trend{display:flex;align-items:center;gap:.25rem;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);margin-top:.25rem}.stats-trend.positive{color:var(--success)}.stats-trend.negative{color:var(--danger)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1.5rem}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr}.stats-card{padding:1rem}.stats-icon{width:48px;height:48px;min-width:48px}.stats-value{font-size:var(--font-size-xl)}}.text-center{text-align:center}.text-right{text-align:right}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mobile-header{display:none;position:sticky;top:0;left:0;right:0;margin:0;background:var(--bg-white);padding:.75rem 1rem;border-bottom:1px solid var(--border);z-index:200;align-items:center;justify-content:space-between;gap:1rem}.mobile-logo{font-size:1.125rem;font-weight:700;color:var(--primary)}.desktop-notifications{display:flex;justify-content:flex-end;margin-bottom:1rem;position:relative;z-index:10}.navbar-search{position:relative;flex-shrink:0}.navbar-search-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:.5rem;color:var(--color-text-secondary);cursor:pointer;transition:all .2s;min-width:220px}.navbar-search-button:hover{background:var(--color-background-tertiary);border-color:var(--color-primary)}.navbar-search-button:focus{outline:2px solid var(--color-primary);outline-offset:2px}.navbar-search-icon{flex-shrink:0}.navbar-search-placeholder{flex:1;text-align:left;font-size:.875rem}.navbar-search-kbd{padding:.125rem .375rem;background:var(--color-background);border:1px solid var(--color-border);border-radius:.25rem;font-size:.75rem;font-family:monospace;color:var(--color-text-tertiary)}.navbar-search-icon-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;background:transparent;border:none;color:var(--text);cursor:pointer;border-radius:.5rem;transition:all .2s}.navbar-search-icon-btn:hover{background:var(--color-background-secondary)}.burger-btn{display:flex;flex-direction:column;justify-content:center;gap:5px;width:32px;height:32px;background:transparent;border:none;cursor:pointer;padding:4px}.burger-line{width:24px;height:2px;background:var(--text);border-radius:2px;transition:all .3s ease}.burger-line.open:nth-child(1){transform:translateY(7px) rotate(45deg)}.burger-line.open:nth-child(2){opacity:0}.burger-line.open:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999}@media (max-width: 768px){.mobile-header{display:flex;width:100%;margin-left:0;margin-right:0}.desktop-notifications,.navbar-search{display:none}.sidebar-overlay{display:block}.sidebar{transform:translate(-100%);z-index:1000;transition:transform .3s ease;width:280px}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:0!important}.main-content>*:not(.mobile-header){padding:0 1rem}.main-content>.card{margin:0 1rem 1rem;padding:1rem}.page-header{flex-direction:column;align-items:flex-start;gap:1rem;margin-top:24px}.form-row{grid-template-columns:1fr}.calendar-header{flex-direction:column;align-items:stretch;gap:1rem}.calendar-nav{gap:.375rem}.calendar-nav-center{width:100%;justify-content:center;order:1}.calendar-nav-today{order:2}.calendar-views{order:3;margin-left:auto;justify-content:flex-end}.calendar-title{font-size:.9rem;min-width:90px;font-weight:600}.calendar-day{min-height:60px;padding:.25rem}.calendar-day-header{padding:.5rem .25rem;font-size:.625rem}.calendar-day-number{font-size:.75rem}.event-item{font-size:.625rem;padding:.125rem .25rem}.calendar-grid-mobile{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:.5rem}.calendar-day-header-mobile{text-align:center;font-size:.7rem;font-weight:600;color:var(--text-light);padding:.25rem 0;text-transform:uppercase}.calendar-day-mobile{display:flex;flex-direction:column;align-items:center;padding:.35rem .1rem;border-radius:6px;cursor:pointer;min-height:44px;transition:background .15s;gap:2px}.calendar-day-mobile.other-month .calendar-day-number-mobile{opacity:.3}.calendar-day-mobile.today .calendar-day-number-mobile{background:var(--primary);color:#fff;border-radius:50%;width:26px;height:26px;display:flex;align-items:center;justify-content:center}.calendar-day-mobile.selected{background:var(--bg);outline:2px solid var(--primary);outline-offset:-2px}.calendar-day-number-mobile{font-size:.875rem;font-weight:500;width:26px;height:26px;display:flex;align-items:center;justify-content:center}.calendar-day-dots{display:flex;gap:2px;justify-content:center;flex-wrap:wrap}.cal-dot{width:5px;height:5px;border-radius:50%;display:inline-block;flex-shrink:0}.cal-dot-atelier{background:var(--event-atelier, #10B981)}.cal-dot-repetition{background:var(--event-repetition, #84CC16)}.cal-dot-concert{background:var(--event-concert, #f59e0b)}.cal-dot-reunion{background:var(--event-reunion, #10b981)}.cal-dot-stage{background:var(--event-stage, #ec4899)}.cal-dot-salon{background:var(--event-salon, #8b5cf6)}.cal-dot-fete{background:var(--event-fete, #ef4444)}.cal-dot-maintenance{background:var(--event-maintenance, #6b7280)}.mobile-month-day-panel{border-top:1px solid var(--border);padding:.75rem;margin-top:.25rem}.mobile-month-day-title{font-size:.875rem;font-weight:600;text-transform:capitalize;margin-bottom:.5rem;color:var(--text)}.mobile-week-view{display:flex;flex-direction:column;gap:.5rem;padding:.75rem}.mobile-week-day{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.mobile-week-day.today .mobile-week-day-header{background:var(--primary);color:#fff}.mobile-week-day-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--bg);font-size:.875rem}.mobile-week-day-name{font-weight:600;text-transform:capitalize}.mobile-week-day-date{font-size:.75rem;opacity:.75}.mobile-week-day .event-item{margin:.25rem .5rem;border-radius:calc(var(--radius) / 2)}.mobile-week-empty{padding:.5rem .75rem;font-size:.75rem;color:var(--text-light);margin:0}.calendar-nav-arrow{padding:.5rem .75rem!important;display:flex;align-items:center;justify-content:center}.event-list-item{flex-direction:column;gap:.75rem}.event-list-date{display:flex;align-items:center;gap:.5rem;min-width:auto;padding:.5rem .75rem}.event-list-date-day{font-size:1.25rem}.members-grid{grid-template-columns:1fr}.member-card{flex-wrap:wrap}.member-card>div:last-child{width:100%;flex-direction:row!important;flex-wrap:wrap;margin-top:.5rem;padding-left:0!important}.member-card>div:last-child>*{flex:1;min-width:calc(50% - .125rem)}.availability-buttons{flex-direction:column}.availability-stats{flex-wrap:wrap;justify-content:center}.availability-list{grid-template-columns:1fr}.event-detail-header{flex-direction:column}.notifications-panel{position:fixed;top:60px;right:.5rem;left:.5rem;width:auto;max-height:calc(100vh - 80px)}.btn-group{flex-direction:column}.btn-group .btn{width:100%;justify-content:center}.modal-content{padding:1.5rem;margin:.5rem;max-height:calc(100vh - 2rem)}}@media (max-width: 400px){.calendar-day{min-height:50px}.calendar-day-header{font-size:.5rem}.event-item{display:none}.calendar-day:has(.event-item):after{content:"";display:block;width:6px;height:6px;background:var(--primary);border-radius:50%;margin:.25rem auto 0}.auth-card{padding:1.5rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content,.modal{background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:2rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.recap-table{width:100%;border-collapse:collapse;font-size:.875rem}.recap-table th,.recap-table td{padding:.5rem;text-align:center;border:1px solid var(--border);white-space:nowrap}.recap-table th{background:var(--bg);font-weight:600}.recap-table .sticky-col{position:sticky;left:0;background:var(--bg-white);z-index:10;text-align:left;min-width:120px}.recap-table thead .sticky-col{background:var(--bg);z-index:30}.recap-table thead th{position:sticky;top:0;background:var(--bg);z-index:20}.recap-table .event-col{min-width:80px;max-width:100px}.recap-table .event-col-improved{min-width:140px;max-width:180px;vertical-align:top;padding:.5rem!important}.event-header-improved{display:flex;gap:.5rem;text-align:left}.event-header-date{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-white);border-radius:var(--radius);padding:.25rem .5rem;min-width:36px}.event-header-date .event-day{font-size:1.125rem;font-weight:700;line-height:1.2;color:var(--text)}.event-header-date .event-month{font-size:.625rem;text-transform:uppercase;color:var(--text-light);font-weight:500}.event-header-info{display:flex;flex-direction:column;gap:.125rem;flex:1;min-width:0}.event-header-badges{display:flex;gap:.25rem;align-items:center}.event-type-mini{font-size:.625rem;padding:.125rem .25rem;border-radius:3px;color:#fff;font-weight:600;text-transform:uppercase}.event-status-mini{font-size:.625rem;padding:0 .25rem;border:1.5px solid;border-radius:3px;background:transparent;font-weight:600;line-height:1.4}.event-title-full{font-size:.75rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.event-time{font-size:.6875rem;color:var(--text-light)}.recap-table .event-header{display:flex;flex-direction:column;gap:.25rem}.recap-table .event-date{font-size:.75rem;color:var(--text-light)}.recap-table .event-title{font-size:.75rem;overflow:hidden;text-overflow:ellipsis;max-width:80px}.recap-table .member-cell{padding:.5rem .75rem}.recap-table .member-name-small{font-weight:500}.recap-table .member-instrument-small{font-size:.75rem;color:var(--text-light)}.recap-table .response-cell{padding:.25rem}.response-dot{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;color:#fff;font-size:.75rem;font-weight:600}.response-dot.clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.response-dot.clickable:hover{transform:scale(1.15);box-shadow:0 2px 8px #0003}.response-cell-wrapper{position:relative;display:inline-block}.response-dropdown{position:absolute;top:100%;left:50%;transform:translate(-50%);background:var(--bg-white);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--border);z-index:100;min-width:120px;margin-top:4px;overflow:hidden}.response-option{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;border:none;background:none;cursor:pointer;font-size:.8125rem;text-align:left;border-left:3px solid transparent;transition:background .15s;color:var(--text)}.response-option:hover{background:var(--bg)}.response-option.active{background:var(--bg);font-weight:600}.response-option:disabled{opacity:.6;cursor:not-allowed}.response-option-icon{font-weight:700;font-size:.875rem}.recap-table .stats-cell{font-size:.75rem;font-weight:500}.recap-table .stats-col{min-width:80px}.recap-table tfoot td{background:var(--bg);font-weight:600}.recap-table tfoot .sticky-col{background:var(--bg)}@media (max-width: 768px){.recap-table{font-size:.75rem}.recap-table th,.recap-table td{padding:.375rem}.recap-table .sticky-col{min-width:100px}.response-dot{width:24px;height:24px;font-size:.625rem}}.members-table{width:100%;border-collapse:collapse;font-size:.875rem}.members-table th,.members-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border)}.members-table th{background:var(--bg);font-weight:600;white-space:nowrap}.members-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.members-table th.sortable:hover{background:var(--border)}.members-table tbody tr:hover{background:var(--bg)}.members-table tbody tr:last-child td{border-bottom:none}@media (max-width: 768px){.members-table{font-size:.75rem}.members-table th,.members-table td{padding:.5rem}.members-table th:nth-child(3),.members-table td:nth-child(3),.members-table th:nth-child(4),.members-table td:nth-child(4){display:none}}.suivi-list{display:flex;flex-direction:column}.suivi-item{display:flex;align-items:center;gap:1rem;padding:1rem;border-bottom:1px solid var(--border);transition:background .15s}.suivi-item:last-child{border-bottom:none}.suivi-item:hover{background:var(--bg)}.suivi-item.unread{background:var(--info-light)}[data-theme=dark] .suivi-item.unread{background:#3b82f626}.suivi-item.unread:hover{background:var(--info-light)}[data-theme=dark] .suivi-item.unread:hover{background:#3b82f640}.suivi-event{min-width:200px;max-width:250px}.suivi-event-link{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:inherit}.suivi-event-link:hover .suivi-event-title{color:var(--primary)}.suivi-event-title{font-weight:500;font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.suivi-event-date{font-size:.75rem;color:var(--text-light);white-space:nowrap}.suivi-content{flex:1;display:flex;align-items:center;gap:1rem}.suivi-member{display:flex;align-items:center;gap:.5rem;min-width:140px}.suivi-member-name{font-weight:500;font-size:.875rem}.suivi-action{font-size:.875rem;color:var(--text-light)}.suivi-response{font-weight:600}.suivi-changed-by{font-size:.75rem;font-style:italic}.suivi-time{font-size:.75rem;color:var(--text-light);white-space:nowrap}@media (max-width: 768px){.suivi-item{flex-direction:column;align-items:flex-start;gap:.5rem}.suivi-event{min-width:auto;max-width:none;width:100%}.suivi-content{flex-direction:column;align-items:flex-start;gap:.25rem}.suivi-time{align-self:flex-end;margin-top:.25rem}}.pedagogie-loading{padding:2rem;text-align:center}.pedagogie-error{padding:2rem;text-align:center;color:var(--text-secondary)}.pedagogie-page{width:100%;position:relative;margin:0 -2rem -2rem;padding:2rem}.pedagogie-page.has-cover{padding-top:2rem}.pedagogie-cover-img{width:100%;height:100%;object-fit:cover;object-position:center}.pedagogie-cover-overlay{position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(to top,rgba(0,0,0,.6),transparent)}.pedagogie-content-wrapper{max-width:900px;margin-left:auto;margin-right:auto;width:100%;box-sizing:border-box;position:relative;z-index:1}.pedagogie-content-container{max-width:100%;width:100%;box-sizing:border-box}.pedagogie-page .page-header{position:relative;z-index:2}.pedagogie-back-btn{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:0;font-size:.875rem;padding:.5rem 1rem}.pedagogie-back-text{display:inline-block}.pedagogie-meta{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;padding-bottom:2rem;margin-bottom:0;border-bottom:1px solid var(--border)}.pedagogie-meta-badge{font-size:.8125rem;padding:.375rem .875rem}.pedagogie-meta-dates{display:flex;flex-wrap:wrap;gap:1rem;font-size:.8125rem;color:var(--text-light);flex:1}.pedagogie-meta-creator{margin-left:.25rem}.pedagogie-edit-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;margin-left:auto}.pedagogie-excerpt{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-bottom:2rem;display:flex;align-items:flex-start;gap:.75rem}.pedagogie-excerpt-icon{color:var(--primary);flex-shrink:0;margin-top:.125rem}.pedagogie-excerpt-text{flex:1;font-size:.875rem;color:var(--text);line-height:1.5}.pedagogie-content{font-size:1.0625rem;line-height:1.8;color:var(--text);word-break:break-word;overflow-wrap:break-word;max-width:100%}.pedagogie-list-container{max-width:1200px;margin:0 auto}.pedagogie-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.pedagogie-list-title{margin:0;font-size:clamp(1.5rem,5vw,2rem)}.pedagogie-list-actions{display:flex;gap:1rem;align-items:center}.pedagogie-add-btn{display:flex;align-items:center;gap:.5rem}.pedagogie-accueil-intro{color:var(--text-muted);margin-bottom:1.5rem;max-width:680px;line-height:1.6}.pedagogie-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.pedagogie-empty p{margin:0}.pedagogie-empty-hint{font-size:.9rem;margin-top:.5rem}.pedagogie-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.pedagogie-card-item{cursor:pointer;background:var(--bg-white);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);transition:all .2s ease;height:100%;display:flex;flex-direction:column;box-shadow:var(--shadow-xs)}.pedagogie-card-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--border-dark)}.pedagogie-card-cover{width:100%;padding-bottom:56.25%;position:relative;overflow:hidden;background:var(--bg-secondary)}.pedagogie-card-cover-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center}.pedagogie-card-placeholder{width:100%;padding-bottom:56.25%;position:relative;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--border) 100%);display:flex;align-items:center;justify-content:center}.pedagogie-card-placeholder-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:3rem;opacity:.3}.pedagogie-card-content{padding:1.25rem;flex:1;display:flex;flex-direction:column;gap:.75rem}.pedagogie-card-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;min-height:2.8rem}.pedagogie-card-excerpt{margin:0;font-size:.875rem;color:var(--text-secondary);line-height:1.6;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.pedagogie-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:.75rem;border-top:1px solid var(--border-light);gap:.5rem}.pedagogie-card-status{flex-shrink:0}.pedagogie-card-date{font-size:.75rem;color:var(--text-lighter);flex-shrink:0;font-weight:500}.pedagogie-table-wrapper{background:var(--bg-white);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-xs)}.pedagogie-table-scroll{overflow-x:auto}.pedagogie-table{width:100%;border-collapse:collapse;font-size:.875rem}.pedagogie-table-header{padding:1rem;text-align:left;font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.pedagogie-table-header-content{display:flex;align-items:center;gap:.5rem}.pedagogie-table-row{cursor:pointer;transition:background .15s ease;border-bottom:1px solid var(--border-light)}.pedagogie-table-row:nth-child(2n){background:var(--bg-secondary)}.pedagogie-table-row:hover{background:var(--primary-light)}.pedagogie-table-cell{padding:1rem}.pedagogie-table-cell-title{font-weight:500;color:var(--text)}.pedagogie-table-cell-status{width:150px}.pedagogie-table-cell-date{width:150px;color:var(--text-secondary);font-size:.8125rem}.pedagogie-content h1{font-size:1.875rem;font-weight:700;margin:2.5rem 0 1rem;color:var(--text);letter-spacing:-.02em}.pedagogie-content h2{font-size:1.5rem;font-weight:700;margin:2rem 0 .75rem;color:var(--text);letter-spacing:-.01em}.pedagogie-content h3{font-size:1.25rem;font-weight:600;margin:1.5rem 0 .5rem;color:var(--text)}.pedagogie-content h4{font-size:1.125rem;font-weight:600;margin:1.25rem 0 .5rem;color:var(--text)}.pedagogie-content p{margin:.75rem 0;line-height:1.75}.pedagogie-content ul,.pedagogie-content ol{margin:.75rem 0;padding-left:1.75rem}.pedagogie-content li{margin:.375rem 0;line-height:1.65}.pedagogie-content li::marker{color:var(--text-light)}.pedagogie-content ul>li{padding-left:.25rem}.pedagogie-content ol{counter-reset:item;list-style:none;padding-left:0}.pedagogie-content ol>li{counter-increment:item;position:relative;padding-left:2rem}.pedagogie-content ol>li:before{content:counter(item) ".";position:absolute;left:0;font-weight:600;color:var(--text-light);min-width:1.5rem}.pedagogie-content,.pedagogie-content *,.pedagogie-content p,.pedagogie-content div,.pedagogie-content span,.pedagogie-content li,.pedagogie-content strong,.pedagogie-content em{word-break:break-word!important;overflow-wrap:anywhere!important;word-wrap:break-word!important;max-width:100%!important}.pedagogie-content .description{word-break:break-word!important;overflow-wrap:break-word!important;max-width:100%!important;overflow-x:hidden!important;white-space:normal!important}.pedagogie-content a{color:var(--primary);text-decoration:none;transition:opacity .15s ease;word-break:break-word!important;overflow-wrap:break-word!important;-webkit-hyphens:auto;hyphens:auto;display:inline;max-width:100%}.pedagogie-content a:hover{opacity:.7}.pedagogie-content pre{background:#f8f9fa;padding:1.5rem;border-radius:var(--radius);overflow-x:auto;font-family:var(--font-family-mono);font-size:.875rem;line-height:1.4;letter-spacing:0;margin:1.5rem 0;border:2px solid #dee2e6;border-left:4px solid var(--primary);white-space:pre;word-wrap:normal;word-break:normal;scrollbar-width:thin;scrollbar-color:var(--border-dark) transparent}.pedagogie-content pre::-webkit-scrollbar{height:8px}.pedagogie-content pre::-webkit-scrollbar-track{background:transparent}.pedagogie-content pre::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:4px}.pedagogie-content pre::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.pedagogie-content code{background:var(--bg-secondary);padding:.2em .4em;border-radius:3px;font-family:var(--font-family-mono);font-size:.875em;color:#eb5757;border:1px solid var(--border-light)}.pedagogie-content pre code{background:none;padding:0;border:none;color:var(--text)}.pedagogie-content .music-notation,.pedagogie-content pre.music-notation{background:#f8f9fa;border:2px solid #dee2e6;border-left:4px solid var(--primary);padding:1.5rem;margin:1.5rem 0;overflow-x:auto;font-family:var(--font-family-mono);font-size:.875rem;line-height:1.4;letter-spacing:0;white-space:pre;word-wrap:normal;word-break:normal;color:#212529;-moz-tab-size:4;tab-size:4;scrollbar-width:thin;scrollbar-color:var(--border-dark) transparent}.pedagogie-content .music-notation::-webkit-scrollbar{height:8px}.pedagogie-content .music-notation::-webkit-scrollbar-track{background:transparent}.pedagogie-content .music-notation::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:4px}.pedagogie-content .music-notation::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.pedagogie-content .music-notation p{margin:0;padding:0;font-family:inherit;font-size:inherit;line-height:inherit;white-space:pre}@media (max-width: 768px){.pedagogie-content .music-notation,.pedagogie-content pre.music-notation{font-size:.75rem;padding:1rem;overflow-x:scroll;-webkit-overflow-scrolling:touch}.pedagogie-page{margin:0;padding:0}.pedagogie-cover-global.desktop-only{display:none}.pedagogie-cover-global.mobile-only{display:block;position:relative;left:0;right:0;pointer-events:auto}.main-content.has-pedagogie-cover{padding-top:0}.pedagogie-page:not(.has-cover) .pedagogie-content-wrapper,.pedagogie-page:not(.has-cover) .pedagogie-list-container{padding:1.5rem 0}.pedagogie-list-container,.pedagogie-cards-grid,.pedagogie-content-wrapper{padding-left:0;padding-right:0}}@media (max-width: 480px){.pedagogie-content .music-notation,.pedagogie-content pre.music-notation{font-size:.7rem;padding:.75rem;border-left-width:3px}}.pedagogie-content .media-container{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin:1.5rem 0;box-shadow:var(--shadow-sm)}.pedagogie-content .media-container video,.pedagogie-content .media-container audio{width:100%;max-width:100%;border-radius:var(--radius);background:#000}.pedagogie-content .media-container audio{height:54px}.pedagogie-content .media-caption{margin-top:.75rem;font-size:var(--font-size-sm);color:var(--text-light);font-style:italic;text-align:center}.pedagogie-content .video-embed{position:relative;width:100%;max-width:100%;padding-bottom:56.25%;height:0;overflow:hidden;margin:1.5rem 0;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);box-sizing:border-box}.pedagogie-content .video-embed iframe{position:absolute!important;top:0!important;left:0!important;width:100%!important;height:100%!important;border:none;border-radius:var(--radius-lg)}.pedagogie-content .spotify-embed{margin:1.5rem 0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}.pedagogie-content .spotify-embed iframe{width:100%;border:none}.pedagogie-content img{max-width:100%;height:auto;border-radius:var(--radius-md);margin:2rem 0;box-shadow:#0f0f0f1a 0 0 0 1px,#0f0f0f1a 0 2px 4px;transition:transform .2s ease}.pedagogie-content img:hover{transform:scale(1.01)}.pedagogie-content video{width:fit-content;max-width:100%;height:auto;max-height:85vh;border-radius:var(--radius-md);margin:2rem 0;box-shadow:#0f0f0f1a 0 0 0 1px,#0f0f0f1a 0 2px 4px;display:block}.video-container{margin:1.5rem 0}.video-portrait{max-width:400px;margin:1.5rem auto}.video-landscape{max-width:100%;margin:1.5rem 0}.video-portrait video{width:100%;height:auto;max-height:85vh;max-width:100%;aspect-ratio:9 / 16;object-fit:contain;border-radius:var(--radius-md);box-shadow:#0f0f0f1a 0 0 0 1px,#0f0f0f1a 0 2px 4px}.video-landscape video{width:100%;height:auto;max-height:85vh;max-width:100%;aspect-ratio:16 / 9;object-fit:contain;border-radius:var(--radius-md);box-shadow:#0f0f0f1a 0 0 0 1px,#0f0f0f1a 0 2px 4px}.pedagogie-content audio{width:100%;max-width:500px;border-radius:var(--radius-md);margin:2rem 0;box-shadow:#0f0f0f1a 0 0 0 1px,#0f0f0f1a 0 2px 4px;display:block}@media (max-width: 768px){.pedagogie-content .media-container{padding:1rem}.pedagogie-content .video-embed{margin:1rem 0}}.pedagogie-content blockquote{background:var(--bg);border-left:3px solid var(--primary);padding:1rem 1.25rem;margin:1.5rem 0;border-radius:var(--radius);font-style:normal;color:var(--text)}.pedagogie-content blockquote p{margin:0}.pedagogie-content table{width:100%;border-collapse:collapse;margin:2rem 0;font-size:.9375rem}.pedagogie-content table th,.pedagogie-content table td{border:1px solid var(--border);padding:.75rem 1rem;text-align:left}.pedagogie-content table th{background:var(--bg);font-weight:600;color:var(--text);font-size:.875rem;text-transform:none}.pedagogie-content table tbody tr:hover{background:var(--bg-hover)}.pedagogie-content hr{border:none;border-top:1px solid var(--border);margin:2.5rem 0}.pedagogie-content audio,.pedagogie-content video{margin:1.5rem 0;border-radius:var(--radius)}.pedagogie-content iframe{max-width:100%;border-radius:var(--radius-md);margin:2rem 0;border:none;box-shadow:var(--shadow-sm)}.pedagogie-content strong{font-weight:600}.pedagogie-content em{font-style:italic;color:var(--text-secondary)}.pedagogie-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1rem;transition:box-shadow .2s}.pedagogie-card:hover{box-shadow:var(--shadow-md)}.pedagogie-card h3{margin-top:0}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:999px;font-size:.875rem;font-weight:500}.status-badge.en-cours{background:#3b82f61a;color:#3b82f6}.status-badge.termine{background:#10b9811a;color:#10b981}.loading-spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.pedagogie-sidebar{width:100%!important;height:auto!important;position:relative!important;top:0!important;border-right:none!important;border-bottom:1px solid var(--border)}.content-metadata{flex-direction:column!important;gap:.75rem!important;font-size:.8rem!important}@media (max-width: 480px){.edit-btn-text{display:none}.edit-btn-responsive{padding:.5rem!important}}.pedagogie-admin-header{flex-direction:column!important;align-items:stretch!important;gap:1rem!important}.pedagogie-admin-header h1{font-size:1.5rem!important}.pedagogie-admin-header .button-group{flex-direction:column!important}.pedagogie-admin-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.pedagogie-admin-table{min-width:600px}@media (max-width: 480px){.pedagogie-admin-table thead{display:none}.pedagogie-admin-table,.pedagogie-admin-table tbody,.pedagogie-admin-table tr,.pedagogie-admin-table td{display:block;width:100%}.pedagogie-admin-table tr{margin-bottom:1rem;border:1px solid var(--border);border-radius:var(--radius);padding:1rem;background:var(--bg-white)}.pedagogie-admin-table td{padding:.5rem 0!important;border:none!important;text-align:left!important;position:relative;padding-left:50%!important}.pedagogie-admin-table td:before{content:attr(data-label);position:absolute;left:0;width:45%;padding-right:10px;font-weight:600;color:var(--text)}.pedagogie-admin-table td:last-child{padding-left:0!important}}}@media (max-width: 1024px) and (min-width: 769px){.pedagogie-sidebar{width:240px!important}}@media (max-width: 768px){body,#root{max-width:100vw!important}.app-layout{display:block!important}.pedagogie-sidebar{display:block!important;width:100%!important;height:auto!important;position:relative!important;top:0!important;border-right:none!important;border-bottom:1px solid var(--border);margin-bottom:.5rem;padding:.5rem!important}.pedagogie-sidebar>div{padding:.5rem!important}.pedagogie-content-wrapper,.pedagogie-content{max-width:100%}.pedagogie-content h1{font-size:clamp(1.25rem,5vw,1.75rem);margin-top:1rem}.pedagogie-content h2{font-size:1.25rem}.pedagogie-content h3{font-size:1.1rem}.pedagogie-content img{max-width:100%;height:auto}.pedagogie-content audio{width:100%;max-width:100%}.pedagogie-content .video-embed{width:100%;max-width:100%}.pedagogie-cards-grid{grid-template-columns:1fr;gap:1rem}.pedagogie-card-item{max-width:100%}}@media (min-width: 769px) and (max-width: 1024px){.pedagogie-cards-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))!important}}@media (max-width: 480px){.pedagogie-cards-grid{padding:0}.pedagogie-card-item h3{font-size:1rem!important}.pedagogie-card-item p{font-size:.8125rem!important}}.password-change-badge{display:inline-block;margin-left:.5rem;padding:.125rem .5rem;background:var(--color-warning-light, #fff3cd);color:var(--color-warning, #856404);border:1px solid var(--color-warning, #ffc107);border-radius:.25rem;font-size:.75rem;font-weight:500;cursor:help}.password-change-badge-modal{display:inline-block;margin-left:.5rem;padding:.25rem .75rem;background:var(--color-warning-light, #fff3cd);color:var(--color-warning, #856404);border:1px solid var(--color-warning, #ffc107);border-radius:.375rem;font-size:.875rem;font-weight:500}.action-button-warning{background:var(--color-warning, #ffc107);color:#000;border:1px solid var(--color-warning, #ffc107)}.action-button-warning:hover:not(:disabled){background:#e0a800;border-color:#d39e00}.action-button-warning:disabled{opacity:.5;cursor:not-allowed}
