@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:1rem;animation:fadeIn .3s ease}.loading-state p{margin:0;color:var(--color-text-muted);font-size:.95rem}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner--small{width:20px;height:20px;border-width:2px}.loading-spinner--large{width:60px;height:60px;border-width:4px}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:1rem;text-align:center;animation:fadeIn .3s ease}.error-state p{margin:0;color:var(--color-error);font-size:.95rem;max-width:400px}.error-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:var(--color-error-bg);border-radius:50%;color:var(--color-error);font-size:1.75rem;animation:shake .5s ease}.error-icon svg{width:28px;height:28px}.btn-retry{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--color-error);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn-retry:hover{background:#dc2626;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-retry:active{transform:translateY(0)}.btn-retry:focus-visible{outline:none;box-shadow:0 0 0 3px #ef44444d}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem;text-align:center;animation:fadeIn .3s ease}.empty-state h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text)}.empty-state p{margin:0;color:var(--color-text-muted);font-size:.95rem;max-width:350px}.empty-icon{width:72px;height:72px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-border) 0%,transparent 100%);border-radius:50%;color:var(--color-text-muted);font-size:2rem;margin-bottom:.5rem}.empty-icon svg{width:36px;height:36px;opacity:.6}.animate-spin{animation:spin 1s linear infinite}.animate-fade-in{animation:fadeIn .3s ease}.animate-slide-in{animation:slideIn .3s ease}.animate-pulse{animation:pulse 2s ease-in-out infinite}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.page-container{max-width:1400px;margin:0 auto}.header-content{flex:1}.page-actions{display:flex;margin-bottom:1.5rem}.btn-create{padding:.75rem 1.5rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:background-color .2s ease;white-space:nowrap}.btn-create:hover{background-color:var(--color-primary-hover)}.btn-create:focus{outline:2px solid var(--color-primary-light);outline-offset:2px}.page-grid,.sessions-grid,.instructors-grid,.dance-styles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}@media(max-width:768px){.btn-create{width:100%;text-align:center}.page-grid,.sessions-grid,.instructors-grid,.dance-styles-grid{grid-template-columns:1fr}}@media(max-width:640px){.page-actions{flex-direction:column}}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast{position:fixed;top:1.5rem;right:1.5rem;display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-weight:500;font-size:.875rem;z-index:1100;animation:slideInRight .3s ease-out;max-width:400px}.toast-success{background-color:var(--color-success);color:#fff}.toast-error{background-color:var(--color-error);color:#fff}.toast-warning{background-color:var(--color-warning);color:#fff}.toast-close{display:flex;align-items:center;justify-content:center;background:none;border:none;color:#fff;cursor:pointer;padding:.25rem;margin-left:.25rem;opacity:.8;transition:opacity .2s ease,transform .2s ease;border-radius:var(--radius-sm)}.toast-close:hover{opacity:1;background-color:#ffffff1a}.success-toast{position:fixed;top:1.5rem;right:1.5rem;bottom:auto;left:auto;width:auto;height:auto;display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;max-height:80px;background-color:var(--color-success);color:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-weight:500;font-size:.9rem;z-index:1100;animation:slideInRight .3s ease-out}.success-icon{font-size:1.25rem}.error-toast{position:fixed;top:1.5rem;right:1.5rem;display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background-color:var(--color-error);color:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-weight:500;z-index:1100;animation:slideInRight .3s ease-out}.error-toast-icon{font-size:1.25rem}.error-toast-close{background:none;border:none;color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;margin-left:.5rem;opacity:.8;transition:opacity .2s ease}.error-toast-close:hover{opacity:1}@media(max-width:640px){.toast{top:auto;bottom:1.5rem;left:1rem;right:1rem;max-width:none}.success-toast,.error-toast{top:auto;bottom:1.5rem;left:1.5rem;right:1.5rem}}*,*:before,*:after{box-sizing:border-box}:root{--sidebar-width: 220px;--color-primary: #e11d48;--color-primary-hover: #be123c;--color-primary-light: #fb7185;--color-success: #10b981;--color-success-bg: rgba(16, 185, 129, .1);--color-error: #ef4444;--color-error-bg: rgba(239, 68, 68, .1);--color-warning: #f59e0b;--color-warning-bg: rgba(245, 158, 11, .1);--color-info: #3b82f6;--color-info-bg: rgba(59, 130, 246, .1);--color-text: #1f2937;--color-text-muted: #6b7280;--color-bg: #fafafa;--color-card: #ffffff;--color-border: #e5e7eb;--color-input-bg: #ffffff;--color-sidebar-bg: #1a1a2e;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-focus: 0 0 0 3px rgba(225, 29, 72, .12);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;font-family:Outfit,Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media(prefers-color-scheme:dark){:root{--color-text: #f9fafb;--color-text-muted: #9ca3af;--color-bg: #0f0f0f;--color-card: #1a1a1a;--color-border: #2d2d2d;--color-input-bg: #262626;--color-sidebar-bg: #0a0a14;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -4px rgba(0, 0, 0, .4);--shadow-focus: 0 0 0 3px rgba(251, 113, 133, .2)}}body{margin:0;padding:0;min-height:100vh;background-color:var(--color-bg);color:var(--color-text)}#root{min-height:100vh}.app-container{min-height:100vh;display:flex;flex-direction:column}.app-header{padding:2rem;text-align:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff}.app-header h1{margin:0;font-size:2.5rem;font-weight:700;letter-spacing:-.02em}.app-subtitle{margin:.5rem 0 0;font-size:1.1rem;opacity:.9}.app-main{flex:1;padding:2rem;max-width:800px;margin:0 auto;width:100%}.status-card{padding:2rem;background-color:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border);text-align:center;margin-bottom:2rem}.status-icon{font-size:3rem;margin-bottom:1rem}.status-card h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:var(--color-success)}.status-card p{margin:0;color:var(--color-text-muted)}.info-section{padding:1.5rem;background-color:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.info-section h3{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:var(--color-primary)}.entity-list{margin:0;padding:0;list-style:none}.entity-list li{padding:.75rem 0;border-bottom:1px solid var(--color-border);color:var(--color-text);font-size:.95rem}.entity-list li:last-child{border-bottom:none}@media(max-width:640px){.app-header{padding:1.5rem 1rem}.app-header h1{font-size:1.75rem}.app-main,.status-card,.info-section{padding:1rem}}.sidebar{width:var(--sidebar-width, 220px);min-height:100vh;background-color:var(--color-sidebar-bg, #1a1a2e);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100}.sidebar-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-title{margin:0;font-size:1.25rem;font-weight:700;color:#fff;letter-spacing:-.02em}.sidebar-subtitle{margin:.25rem 0 0;font-size:.75rem;color:#fff9}.sidebar-nav{flex:1;padding:1rem 0;display:flex;flex-direction:column;gap:.25rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:#ffffffb3;text-decoration:none;font-size:.9rem;font-weight:500;transition:all .2s ease;border-left:3px solid transparent}.nav-item:hover{background-color:#ffffff0d;color:#fff}.nav-item.active{background-color:#e11d4826;color:var(--color-primary);border-left-color:var(--color-primary)}.nav-icon{font-size:1.1rem;width:1.5rem;text-align:center}.nav-label{flex:1}.nav-group{display:flex;flex-direction:column}.nav-item-expandable{background:none;border:none;width:100%;text-align:left;cursor:pointer;font-family:inherit}.nav-chevron{font-size:.6rem;transition:transform .2s ease;opacity:.6}.nav-chevron.expanded{transform:rotate(180deg)}.nav-submenu{display:flex;flex-direction:column;background-color:#00000026}.nav-item-child{padding-left:2.75rem;font-size:.85rem}.nav-item-child .nav-icon{font-size:.9rem}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.version{margin:0;font-size:.7rem;color:#fff6}@media(max-width:768px){.sidebar{width:100%;height:auto;min-height:auto;position:relative;flex-direction:row;align-items:center;padding:.5rem 1rem}.sidebar-header{padding:0;border-bottom:none;flex-shrink:0}.sidebar-title{font-size:1rem}.sidebar-subtitle{display:none}.sidebar-nav{flex-direction:row;padding:0;gap:0;overflow-x:auto;flex:1;justify-content:flex-end}.nav-item{padding:.5rem .75rem;border-left:none;border-bottom:2px solid transparent;flex-direction:column;gap:.25rem}.nav-item.active{border-left-color:transparent;border-bottom-color:var(--color-primary)}.nav-label{font-size:.65rem}.nav-icon{font-size:1rem}.sidebar-footer{display:none}}.main-layout{display:flex;min-height:100vh;background-color:var(--color-bg)}.content-area{flex:1;margin-left:var(--sidebar-width, 220px);width:calc(100% - var(--sidebar-width, 220px));padding:2rem;overflow-y:auto;overflow-x:hidden;min-height:100vh;box-sizing:border-box}@media(max-width:768px){.main-layout{flex-direction:column}.content-area{margin-left:0;width:100%;padding:1rem;min-height:calc(100vh - 60px)}}.session-card{background-color:var(--color-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:1.5rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem;transition:box-shadow .2s ease,transform .2s ease}.session-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.session-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.session-name{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text);line-height:1.3}.badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;white-space:nowrap}.badge.preparation{background-color:#fbbf2426;color:#d97706}.badge.active{background-color:var(--color-success-bg);color:var(--color-success)}.badge.completed{background-color:#6b728026;color:#6b7280}.session-dates{display:flex;flex-direction:column;gap:.5rem}.date-item{display:flex;gap:.5rem;font-size:.875rem}.date-label{color:var(--color-text-muted);min-width:3rem}.date-value{color:var(--color-text);font-weight:500}.session-info{display:flex;flex-direction:column;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border)}.info-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.info-icon{font-size:1rem}.info-text{color:var(--color-text-muted)}.schedule-published{color:var(--color-success)}.schedule-draft{color:var(--color-warning, #f59e0b)}.session-actions{margin-top:auto}.session-actions--split{display:flex;gap:.75rem}.btn-view{width:100%;padding:.75rem 1rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.btn-view:hover{background-color:var(--color-primary-hover)}.btn-view:focus{outline:2px solid var(--color-primary-light);outline-offset:2px}.session-actions--split .btn-view,.session-actions--split .btn-delete{width:auto;flex:1}.btn-delete{padding:.75rem 1rem;background-color:var(--color-error-bg);color:var(--color-error);border:1px solid transparent;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-delete:focus{outline:2px solid var(--color-error);outline-offset:2px}@media(prefers-color-scheme:dark){.badge.preparation{background-color:#fbbf2433;color:#fbbf24}.badge.completed{background-color:#9ca3af33;color:#9ca3af}}@media(max-width:640px){.session-actions--split{flex-direction:column}}.dashboard{max-width:1400px;margin:0 auto}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.dashboard-title{margin:0;font-size:2rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.dashboard-subtitle{margin:.5rem 0 0;color:var(--color-text-muted);font-size:1rem}.section-title{margin:0 0 1.5rem;font-size:1.25rem;font-weight:600;color:var(--color-text)}@media(max-width:640px){.dashboard-header{flex-direction:column;align-items:stretch}.dashboard-title{font-size:1.5rem}}.instructor-card{background-color:var(--color-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:1.5rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem;transition:box-shadow .2s ease,transform .2s ease}.instructor-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.instructor-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.instructor-title{display:flex;align-items:flex-start;gap:.75rem}.instructor-icon{font-size:1.5rem;flex-shrink:0}.instructor-info{display:flex;flex-direction:column;gap:.25rem}.instructor-name{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text);line-height:1.3}.instructor-email{font-size:.875rem;color:var(--color-text-muted)}.instructor-restriction-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;white-space:nowrap;background-color:#f59e0b26;color:#d97706;flex-shrink:0}.instructor-competencies{display:flex;flex-direction:column;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border)}.competencies-label{font-size:.875rem;color:var(--color-text-muted);font-weight:500}.competencies-tags{display:flex;flex-wrap:wrap;gap:.5rem}.competency-tag{background-color:var(--color-info-bg);color:var(--color-info);padding:.25rem .625rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;cursor:help}.instructor-actions{display:flex;gap:.75rem;margin-top:auto;padding-top:.5rem}.instructor-card .btn-action{flex:1;padding:.625rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.instructor-card .btn-edit{background-color:var(--color-card);color:var(--color-text);border:1px solid var(--color-border)}.instructor-card .btn-edit:hover{background-color:var(--color-bg);border-color:var(--color-text-muted)}.instructor-card .btn-delete{background-color:var(--color-error-bg);color:var(--color-error)}.instructor-card .btn-delete:hover{background-color:var(--color-error);color:#fff}@media(prefers-color-scheme:dark){.instructor-restriction-badge{background-color:#f59e0b40}}@media(max-width:480px){.instructor-header{flex-direction:column;gap:.75rem}.instructor-restriction-badge{align-self:flex-start}.instructor-actions{flex-direction:column}.instructor-card .btn-action{width:100%}}.modal-overlay{position:fixed;inset:0;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}.modal-container{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .25s ease-out;border:1px solid var(--color-border)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.modal-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text)}.modal-close-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-md);transition:all .15s ease}.modal-close-button:hover{color:var(--color-text);background-color:var(--color-bg)}.modal-close-button:active{transform:scale(.95)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:640px){.modal-overlay{padding:.5rem}.modal-container{max-height:95vh}.modal-header{padding:1rem 1.25rem}.modal-title{font-size:1rem}.modal-body{padding:1.25rem}}.confirm-dialog{display:flex;flex-direction:column;gap:1rem}.confirm-dialog-message{margin:0;color:var(--color-text);font-size:1rem;line-height:1.5}.confirm-dialog-impacted{background:var(--color-warning-bg);border-left:4px solid var(--color-warning);padding:1rem;border-radius:var(--radius-sm)}.confirm-dialog-impacted-title{margin:0 0 .5rem;font-weight:600;color:var(--color-warning);font-size:.875rem}.confirm-dialog-impacted-list{margin:0;padding-left:1.25rem}.confirm-dialog-impacted-list li{color:var(--color-text);font-size:.875rem;margin-bottom:.25rem}.confirm-dialog-impacted-list li:last-child{margin-bottom:0}.confirm-dialog-footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.confirm-dialog-btn{padding:.625rem 1.25rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.confirm-dialog-btn:disabled{opacity:.6;cursor:not-allowed}.confirm-dialog-btn-secondary{background:var(--color-card);color:var(--color-text);border:1px solid var(--color-border)}.confirm-dialog-btn-secondary:hover:not(:disabled){background:var(--color-bg)}.confirm-dialog-btn-danger{background:var(--color-error);color:#fff}.confirm-dialog-btn-danger:hover:not(:disabled){background:#dc2626}.confirm-dialog-btn-warning{background:var(--color-warning);color:#fff}.confirm-dialog-btn-warning:hover:not(:disabled){background:#d97706}.instructor-form{display:flex;flex-direction:column;gap:1.5rem}.form-section{display:flex;flex-direction:column;gap:1rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.form-section:last-of-type{border-bottom:none;padding-bottom:0}.form-label-small{font-weight:500;color:var(--color-text-muted);font-size:.75rem}.form-input-small{padding:.5rem .75rem;font-size:.875rem}.form-select{padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-input-bg);color:var(--color-text);font-size:1rem;width:100%;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #e11d481a}.form-select:disabled{opacity:.6;cursor:not-allowed}.competencies-list{display:flex;flex-direction:column;gap:.75rem}.competency-row{display:flex;align-items:flex-end;gap:.75rem;padding:1rem;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md)}.competency-row-differentiated{flex-wrap:wrap}.competency-style{flex:2;display:flex;flex-direction:column;gap:.375rem;min-width:180px}.competency-levels-group{display:flex;gap:.5rem;flex:2}.competency-level{flex:1;display:flex;flex-direction:column;gap:.375rem;min-width:100px}.competency-level-error{width:100%;flex-basis:100%;padding-left:0;margin-top:-.5rem}.btn-remove-competency{padding:.5rem .75rem;background-color:var(--color-error-bg);color:var(--color-error);border:none;border-radius:var(--radius-md);font-size:1.25rem;line-height:1;cursor:pointer;transition:all .2s ease;height:42px;width:42px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-remove-competency:hover:not(:disabled){background-color:var(--color-error);color:#fff}.btn-remove-competency:disabled{opacity:.4;cursor:not-allowed}.btn-add-competency{padding:.75rem 1rem;background-color:var(--color-card);color:var(--color-primary);border:2px dashed var(--color-primary);border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-add-competency:hover:not(:disabled){background-color:#e11d480d}.btn-add-competency:disabled{opacity:.4;cursor:not-allowed;border-color:var(--color-border);color:var(--color-text-muted)}.form-checkbox-group{display:flex;align-items:center}.form-checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.875rem;color:var(--color-text)}.form-checkbox{width:1.125rem;height:1.125rem;cursor:pointer;accent-color:var(--color-primary)}.form-info-box-warning{background-color:#f59e0b1a;border-left-color:#d97706}@media(max-width:640px){.competency-row{flex-direction:column;align-items:stretch;gap:.75rem}.competency-style,.competency-level{width:100%}.competency-levels-group{flex-direction:column;gap:.75rem}.btn-remove-competency{width:100%;height:auto;padding:.5rem}.competency-level-error{margin-top:0}}@media(max-width:480px){.form-actions{flex-direction:column-reverse}.form-btn{width:100%}}.instructors-page{max-width:1400px;margin:0 auto}.reconfiguration-banner{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background-color:#f59e0b26;border:1px solid #d97706;border-left:4px solid #d97706;border-radius:var(--radius-md);margin-bottom:1.5rem}.reconfiguration-banner-icon{font-size:1.25rem;flex-shrink:0}.reconfiguration-banner-text{flex:1;color:var(--color-text);font-size:.9rem;line-height:1.4}.reconfiguration-banner-btn{padding:.5rem 1rem;background-color:#d97706;color:#fff;border:none;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;cursor:pointer;transition:background-color .2s ease;white-space:nowrap}.reconfiguration-banner-btn:hover{background-color:#b45309}@media(max-width:640px){.reconfiguration-banner{flex-direction:column;align-items:flex-start;gap:.75rem}.reconfiguration-banner-btn{width:100%;text-align:center}}.dance-style-card{background-color:var(--color-card);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:1.5rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem;transition:box-shadow .2s ease,transform .2s ease}.dance-style-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.dance-style-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.dance-style-title{display:flex;align-items:center;gap:.5rem}.dance-style-icon{font-size:1.5rem}.dance-style-name{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text);line-height:1.3}.dance-style-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;white-space:nowrap;background-color:var(--color-primary);background-color:#e11d4826;color:var(--color-primary)}.dance-style-courses{display:flex;flex-direction:column;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border)}.courses-label{font-size:.875rem;color:var(--color-text-muted);font-weight:500}.courses-tags{display:flex;flex-wrap:wrap;gap:.5rem}.course-tag{display:inline-flex;align-items:center;gap:.25rem;background-color:var(--color-info-bg);color:var(--color-info);padding:.25rem .625rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;cursor:default}.course-tag-restricted{border:1px dashed var(--color-warning, #d97706);background-color:#f59e0b1a}.course-restriction-icon{font-size:.625rem}.course-instructors-badge{display:inline-flex;align-items:center;margin-left:.25rem;padding:0 .25rem;border-radius:3px;font-size:.625rem;font-weight:600}.badge-single{background-color:#3b82f633;color:#3b82f6}.badge-double{background-color:#22c55e33;color:#22c55e}.dance-style-actions{display:flex;gap:.75rem;margin-top:auto;padding-top:.5rem}.btn-action{flex:1;padding:.625rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.btn-edit{background-color:var(--color-card);color:var(--color-text);border:1px solid var(--color-border)}.btn-edit:hover{background-color:var(--color-bg);border-color:var(--color-text-muted)}.btn-delete{background-color:var(--color-error-bg);color:var(--color-error)}.btn-delete:hover{background-color:var(--color-error);color:#fff}@media(prefers-color-scheme:dark){.dance-style-badge{background-color:#e11d4840}}@media(max-width:480px){.dance-style-actions{flex-direction:column}.btn-action{width:100%}}.instructor-restriction-modal{display:flex;flex-direction:column;gap:1rem;min-height:300px}.restriction-erreur{display:flex;align-items:center;gap:.5rem;background-color:var(--color-error-bg);color:var(--color-error);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.875rem;border-left:4px solid var(--color-error)}.erreur-icon{flex-shrink:0}.restriction-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 1rem}.restriction-loading .loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.restriction-loading p{color:var(--color-text-muted);font-size:.875rem}.restriction-info{display:flex;gap:.75rem;background-color:var(--color-info-bg);border-left:4px solid var(--color-info);padding:.75rem 1rem;border-radius:var(--radius-sm)}.info-icon{flex-shrink:0;font-size:1rem}.restriction-info p{margin:0;color:var(--color-text);font-size:.875rem;line-height:1.5}.restriction-liste{display:flex;flex-direction:column;gap:.5rem;max-height:350px;overflow-y:auto;padding-right:.25rem}.restriction-liste::-webkit-scrollbar{width:6px}.restriction-liste::-webkit-scrollbar-track{background:var(--color-bg);border-radius:3px}.restriction-liste::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.restriction-liste::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.restriction-vide{display:flex;justify-content:center;align-items:center;padding:2rem;color:var(--color-text-muted);font-size:.875rem}.restriction-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;background-color:var(--color-card)}.restriction-item:hover:not(.restriction-item-disabled){border-color:var(--color-primary);background-color:#e11d4805}.restriction-item-selected{border-color:var(--color-primary);background-color:#e11d480d}.restriction-item-disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-bg)}.restriction-checkbox{width:18px;height:18px;margin-top:2px;flex-shrink:0;cursor:pointer;accent-color:var(--color-primary)}.restriction-item-disabled .restriction-checkbox{cursor:not-allowed}.restriction-item-content{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.restriction-item-header{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.restriction-item-nom{font-weight:600;color:var(--color-text);font-size:.9375rem}.restriction-badge-incompetent{padding:.125rem .5rem;border-radius:9999px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;background-color:#ef444426;color:var(--color-error)}.restriction-item-details{display:flex;align-items:center;gap:.5rem}.restriction-niveaux{font-size:.8125rem;color:var(--color-text-muted)}.restriction-niveaux-na{font-size:.8125rem;color:var(--color-text-muted);font-style:italic}.restriction-actions{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-top:1rem;border-top:1px solid var(--color-border);margin-top:auto}.restriction-compteur{font-size:.875rem;color:var(--color-text);font-weight:500}.restriction-compteur-tous{color:var(--color-text-muted)}.restriction-boutons{display:flex;gap:.75rem}.btn-restriction{padding:.625rem 1.25rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.btn-restriction:disabled{opacity:.6;cursor:not-allowed}.btn-annuler{background-color:var(--color-card);color:var(--color-text);border:1px solid var(--color-border)}.btn-annuler:hover:not(:disabled){background-color:var(--color-bg)}.btn-enregistrer{background-color:var(--color-primary);color:#fff}.btn-enregistrer:hover:not(:disabled){background-color:var(--color-primary-hover)}@media(prefers-color-scheme:dark){.restriction-badge-incompetent{background-color:#ef444440}.restriction-item-selected{background-color:#e11d481a}.restriction-item:hover:not(.restriction-item-disabled){background-color:#e11d480d}}@media(max-width:480px){.restriction-actions{flex-direction:column;align-items:stretch;gap:.75rem}.restriction-compteur{text-align:center}.restriction-boutons{flex-direction:column-reverse}.btn-restriction{width:100%}}.star-rating{display:flex;align-items:center;gap:.125rem}.star-filled{color:#fbbf24;line-height:1}.star-empty{color:#d1d5db;line-height:1}.star-number{margin-left:.5rem;font-size:.875rem;font-weight:500;color:var(--color-text)}.dance-style-form{display:flex;flex-direction:column;gap:1.25rem}.form-error-general{background-color:var(--color-error-bg);color:var(--color-error);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.875rem;border-left:4px solid var(--color-error)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:600;color:var(--color-text);font-size:.875rem}.form-input{padding:.75rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-input-bg);color:var(--color-text);font-size:1rem;width:100%;transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #e11d481a}.form-input:disabled{opacity:.6;cursor:not-allowed}.form-input-error{border-color:var(--color-error)}.form-input-error:focus{box-shadow:0 0 0 3px #ef44441a}.form-error{color:var(--color-error);font-size:.75rem;margin-top:.25rem}.form-hint{color:var(--color-text-muted);font-size:.75rem}.form-info-box{display:flex;gap:.75rem;background-color:var(--color-info-bg);border-left:4px solid var(--color-info);padding:1rem;border-radius:var(--radius-sm)}.form-info-icon{font-size:1.25rem;flex-shrink:0}.form-info-content{display:flex;flex-direction:column;gap:.75rem}.form-info-text{margin:0;color:var(--color-text);font-size:.875rem;line-height:1.5}.form-info-preview{display:flex;flex-direction:column;gap:.5rem}.form-info-preview-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted)}.form-info-preview-tags{display:flex;flex-wrap:wrap;gap:.375rem}.form-info-preview-tag{background-color:var(--color-card);color:var(--color-info);padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;border:1px solid var(--color-info)}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.form-btn{padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.form-btn-secondary:hover:not(:disabled){background-color:var(--color-bg)}.form-btn-primary{background-color:var(--color-primary);color:#fff}.form-btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.form-section{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background-color:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border)}.form-section-title{margin:0;font-size:1rem;font-weight:600;color:var(--color-text)}.form-section-description{margin:0;font-size:.8125rem;color:var(--color-text-muted);line-height:1.4}.form-section-loading{padding:1rem;text-align:center;color:var(--color-text-muted);font-size:.875rem}.courses-configuration{display:flex;flex-direction:column;gap:.75rem}.course-config-item{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background-color:var(--color-card);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.course-config-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.course-config-name{font-weight:600;color:var(--color-text);font-size:.9375rem}.course-config-restriction-badge{padding:.125rem .5rem;border-radius:9999px;font-size:.6875rem;font-weight:500;background-color:#f59e0b26;color:#d97706}.course-config-controls{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.required-instructors-group{display:flex;align-items:center;gap:.75rem}.control-label{font-size:.8125rem;color:var(--color-text-muted);font-weight:500}.radio-group{display:flex;gap:1rem}.radio-label{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--color-text);cursor:pointer}.radio-label input[type=radio],.radio-label input[type=checkbox]{width:16px;height:16px;margin:0;cursor:pointer;accent-color:var(--color-primary)}.radio-label input[type=radio]:disabled{cursor:not-allowed;opacity:.5}.radio-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.radio-label-loading{opacity:.6;cursor:wait}.radio-loading-indicator{font-size:.875rem;margin-left:.25rem;animation:pulse 1s ease-in-out infinite}.btn-restriction-config{padding:.375rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease;border:1px solid var(--color-border);background-color:var(--color-card);color:var(--color-text)}.btn-restriction-config:hover:not(:disabled){border-color:var(--color-primary);background-color:#e11d480d;color:var(--color-primary)}.btn-restriction-config:disabled{opacity:.6;cursor:not-allowed}.course-popularity-list{display:flex;flex-direction:column;gap:.75rem}.course-popularity-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background-color:var(--color-card);border-radius:var(--radius-sm);border:1px solid var(--color-border);transition:background-color .2s ease}.course-popularity-item:hover{background-color:var(--color-bg)}.course-name{flex:0 0 150px;font-weight:500;color:#fff;font-size:.9375rem}.popularity-slider{flex:1;max-width:200px;height:6px;border-radius:3px;background:linear-gradient(to right,#d1d5db,#fbbf24);outline:none;-webkit-appearance:none;appearance:none}.popularity-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#fbbf24;cursor:pointer;box-shadow:0 2px 4px #0003;transition:transform .2s ease}.popularity-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.popularity-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fbbf24;cursor:pointer;border:none;box-shadow:0 2px 4px #0003;transition:transform .2s ease}.popularity-slider::-moz-range-thumb:hover{transform:scale(1.1)}.popularity-slider:disabled{opacity:.5;cursor:not-allowed}.course-popularity-stars{flex:0 0 120px}.popularity-loading{font-size:.875rem;animation:pulse 1s ease-in-out infinite}@media(max-width:480px){.form-actions{flex-direction:column-reverse}.form-btn{width:100%}.course-config-controls{flex-direction:column;align-items:stretch}.required-instructors-group{flex-direction:column;align-items:flex-start;gap:.5rem}.btn-restriction-config{width:100%}}.dance-styles-page{max-width:1400px;margin:0 auto}.sessions-page{max-width:1400px;margin:0 auto}.sessions-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.sessions-title{margin:0;font-size:2rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.sessions-subtitle{margin:.5rem 0 0;color:var(--color-text-muted);font-size:1rem}.sessions-stats{display:flex;gap:1rem;margin-bottom:2rem}.stat-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:1.5rem;background-color:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center}.stat-value{font-size:2rem;font-weight:700;color:var(--color-primary)}.stat-label{font-size:.875rem;color:var(--color-text-muted);margin-top:.25rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--color-text-muted)}.loading-spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.loading-state p{margin-top:1rem;font-size:.95rem}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:2rem;background-color:var(--color-error-bg);border-radius:var(--radius-lg);text-align:center}.error-icon{font-size:3rem;margin-bottom:1rem}.error-state p{margin:0 0 1.5rem;color:var(--color-error);font-size:1rem}.btn-retry{padding:.75rem 1.5rem;background-color:var(--color-error);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .2s ease}.btn-retry:hover{opacity:.9}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:3rem;background-color:var(--color-card);border:2px dashed var(--color-border);border-radius:var(--radius-lg);text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h2{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:var(--color-text)}.empty-state p{margin:0 0 1.5rem;color:var(--color-text-muted);max-width:400px}@media(max-width:768px){.sessions-header{flex-direction:column;align-items:stretch}.sessions-title{font-size:1.5rem}.sessions-stats{flex-direction:column}}.attendance-table-container{width:100%;overflow-x:auto;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.attendance-table{width:100%;border-collapse:collapse;font-size:14px}.attendance-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.attendance-table th{padding:16px 12px;text-align:left;font-weight:600;text-transform:uppercase;font-size:12px;letter-spacing:.5px}.attendance-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s ease}.attendance-table tbody tr:hover{background-color:#f9fafb}.attendance-table tbody tr.saved{background-color:#f0fdf4}.attendance-table tbody tr.saved:hover{background-color:#dcfce7}.attendance-table td{padding:14px 12px}.course-name{font-weight:600}.time{font-family:Courier New,monospace;color:#6b7280;font-weight:500}.popularity-cell{padding:8px 12px}.attendance-cell{min-width:200px}.attendance-input{display:flex;align-items:center;gap:12px}.attendance-slider{flex:1;height:6px;border-radius:3px;background:linear-gradient(to right,#ef4444,#f59e0b,#eab308,#84cc16,#22c55e);outline:none;-webkit-appearance:none;appearance:none}.attendance-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid #667eea;cursor:pointer;box-shadow:0 2px 4px #0003;transition:all .2s ease}.attendance-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 4px 8px #0000004d}.attendance-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid #667eea;cursor:pointer;box-shadow:0 2px 4px #0003;transition:all .2s ease}.attendance-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 4px 8px #0000004d}.attendance-value{font-weight:700;font-size:18px;color:#667eea;min-width:20px;text-align:center}.saved-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:#22c55e;color:#fff;border-radius:50%;font-size:14px;font-weight:700;animation:fadeInScale .3s ease}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.empty-state{padding:60px 20px;text-align:center;color:#9ca3af}.empty-state p{font-size:16px;margin:0}@media(max-width:768px){.attendance-table{font-size:12px}.attendance-table th,.attendance-table td{padding:10px 8px}.attendance-cell{min-width:150px}.attendance-value{font-size:16px}}.correlation-chart-container{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 12px #0000001a}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:16px}.chart-title{font-size:18px;font-weight:700;color:#1f2937;margin:0}.correlation-badge{display:flex;flex-direction:column;align-items:flex-end;padding:12px 20px;border-radius:8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea4d}.correlation-badge.strong{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 2px 8px #22c55e4d}.correlation-badge.moderate{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 8px #f59e0b4d}.correlation-badge.weak{background:linear-gradient(135deg,#94a3b8,#64748b);box-shadow:0 2px 8px #94a3b84d}.correlation-badge.neutral{background:linear-gradient(135deg,#6b7280,#4b5563);box-shadow:0 2px 8px #6b72804d}.correlation-value{font-size:24px;font-weight:800;letter-spacing:.5px}.correlation-label{font-size:12px;font-weight:500;opacity:.9;margin-top:4px}.correlation-tooltip{background:#fffffffa;border:2px solid #667eea;border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #00000026}.tooltip-label{font-weight:700;color:#1f2937;margin:0 0 8px;font-size:14px}.tooltip-value{margin:4px 0;font-size:13px;color:#4b5563}.tooltip-value strong{color:#667eea;margin-right:4px}.empty-chart{display:flex;align-items:center;justify-content:center;height:400px;background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-radius:8px;border:2px dashed #d1d5db}.empty-chart p{color:#9ca3af;font-size:16px;margin:0;text-align:center;padding:0 20px}@media(max-width:768px){.correlation-chart-container{padding:16px}.chart-header{flex-direction:column;align-items:flex-start}.correlation-badge{align-items:flex-start;width:100%}.chart-title{font-size:16px}.correlation-value{font-size:20px}}.insights-panel{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 12px #0000001a}.insights-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #f3f4f6}.insights-title{font-size:20px;font-weight:700;color:#1f2937;margin:0;display:flex;align-items:center;gap:8px}.insights-count{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600}.insights-list{display:flex;flex-direction:column;gap:16px}.insight-card{display:flex;gap:16px;padding:18px;border-radius:10px;border-left:4px solid;background:linear-gradient(135deg,#ffffffe6,#f9fafbe6);box-shadow:0 2px 6px #00000014;transition:all .3s ease;animation:slideInLeft .4s ease}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.insight-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.insight-card.positive{border-left-color:#22c55e;background:linear-gradient(135deg,#f0fdf4e6,#dcfce7e6)}.insight-card.warning{border-left-color:#f59e0b;background:linear-gradient(135deg,#fefce8e6,#fef3c7e6)}.insight-card.neutral{border-left-color:#667eea;background:linear-gradient(135deg,#eef2ffe6,#e0e7ffe6)}.insight-icon{font-size:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px}.insight-content{flex:1}.insight-content p{margin:0;font-size:15px;line-height:1.6;color:#374151}.insight-content strong{color:#1f2937;font-weight:700}.empty-insights{text-align:center;padding:60px 20px;background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-radius:8px;border:2px dashed #d1d5db}.empty-insights p{color:#6b7280;font-size:16px;margin:8px 0}.empty-subtitle{font-size:14px!important;color:#9ca3af!important}@media(max-width:768px){.insights-panel{padding:16px}.insights-header{flex-direction:column;align-items:flex-start;gap:12px}.insights-title{font-size:18px}.insight-card{flex-direction:column;gap:12px}.insight-icon{font-size:24px;width:32px;height:32px}.insight-content p{font-size:14px}}.session-analytics-page{max-width:1400px;margin:0 auto;padding:32px;background:linear-gradient(135deg,#f0f4f8,#e2e8f0);min-height:100vh}.analytics-header{margin-bottom:32px}.btn-back-link{background:none;border:none;color:#667eea;font-size:14px;font-weight:600;cursor:pointer;padding:8px 0;margin-bottom:16px;transition:color .2s ease;display:inline-flex;align-items:center;gap:4px}.btn-back-link:hover{color:#5568d3;text-decoration:underline}.header-content{padding:32px;border-radius:16px;box-shadow:0 4px 16px #0000001a}.page-title{font-size:32px;font-weight:800;color:#1f2937;margin:0 0 8px;display:flex;align-items:center;gap:12px}.session-name{font-size:20px;font-weight:600;color:#667eea;margin:0 0 20px}.progress-indicator{display:flex;align-items:center;gap:16px;margin-top:16px}.progress-text{font-size:14px;font-weight:600;color:#4b5563;min-width:180px}.progress-bar{flex:1;height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:6px;transition:width .5s ease}.progress-percentage{font-size:16px;font-weight:700;color:#667eea;min-width:50px;text-align:right}.analytics-section{margin-bottom:32px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:16px}.section-title{font-size:22px;font-weight:700;color:#1f2937;margin:0 0 20px;display:flex;align-items:center;gap:10px}.btn-save{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 28px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d;display:flex;align-items:center;gap:8px}.btn-save:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn-save:disabled{opacity:.6;cursor:not-allowed}.btn-save.success{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 4px 12px #22c55e4d}.save-warning{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#f59e0b1a;border:1px solid #f59e0b;border-radius:8px;color:#d97706;font-size:14px;font-weight:500}.spinner-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:40px}.spinner{width:60px;height:60px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:20px}.loading-container p,.error-container p{font-size:16px;color:#6b7280;margin:8px 0}.error-icon{font-size:64px;margin-bottom:16px}.error-container h2{font-size:24px;font-weight:700;color:#1f2937;margin:0 0 12px}.btn-back{margin-top:24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 28px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-back:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.success-toast{position:fixed;bottom:32px;right:32px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;padding:14px 20px;border-radius:10px;box-shadow:0 8px 24px #22c55e66;font-weight:600;font-size:14px;animation:slideInUp .4s ease,fadeOut .4s ease 2.6s;z-index:1000;display:flex;align-items:center;gap:10px}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{to{opacity:0}}@media(max-width:768px){.session-analytics-page{padding:16px}.header-content{padding:20px}.page-title{font-size:24px}.session-name{font-size:18px}.progress-indicator{flex-direction:column;align-items:flex-start;gap:8px}.progress-text{min-width:auto}.progress-bar{width:100%}.section-header{flex-direction:column;align-items:flex-start}.btn-save{width:100%;justify-content:center}.success-toast{bottom:16px;right:16px;left:16px;text-align:center}}.schedules-page{max-width:1400px;margin:0 auto}.schedules-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem}.schedules-title{margin:0;font-size:2rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.schedules-subtitle{margin:.5rem 0 0;color:var(--color-text-muted);font-size:1rem}.schedules-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1.25rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center}.stat-value{font-size:1.875rem;font-weight:700;color:var(--color-primary)}.stat-label{font-size:.875rem;color:var(--color-text-muted)}.schedules-filters{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.search-input{width:100%;max-width:360px;padding:.75rem .875rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-input-bg);color:var(--color-text)}.search-input:focus{outline:none;box-shadow:var(--shadow-focus);border-color:var(--color-primary)}.filter-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.filter-btn{padding:.6rem .9rem;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text-muted);border-radius:var(--radius-md);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.filter-btn:hover{color:var(--color-text);border-color:var(--color-primary-light)}.filter-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.schedules-list-section{margin-bottom:1.75rem}.section-title{margin:0 0 .9rem;font-size:1.125rem;font-weight:700;color:var(--color-text)}.schedules-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1rem}.schedules-grid--compact{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.schedule-card{display:flex;flex-direction:column;gap:.9rem;padding:1rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.schedule-card--empty{border-style:dashed}.schedule-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.schedule-session-name{margin:0;font-size:1.05rem;font-weight:700;color:var(--color-text)}.schedule-card-badges{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;justify-content:flex-end}.status-badge,.session-badge{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .6rem;border-radius:var(--radius-full);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em;white-space:nowrap}.status-badge--draft{background:#f59e0b1f;color:#b45309}.status-badge--published{background:var(--color-success-bg);color:var(--color-success)}.status-badge--none{background:#6b728026;color:#6b7280}.status-badge--unknown{background:#ef44441f;color:var(--color-error)}.session-badge--preparation{background:#fbbf2426;color:#b45309}.session-badge--active{background:#10b98126;color:#047857}.session-badge--completed{background:#6b728026;color:#6b7280}.schedule-dates{margin:0;color:var(--color-text-muted);font-size:.9rem}.schedule-metadata{margin:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem}.schedule-metadata dt{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.02em}.schedule-metadata dd{margin:.2rem 0 0;font-size:.95rem;color:var(--color-text);font-weight:600}.schedule-warning{margin:0;padding:.6rem;border-radius:var(--radius-md);border:1px solid rgba(239,68,68,.4);background:#ef44441a;color:var(--color-error);font-size:.82rem}.schedule-actions{display:flex;gap:.5rem;flex-wrap:wrap}.btn-primary-link,.btn-secondary-link{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.6rem .85rem;border-radius:var(--radius-md);font-size:.85rem;font-weight:600;text-decoration:none;transition:all var(--transition-fast)}.btn-primary-link{background:var(--color-primary);color:#fff;border:1px solid var(--color-primary)}.btn-primary-link:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-secondary-link{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary-link:hover{border-color:var(--color-primary-light);color:var(--color-primary)}.schedules-loading-state,.schedules-error-state,.schedules-empty-state,.schedules-empty-inline{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.schedules-loading-state,.schedules-error-state,.schedules-empty-state{min-height:360px}.schedules-error-state,.schedules-empty-state,.schedules-empty-inline{padding:1.5rem;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.schedules-empty-inline{min-height:120px}.error-icon,.empty-icon{font-size:2rem;margin-bottom:.65rem;color:var(--color-text-muted)}.schedules-error-state p,.schedules-empty-state p,.schedules-empty-inline p,.schedules-loading-state p{margin:0;color:var(--color-text-muted)}.schedules-empty-state h2{margin:0 0 .45rem;color:var(--color-text)}.btn-retry{margin-top:1rem;padding:.65rem 1rem;border:none;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;font-weight:600;cursor:pointer}.btn-retry:hover{background:var(--color-primary-hover)}@media(max-width:992px){.schedules-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.schedules-filters{flex-direction:column;align-items:stretch}.search-input{max-width:none}}@media(max-width:768px){.schedules-header{flex-direction:column;align-items:stretch}.schedules-title{font-size:1.6rem}.schedules-grid,.schedules-grid--compact,.schedule-metadata{grid-template-columns:1fr}}@media(max-width:480px){.schedules-stats{grid-template-columns:1fr}.filter-buttons{width:100%}.filter-btn{flex:1}.schedule-card-header{flex-direction:column;align-items:flex-start}.schedule-card-badges{justify-content:flex-start}}.time-slots-form{display:flex;flex-direction:column;gap:1.5rem}.form-error-general{display:flex;align-items:center;gap:.75rem;background-color:var(--color-error-bg);color:var(--color-error);padding:.875rem 1rem;border-radius:var(--radius-md);font-size:.875rem;border-left:4px solid var(--color-error);font-weight:500}.form-info-box{display:flex;gap:.75rem;padding:1rem 1.125rem;background-color:var(--color-info-bg);border:1px solid rgba(59,130,246,.15);border-left:4px solid var(--color-info);border-radius:var(--radius-md)}.form-info-icon{color:var(--color-info);flex-shrink:0;margin-top:.125rem}.form-info-content{display:flex;flex-direction:column;gap:.5rem}.form-info-text{margin:0;color:var(--color-text);font-size:.8125rem;line-height:1.6}.day-cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.day-card{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.25rem;transition:all .2s ease;animation:fadeInUp .4s ease-out forwards;opacity:0}.day-card:hover{border-color:var(--color-primary-light);box-shadow:0 4px 12px #0000000f}.day-card-error{background-color:var(--color-error-bg);border-color:#ef44444d}.day-card-error:hover{border-color:var(--color-error)}.day-card-weekend{background:linear-gradient(135deg,var(--color-card) 0%,rgba(251,113,133,.04) 100%)}.day-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem}.day-info{display:flex;align-items:center;gap:.625rem}.day-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background-color:var(--color-bg);border-radius:var(--radius-sm);color:var(--color-text-muted)}.day-icon-weekend{background-color:#fb71851f;color:var(--color-primary)}.day-label{font-weight:600;font-size:.9375rem;color:var(--color-text)}.duration-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;background-color:var(--color-success-bg);color:var(--color-success);border-radius:999px;font-size:.75rem;font-weight:600}.day-card-content{display:flex;flex-direction:column;gap:.75rem;overflow:hidden}.time-inputs-row{display:flex;align-items:flex-end;gap:.5rem}.time-field{flex:1;min-width:0;display:flex;flex-direction:column;gap:.375rem}.time-field-label{display:flex;align-items:center;gap:.375rem;font-size:.6875rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.time-arrow{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);padding-bottom:.375rem;flex-shrink:0}.time-input{width:100%;max-width:100%;padding:.5rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-input-bg);color:var(--color-text);font-size:.875rem;font-weight:500;font-family:inherit;transition:all .2s ease;box-sizing:border-box}.time-input::-webkit-datetime-edit-second-field,.time-input::-webkit-datetime-edit-millisecond-field{display:none}.time-input::-webkit-datetime-edit-ampm-field{display:none}.time-input:hover:not(:disabled){border-color:var(--color-text-muted)}.time-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #e11d481f}.time-input:disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-bg)}.time-input-error{border-color:var(--color-error);background-color:var(--color-error-bg)}.time-input-error:focus{box-shadow:0 0 0 3px #ef44441f}.field-errors{display:flex;flex-direction:column;gap:.25rem}.field-error{display:flex;align-items:center;gap:.375rem;color:var(--color-error);font-size:.75rem;font-weight:500}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.5rem}.form-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;font-family:inherit}.form-btn:disabled{opacity:.6;cursor:not-allowed}.form-btn-secondary{background-color:var(--color-card);color:var(--color-text);border:1px solid var(--color-border)}.form-btn-secondary:hover:not(:disabled){background-color:var(--color-bg);border-color:var(--color-text-muted)}.form-btn-primary{background-color:var(--color-primary);color:#fff;box-shadow:0 2px 4px #e11d4833}.form-btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:0 4px 12px #e11d4840;transform:translateY(-1px)}.form-btn-primary:active:not(:disabled){transform:translateY(0)}.btn-spinner{animation:spin 1s linear infinite}@media(max-width:640px){.day-cards-grid{grid-template-columns:1fr}.day-card{padding:1rem}.time-inputs-row{gap:.5rem}.time-arrow{display:none}.time-input{padding:.5rem .375rem;font-size:.8125rem}.day-label{font-size:.875rem}.form-actions{flex-direction:column-reverse}.form-btn{width:100%;justify-content:center}}.impacted-sessions-content{display:flex;flex-direction:column;gap:1.25rem}.impacted-sessions-message{display:flex;gap:.875rem;background-color:var(--color-info-bg);border:1px solid rgba(59,130,246,.15);border-left:4px solid var(--color-info);padding:1rem 1.125rem;border-radius:var(--radius-md)}.impacted-sessions-message .message-icon{color:var(--color-info);flex-shrink:0;margin-top:.125rem}.impacted-sessions-message p{margin:0;color:var(--color-text);font-size:.875rem;line-height:1.6}.impacted-sessions-list-container{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:.5rem;max-height:200px;overflow-y:auto}.impacted-sessions-list{margin:0;padding:0;list-style-type:none}.impacted-sessions-list li{display:flex;align-items:center;gap:.75rem;color:var(--color-text);font-size:.875rem;padding:.625rem .875rem;margin-bottom:.25rem;font-weight:500;background-color:var(--color-card);border-radius:var(--radius-md);animation:fadeInSlide .3s ease-out forwards;opacity:0;transition:background-color .15s ease}@keyframes fadeInSlide{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.impacted-sessions-list li:hover{background-color:var(--color-bg)}.impacted-sessions-list li:last-child{margin-bottom:0}.impacted-sessions-list li svg{color:var(--color-text-muted);flex-shrink:0}.impacted-sessions-note{display:flex;gap:.875rem;background-color:var(--color-warning-bg);border:1px solid rgba(245,158,11,.2);border-left:4px solid var(--color-warning);padding:.875rem 1rem;border-radius:var(--radius-md)}.impacted-sessions-note .note-icon{color:var(--color-warning);flex-shrink:0;margin-top:.125rem}.impacted-sessions-note p{margin:0;color:var(--color-text);font-size:.8125rem;line-height:1.5}.impacted-sessions-footer{display:flex;justify-content:flex-end;margin-top:.25rem}.impacted-sessions-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #e11d4833}.impacted-sessions-btn:hover{background-color:var(--color-primary-hover);box-shadow:0 4px 12px #e11d4840;transform:translateY(-1px)}.impacted-sessions-btn:active{transform:translateY(0)}.impacted-sessions-btn:focus{outline:2px solid var(--color-primary-light);outline-offset:2px}.skeleton{background-color:var(--color-border);border-radius:var(--radius-sm)}.skeleton-text{border-radius:var(--radius-sm);height:1em}.skeleton-rectangular{border-radius:var(--radius-md)}.skeleton-circular{border-radius:50%}.skeleton-pulse{animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-wave{position:relative;overflow:hidden}.skeleton-wave:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);animation:skeleton-wave 1.5s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes skeleton-wave{0%{transform:translate(-100%)}to{transform:translate(100%)}}.day-card-skeleton{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.25rem;animation:fadeInUp .4s ease-out forwards;opacity:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.day-card-skeleton-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem}.day-card-skeleton-info{display:flex;align-items:center;gap:.625rem}.day-card-skeleton-content{display:flex;align-items:flex-end;gap:.75rem}.day-card-skeleton-field{flex:1;display:flex;flex-direction:column;gap:.375rem}.day-card-skeleton-arrow{display:flex;align-items:center;justify-content:center;padding-bottom:.75rem}.configuration-skeleton{max-width:1000px;margin:0 auto}.config-skeleton-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:2rem}.config-skeleton-header-text{display:flex;flex-direction:column;gap:.5rem}.config-skeleton-section{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.config-skeleton-section-header{display:flex;align-items:flex-start;gap:.875rem;margin-bottom:1.25rem}.config-skeleton-section-text{display:flex;flex-direction:column;gap:.5rem;flex:1}.config-skeleton-info-box{display:flex;gap:.75rem;padding:1rem 1.125rem;background-color:var(--color-bg);border-radius:var(--radius-md);margin-bottom:1.5rem}.config-skeleton-info-text{display:flex;flex-direction:column;gap:.5rem;flex:1}.config-skeleton-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-bottom:1.5rem}.config-skeleton-actions{display:flex;justify-content:flex-end;gap:.75rem}.config-skeleton-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 2rem;background-color:var(--color-bg);border:2px dashed var(--color-border);border-radius:var(--radius-md);gap:1rem}@media(max-width:640px){.config-skeleton-header{flex-direction:column;gap:.75rem}.config-skeleton-section{padding:1.25rem}.config-skeleton-section-header{flex-direction:column;gap:.5rem}.config-skeleton-cards{grid-template-columns:1fr}.config-skeleton-actions{flex-direction:column-reverse}.config-skeleton-actions .skeleton{width:100%!important}}.history-modal-content{display:flex;flex-direction:column;gap:1.5rem}.history-loading,.history-error,.history-empty-state{text-align:center;padding:2rem;color:var(--color-text-muted)}.history-error{color:var(--color-error)}.history-chart-container{background-color:var(--color-bg);padding:1rem;border-radius:var(--radius-md)}.history-table-container{overflow-x:auto}.history-table{width:100%;border-collapse:collapse}.history-table th{text-align:left;padding:.75rem;background-color:var(--color-bg);font-weight:600;color:var(--color-text);border-bottom:2px solid var(--color-border)}.history-table td{padding:.75rem;border-bottom:1px solid var(--color-border);color:var(--color-text)}.history-table tbody tr:hover{background-color:var(--color-bg)}.config-section{background-color:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;transition:box-shadow .2s ease,border-color .2s ease}.config-section:hover{box-shadow:var(--shadow-md)}.section-header{margin-bottom:1.25rem}.section-title-group{display:flex;align-items:flex-start;gap:.875rem}.section-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background-color:var(--color-info-bg);border-radius:var(--radius-md);color:var(--color-info);flex-shrink:0}.section-icon-muted{background-color:var(--color-bg);color:var(--color-text-muted)}.section-title{margin:0 0 .25rem;font-size:1.125rem;font-weight:600;color:var(--color-text)}.section-description{margin:0;color:var(--color-text-muted);font-size:.875rem;line-height:1.5}.section-content{display:flex;flex-direction:column;gap:1.25rem}.section-actions{display:flex;gap:.75rem;justify-content:flex-end}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--color-border)}.btn-cancel{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background-color:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-cancel:hover:not(:disabled){background-color:var(--color-bg);border-color:var(--color-text-muted);color:var(--color-text)}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-save{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-save:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:0 4px 12px #e11d4840}.btn-save:disabled{opacity:.5;cursor:not-allowed}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:background-color .2s ease,transform .2s ease,box-shadow .2s ease}.btn-primary:hover{background-color:var(--color-primary-hover);box-shadow:0 4px 12px #e11d4840}.btn-primary:active{transform:scale(.98)}.info-section,.info-section-config{background-color:var(--color-info-bg);border-color:#3b82f633}.info-content{padding:.5rem}.info-title{margin:0 0 .5rem;font-size:.9375rem;font-weight:600;color:var(--color-info)}.info-text{margin:0;font-size:.875rem;color:var(--color-text);line-height:1.6}.warning-box{display:flex;gap:.875rem;background-color:var(--color-warning-bg);border:1px solid rgba(245,158,11,.2);border-left:4px solid var(--color-warning);padding:1rem 1.25rem;border-radius:var(--radius-md);margin-top:.5rem}.warning-icon{display:flex;align-items:flex-start;color:var(--color-warning);flex-shrink:0;padding-top:.125rem}.warning-content{display:flex;flex-direction:column;gap:.25rem}.warning-title{margin:0;font-weight:600;color:var(--color-warning);font-size:.875rem}.warning-text{margin:0;color:var(--color-text);font-size:.8125rem;line-height:1.5}.placeholder-section{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 2rem;background-color:var(--color-bg);border:2px dashed var(--color-border);border-radius:var(--radius-md);text-align:center;transition:border-color .2s ease}.placeholder-section:hover{border-color:var(--color-text-muted)}.placeholder-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background-color:var(--color-card);border-radius:50%;color:var(--color-text-muted);margin-bottom:1rem;box-shadow:var(--shadow-sm)}.placeholder-section p{margin:0;color:var(--color-text-muted);font-size:.875rem}@media(max-width:640px){.config-section{padding:1.25rem}.section-title-group{flex-direction:column;gap:.5rem}.section-icon{width:32px;height:32px}.section-title{font-size:1rem}.warning-box{flex-direction:column;gap:.5rem;padding:1rem}.placeholder-section{padding:2rem 1rem}.placeholder-icon{width:56px;height:56px}.form-actions{flex-direction:column}.btn-cancel,.btn-save{width:100%;justify-content:center}}.configuration-page{max-width:1000px;margin:0 auto}.timeslot-popularity-list{display:flex;flex-direction:column;gap:1rem}.timeslot-popularity-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background-color:var(--color-bg);border-radius:var(--radius-md);transition:background-color .2s ease}.timeslot-popularity-item:hover{background-color:var(--color-border)}.timeslot-label{flex:0 0 180px;font-weight:500;color:var(--color-text)}.timeslot-slider{flex:1;max-width:200px;height:6px;border-radius:3px;background:linear-gradient(to right,#d1d5db,#fbbf24);outline:none;-webkit-appearance:none}.timeslot-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#fbbf24;cursor:pointer;box-shadow:0 2px 4px #0003;transition:transform .2s ease}.timeslot-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.timeslot-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fbbf24;cursor:pointer;border:none;box-shadow:0 2px 4px #0003;transition:transform .2s ease}.timeslot-slider::-moz-range-thumb:hover{transform:scale(1.1)}.timeslot-stars{flex:0 0 120px}.btn-history{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:var(--color-info-bg);color:var(--color-info);border:1px solid var(--color-info);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s ease}.btn-history:hover{background-color:var(--color-info);color:#fff}.dev-random-page{max-width:900px;margin:0 auto;padding:1.5rem;display:grid;gap:1rem}.dev-random-page__header h1{margin:0;font-size:1.6rem}.dev-random-page__header p{margin:.5rem 0 0;color:var(--color-text-muted)}.dev-random-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem;box-shadow:var(--shadow-sm)}.dev-random-form-row{display:grid;gap:.4rem;margin-bottom:1rem}.dev-random-form-row label{font-weight:600}.dev-random-form-row input{height:2.5rem;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-input-bg);color:var(--color-text);padding:0 .75rem}.dev-random-button{height:2.6rem;border:none;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;cursor:pointer;font-weight:700;padding:0 1rem}.dev-random-button:disabled{opacity:.7;cursor:not-allowed}.dev-random-message{margin-top:.75rem}.dev-random-message--error{color:var(--color-error)}.dev-random-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.dev-random-grid>div{display:grid;gap:.2rem}.dev-random-label{color:var(--color-text-muted);font-size:.85rem}.dev-random-schedule{margin-top:1rem}.dev-random-schedule h3{margin:0 0 .4rem}.dev-random-schedule p{margin:.35rem 0}.dev-random-links{margin-top:1rem;display:flex;gap:.75rem;flex-wrap:wrap}.dev-random-link{display:inline-flex;align-items:center;justify-content:center;padding:.55rem .85rem;border-radius:var(--radius-md);border:1px solid var(--color-border);color:var(--color-text);text-decoration:none;font-weight:600}.dev-random-link:hover{border-color:var(--color-primary);color:var(--color-primary)}@media(max-width:700px){.dev-random-grid{grid-template-columns:1fr}}
