.auth-page{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - var(--header-height) - 50px);padding:20px}.auth-form-container{background-color:#fff;padding:30px;border-radius:8px;box-shadow:0 4px 8px #0000001a;width:100%;max-width:400px}.auth-form-container h2{text-align:center;color:var(--primary-color);margin-bottom:20px}.form-group{margin-bottom:15px}.form-group label{display:block;font-weight:700;margin-bottom:5px;color:#333}.form-group input[type=email],.form-group input[type=password],.form-group input[type=text]{width:100%;padding:10px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:1em}.form-group input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 2px #007bff40}.auth-button{width:100%;padding:12px;background-color:var(--primary-color);color:#fff;border:none;border-radius:4px;font-size:1.1em;font-weight:700;cursor:pointer;transition:background-color .3s ease}.auth-button:hover{opacity:.9}.auth-button:disabled{background-color:#ccc;cursor:not-allowed}.error-message{color:red;background-color:#ffebee;border:1px solid red;padding:10px;border-radius:4px;margin-bottom:15px;text-align:center}.auth-switch-prompt{text-align:center;margin-top:20px;font-size:.9em}.auth-switch-prompt a{color:var(--primary-color);font-weight:700;text-decoration:none}.auth-switch-prompt a:hover{text-decoration:underline}.dashboard-page{padding:20px}.dashboard-header{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #eee}.dashboard-header h1{color:var(--primary-color);margin-bottom:5px}.dashboard-header p{font-size:1.1em;color:var(--secondary-color)}.dashboard-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.summary-card{background-color:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000000d;transition:transform .2s ease-in-out}.summary-card:hover{transform:translateY(-5px)}.summary-card h2{font-size:1.3em;color:var(--primary-color);margin-top:0;margin-bottom:10px}.summary-card p{font-size:1.2em;color:#333;font-weight:700;margin-bottom:5px}.quick-actions{margin-bottom:30px;padding:20px;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000000d}.quick-actions h2{margin-top:0;margin-bottom:15px;color:var(--primary-color)}.quick-actions button{background-color:var(--primary-color);color:#fff;border:none;padding:10px 15px;margin-right:10px;margin-bottom:10px;border-radius:4px;cursor:pointer;font-size:1em;transition:background-color .2s ease}.quick-actions button:hover{opacity:.9}.role-switcher{background:white;padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e1e5e9;margin-bottom:30px}.role-switcher h3{margin:0 0 15px;color:#2c3e50;font-size:1.2rem}.view-buttons{display:flex;gap:10px;flex-wrap:wrap}.view-button{background:#f8f9fa;color:#495057;border:2px solid #e9ecef;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.view-button:hover{background:#e9ecef;border-color:#667eea}.view-button.active{background:#667eea;color:#fff;border-color:#667eea}.action-group{margin-bottom:25px;padding:20px;background:#f8f9fa;border-radius:8px;border-left:4px solid #667eea}.action-group h4{margin:0 0 15px;color:#2c3e50;font-size:1.1rem;font-weight:600}.action-group button{margin-right:15px;margin-bottom:10px;background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s ease}.action-group button:hover{background:#5a6fd8}@media (max-width: 768px){.view-buttons{flex-direction:column}.view-button{width:100%;text-align:center}.action-group button{width:100%;margin-right:0}}.dashboard-separator{margin:40px 0;padding:15px 0;text-align:center;border-top:2px dashed #667eea;border-bottom:2px dashed #667eea;background:linear-gradient(135deg,#f8f9ff 0%,#f0f4ff 100%)}.dashboard-separator span{color:#667eea;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.new-dashboard-layout{padding:20px 0}.dashboard-top-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.dashboard-card{background:white;border-radius:12px;box-shadow:0 2px 12px #00000014;overflow:hidden;transition:box-shadow .2s ease}.dashboard-card:hover{box-shadow:0 4px 20px #0000001f}.dashboard-card .card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#f8f9fa;border-bottom:1px solid #e9ecef}.dashboard-card .card-header h3{margin:0;font-size:1.1rem;color:#2c3e50}.dashboard-card .card-body{padding:20px}.badge{padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:600}.badge-success{background:#d4edda;color:#155724}.badge-warning{background:#fff3cd;color:#856404}.badge-danger{background:#f8d7da;color:#721c24}.action-needed-card .action-list{list-style:none;padding:0;margin:0}.action-needed-card .action-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;margin-bottom:8px;transition:background-color .2s ease}.action-needed-card .action-item:hover{background:#f8f9fa}.action-needed-card .action-item.priority-high{border-left:3px solid #dc3545}.action-needed-card .action-item.priority-normal{border-left:3px solid #ffc107}.action-needed-card .action-icon{font-size:1.5rem}.action-needed-card .action-content{flex:1;display:flex;flex-direction:column}.action-needed-card .action-title{font-weight:600;color:#2c3e50}.action-needed-card .action-subtitle{font-size:.85rem;color:#6c757d}.action-needed-card .action-button{background:#667eea;color:#fff;border:none;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:.75rem;transition:background-color .2s ease;white-space:nowrap;flex-shrink:0;align-self:center;width:auto!important;max-width:60px}.action-needed-card .action-button:hover{background:#5a6fd8}.action-needed-card .no-actions,.action-needed-card .more-actions{text-align:center;color:#6c757d;font-style:italic}.this-week-card .event-list{list-style:none;padding:0;margin:0}.this-week-card .event-item{display:grid;grid-template-columns:50px 1fr auto;gap:10px;align-items:center;padding:10px 8px;border-bottom:1px solid #f0f0f0;border-radius:6px;margin:4px 0;transition:background-color .2s ease}.this-week-card .event-item.clickable{cursor:pointer}.this-week-card .event-item.clickable:hover{background-color:#f8f9fa}.this-week-card .event-item:last-child{border-bottom:none}.this-week-card .event-date-block{display:flex;flex-direction:column;align-items:center}.this-week-card .event-day{font-weight:600;color:#667eea;text-transform:uppercase;font-size:.75rem}.this-week-card .event-date{font-size:.7rem;color:#6c757d}.this-week-card .event-details{display:flex;flex-direction:column;gap:2px}.this-week-card .event-title{color:#2c3e50;font-weight:500;font-size:.9rem}.this-week-card .event-class{font-size:.75rem;color:#6c757d}.this-week-card .event-badges{display:flex;gap:4px;margin-top:2px}.this-week-card .print-badge{font-size:.8rem;padding:1px 4px;border-radius:3px;cursor:help}.this-week-card .print-badge.needs-print{background:#fff3cd;color:#856404}.this-week-card .print-badge.printed{background:#d1ecf1;color:#0c5460}.this-week-card .print-badge.confirmed{background:#d4edda;color:#155724}.this-week-card .print-badge.bypassed{background:#e2e3e5;color:#383d41}.this-week-card .event-status{padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:500;text-transform:uppercase}.this-week-card .status-draft{background:#fff3cd;color:#856404}.this-week-card .status-published{background:#d4edda;color:#155724}.this-week-card .status-printed{background:#d1ecf1;color:#0c5460}.this-week-card .no-events{text-align:center;color:#6c757d;font-style:italic}.this-week-card .event-item.summative-highlight{background:linear-gradient(90deg,#fff3cd 0%,#ffffff 30%);border-left:3px solid #ffc107}.this-week-card .task-type-badge{display:inline-block;font-size:.6rem;padding:1px 4px;border-radius:3px;margin-right:5px;font-weight:700;text-transform:uppercase}.this-week-card .task-type-badge.summative{background:#ffc107;color:#000}.text-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:.9rem;text-decoration:underline}.text-button:hover{color:#5a6fd8}.my-classes-card .class-count{color:#6c757d;font-size:.9rem}.my-classes-card .class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.my-classes-card .class-tile{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:16px;border-radius:10px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;gap:4px}.my-classes-card .class-tile:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.my-classes-card .class-name{font-weight:700;font-size:1.1rem}.my-classes-card .class-students{font-size:.85rem;opacity:.9}.my-classes-card .pending-badge{background:#dc3545;padding:2px 8px;border-radius:4px;font-size:.75rem;align-self:flex-start;margin-top:4px}.my-classes-card .no-classes{text-align:center;color:#6c757d;font-style:italic;padding:20px}.notification-bell{position:relative;background:none;border:none;font-size:1.5rem;cursor:pointer;padding:8px;transition:transform .2s ease}.notification-bell:hover{transform:scale(1.1)}.notification-bell .notification-badge{position:absolute;top:0;right:0;background:#dc3545;color:#fff;font-size:.7rem;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}@media (max-width: 768px){.dashboard-top-row{grid-template-columns:1fr}.my-classes-card .class-grid{grid-template-columns:repeat(2,1fr)}}.templates-page{padding:0;max-width:none;width:100%;margin:0}.page-header .header-actions{display:flex;gap:10px;align-items:center}.import-template-button{background-color:#6366f1!important}.import-template-button:hover{background-color:#4f46e5!important}.create-template-button,.edit-button,.delete-button,.view-button,.submit-button,.add-button,.remove-button,.add-button-small,.remove-button-small,.remove-button-xsmall{background-color:var(--primary-color);color:#fff;border:none;padding:10px 15px;border-radius:4px;cursor:pointer;text-decoration:none;font-size:1em;transition:opacity .2s ease}.template-tabs{display:flex;gap:10px;margin-bottom:20px;border-bottom:2px solid #eee;padding-bottom:0}.tab-button{background:none;border:none;padding:12px 25px;font-size:1.1em;font-weight:500;color:#666;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s ease}.tab-button:hover{color:var(--primary-color);background-color:#f8f9fa}.tab-button.active{color:var(--primary-color);border-bottom-color:var(--primary-color);font-weight:700}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.preview-header h2{margin:0}.test-print-button{display:flex;align-items:center;gap:6px;padding:8px 16px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:6px;font-size:.9em;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #4f46e54d}.test-print-button:hover{background:linear-gradient(135deg,#4338ca,#6d28d9);transform:translateY(-1px);box-shadow:0 4px 8px #4f46e566}.test-print-button:active{transform:translateY(0)}.assessment-preview-container{border:2px solid #e0e0e0;border-radius:8px;padding:20px;background-color:#4a5568;max-height:calc(100vh - 300px);overflow-y:auto;font-family:Arial,sans-serif}.preview-page{width:100%;max-width:650px;min-height:900px;margin:0 auto 30px;padding:40px;background-color:#fff;box-shadow:0 4px 20px #0000004d;border-radius:2px;position:relative;box-sizing:border-box}.preview-page:last-child{margin-bottom:10px}.page-number-indicator{position:absolute;bottom:15px;right:20px;font-size:.85em;color:#6b7280;font-style:italic}.page-break-indicator{display:none}.page-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;margin-bottom:15px;border-bottom:1px solid #e5e7eb}.page-header .header-content{display:flex;align-items:center;gap:10px}.page-header .header-logo{max-height:30px;max-width:80px}.page-header .header-school-name{font-size:.9em;font-weight:500}.page-header .page-number{font-size:.85em;color:#6b7280}.assessment-header{border-bottom:2px solid #ddd;padding-bottom:15px;margin-bottom:20px}.assessment-header h2{margin:0 0 10px;color:#333;font-size:1.5em}.assessment-description{margin:0;color:#666;font-style:italic}.section-preview{margin-bottom:25px;padding:15px;background:white;border-radius:6px;border:1px solid #e0e0e0}.section-preview h4{margin:0 0 15px;color:#444;font-size:1.2em;border-bottom:1px solid #eee;padding-bottom:8px}.question-preview-item{margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:4px;border-left:4px solid #007bff}.question-preview-item:last-child{margin-bottom:0}.no-content-message{text-align:center;color:#666;font-style:italic;padding:40px}.preview-question{font-size:.9em}.add-button{background-color:#28a745;color:#fff;margin-top:10px;margin-bottom:10px}.template-form .remove-button,.template-section .remove-button{background-color:#dc3545;color:#fff;border:none;padding:10px 15px;border-radius:4px!important;cursor:pointer;font-size:1em;width:auto!important;height:auto!important;display:inline-block!important}.add-button-small{font-size:.9em;padding:5px 10px;background-color:#28a745;color:#fff;margin-top:5px}.remove-button-small{font-size:.9em;padding:5px 10px;background-color:#6c757d;color:#fff}.remove-button-xsmall{font-size:.8em;padding:3px 8px;background-color:#6c757d;color:#fff;margin-left:5px}.create-template-button:hover,.edit-button:hover,.delete-button:hover,.view-button:hover,.submit-button:hover,.add-button:hover,.remove-button:hover,.add-button-small:hover,.remove-button-small:hover,.remove-button-xsmall:hover{opacity:.85}.loading-message,.error-message,.info-message,.no-templates-message{text-align:center;padding:20px;font-size:1.1em}.no-templates-message{color:var(--secondary-color)}.templates-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.template-card{background-color:#fff;border:1px solid #ddd;border-radius:8px;padding:20px;box-shadow:0 2px 5px #0000000d}.template-card h3{margin-top:0;color:var(--primary-color)}.template-card p{font-size:.95em;line-height:1.5;color:#555;margin-bottom:15px}.template-meta{font-size:.85em;color:#777;margin-bottom:15px}.template-meta span{margin-right:15px}.template-actions{display:flex;gap:10px}.template-form-page .page-header{margin-bottom:20px}.template-form-page{max-width:none;width:100%;padding:0}.template-edit-page{display:flex;flex-direction:column;height:100vh}.template-edit-page .page-header{flex-shrink:0;margin-bottom:0;padding:20px;background:white;border-bottom:1px solid #e9ecef}.template-edit-page .main-content{flex:1;display:flex;overflow:hidden;min-height:0}.template-edit-page .left-panel{flex:1;background:#f8f9fa;border-right:1px solid #e9ecef;display:flex;flex-direction:column;overflow:hidden}.template-edit-page .left-panel-content{flex:1;overflow-y:auto;padding:20px;min-height:0}.template-edit-page .right-panel{flex:1;background:#f8f9fa;display:flex;flex-direction:column;overflow:hidden}.template-edit-page .right-panel-content{flex:1;overflow-y:auto;padding:20px;min-height:0}.template-form .form-group{margin-bottom:15px}.template-form label{font-weight:700;display:block;margin-bottom:5px}.template-form input[type=text],.template-form textarea,.template-form select{width:100%;padding:10px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box}.template-form textarea{min-height:100px}.template-section{border:1px solid #e0e0e0;border-radius:6px;padding:20px;margin-bottom:20px;background-color:#f9f9f9}.section-header h3{margin:0;color:var(--primary-color)}.template-question{border:1px dashed #ccc;border-radius:4px;padding:15px;margin-bottom:15px;background-color:#fff}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.question-header p{margin:0;font-weight:700}.options-group{margin-top:10px;padding-left:15px}.option-item{display:flex;align-items:flex-start;margin-bottom:12px;padding:8px;border:1px solid #e0e0e0;border-radius:4px;background-color:#fafafa}.option-item .option-content-editor{flex:1;margin-right:12px}.option-item .option-controls{display:flex;flex-direction:column;align-items:flex-end;gap:4px;min-width:120px}.option-item .option-correct-label{display:flex;align-items:center;gap:4px;font-size:12px;margin:0}.option-item .option-correct-label input[type=checkbox]{margin:0}.option-item input[type=text]{width:auto;flex-grow:1;margin-right:8px}.form-divider{margin:30px 0;border:0;border-top:1px solid #eee}.submit-button{width:100%;padding:12px;font-size:1.1em}.template-view-page .page-header .header-actions{display:flex;gap:10px}.template-description{font-size:1.1em;line-height:1.6;color:#333;background-color:#f9f9f9;padding:15px;border-radius:4px;margin-bottom:20px}.template-content h2{margin-bottom:10px;border-bottom:1px solid #eee;padding-bottom:5px}.template-section-view{margin-bottom:20px;padding:15px;background-color:#fff;border:1px solid #ddd;border-radius:6px}.template-section-view h3{margin-top:0;color:var(--primary-color)}.questions-list{list-style:none;padding-left:0}.question-item-view{margin-bottom:10px;padding-bottom:10px;border-bottom:1px dotted #eee}.question-item-view:last-child{border-bottom:none}.question-item-view p strong{font-size:1.05em}.options-list-view{list-style:disc;padding-left:30px;margin-top:5px;font-size:.95em}.options-list-view li{margin-bottom:3px}.template-metadata-view{margin-top:30px;padding-top:15px;border-top:1px solid #eee;font-size:.9em;color:#555}.template-metadata-view p{margin:5px 0}.back-link{display:inline-block;margin-top:20px;color:var(--primary-color);text-decoration:none}.skills-management-section{margin-top:30px;padding:20px;background-color:#fdfdfd;border:1px solid #e0e0e0;border-radius:6px}.skills-management-section h2{color:var(--primary-color);margin-top:0;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid #eee}.add-skill-form{display:flex;gap:10px;align-items:center;margin-bottom:20px}.add-skill-form label{font-weight:400;margin-bottom:0}.add-skill-form input[type=text]{flex-grow:1}.add-skill-form .add-button-small{margin-top:0;white-space:nowrap}.skills-list{list-style:none;padding:0}.skill-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;border:1px solid #eee;border-radius:4px;margin-bottom:10px;background-color:#fff}.skill-name{font-weight:500;flex-grow:1}.skill-meta{font-size:.85em;color:#555;margin:0 15px;min-width:150px}.skill-actions{display:flex;gap:8px;flex-shrink:0}.skill-actions .button-small,.skill-actions .remove-button-small{padding:6px 10px}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background-color:#fff;padding:25px;border-radius:8px;box-shadow:0 5px 15px #0000004d;width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.modal.modal-large{max-width:1200px;width:95%;max-height:95vh}.modal.curriculum-linker-modal{max-width:1400px;width:95%;max-height:95vh;padding:30px}.modal h3{margin-top:0;color:var(--primary-color);margin-bottom:20px}.modal .form-group{margin-bottom:15px}.modal .modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:25px;padding-top:15px;border-top:1px solid #eee}.modal .button-primary,.modal .button-secondary{padding:10px 15px;border:none;border-radius:4px;cursor:pointer}.modal .button-primary{background-color:var(--primary-color);color:#fff}.modal .button-secondary{background-color:#6c757d;color:#fff}.modal .button-primary:hover,.modal .button-secondary:hover{opacity:.85}.curriculum-strand-list{max-height:var(--curriculum-strand-list-max-height, 600px);overflow-y:auto;border:1px solid #eee;padding:10px;border-radius:4px;margin-top:10px;margin-bottom:15px}.curriculum-strand-item{display:flex;align-items:flex-start;padding:8px 0;border-bottom:1px solid #f5f5f5}.curriculum-strand-item:last-child{border-bottom:none}.curriculum-strand-item input[type=checkbox]{margin-right:10px;margin-top:4px}.curriculum-strand-item label{font-weight:400;font-size:.95em;flex-grow:1}.curriculum-strand-item label .strand-description{font-size:.9em;color:#555;margin-top:3px;padding-left:5px}.minimal-section{padding:15px;background-color:#f9f9f980}.minimal-section .section-header h3{font-size:1.1em}.form-hint{font-size:.9em;color:#555;margin-bottom:15px;background-color:#eef;padding:8px;border-radius:4px;border-left:3px solid var(--primary-color)}.multi-select-skills{min-height:100px}.form-hint-small{font-size:.85em;color:#666;margin-top:5px}.react-resizable-handle{position:absolute;width:10px;height:100%;background:#ddd;cursor:ew-resize;right:0;top:0}.field-help{display:block;margin-top:4px;font-size:.875rem;color:#6b7280;font-style:italic}.form-group .field-help{margin-top:4px}.form-section{margin:20px 0;padding:20px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.form-section h3{margin:0 0 15px;color:var(--primary-color);font-size:1.1em}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:15px}.checkbox-label{display:flex;align-items:center;gap:8px;font-weight:400;cursor:pointer}.checkbox-label input[type=checkbox]{margin:0;cursor:pointer}.color-input-group{display:flex;align-items:center;gap:8px}.color-input-group input[type=color]{width:50px;height:40px;border:1px solid #ced4da;border-radius:4px;cursor:pointer}.color-input-group input[type=text]{flex:1;padding:8px 12px;border:1px solid #ced4da;border-radius:4px;font-family:monospace;font-size:14px}.field-help{display:block;margin-top:4px;font-size:.85em;color:#6c757d;font-style:italic}.form-divider{margin:30px 0;border:none;border-top:2px solid #e9ecef}.branding-info{background:#e7f3ff;border:1px solid #b3d8ff;border-radius:6px;padding:15px;margin-bottom:20px}.branding-info p{margin:0;color:#1e40af;font-size:.9em;line-height:1.4}.branding-info strong{color:#1e3a8a}.preview-cover-page{page-break-after:always;background:white;border:none;border-radius:0;padding:0;margin-bottom:0;text-align:center;min-height:600px;display:flex;flex-direction:column;justify-content:center}.preview-page .preview-cover-page{background:transparent}.cover-page-header{margin-bottom:40px}.cover-logo{margin-bottom:20px}.school-name{font-size:2.5em;font-weight:700;color:var(--primary-color);margin:20px 0}.cover-page-content{flex:1;display:flex;flex-direction:column;justify-content:center}.assessment-title{font-size:2em;margin:20px 0;color:#333}.assessment-subtitle{font-size:1.2em;color:#666;margin:10px 0;font-style:italic}.cover-meta{margin-top:40px;font-size:.9em;color:#666}.cover-meta p{margin:5px 0}.preview-assessment-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#f8f9fa;border-bottom:2px solid #e9ecef;margin-bottom:20px;border-radius:4px}.header-content{display:flex;align-items:center;gap:15px}.header-content.left{justify-content:flex-start}.header-content.center{justify-content:center}.header-content.right{justify-content:flex-end}.header-logo{max-height:40px;max-width:120px}.header-school-name{font-weight:700;color:var(--primary-color);font-size:1.1em}.page-number{font-size:.9em;color:#666;font-weight:500}.chart-table-display{width:100%;border-collapse:collapse;margin:10px 0}.chart-table-display table{width:100%;border:1px solid #ddd;border-collapse:collapse}.chart-table-display th,.chart-table-display td{border:1px solid #ddd;padding:8px 12px;text-align:left}.chart-table-display th{background-color:#f8f9fa;font-weight:700;color:#333}.chart-table-display tr:nth-child(2n){background-color:#f9f9f9}.chart-table-display tr:hover{background-color:#f5f5f5}.linked-curriculum-preview{position:relative;display:inline-block}.link-count{color:#666;font-size:.9em;cursor:help}.curriculum-links-tooltip{position:absolute;bottom:100%;left:0;background:white;border:1px solid #ddd;border-radius:6px;padding:8px 12px;box-shadow:0 4px 12px #00000026;min-width:300px;max-width:400px;z-index:1000;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;pointer-events:none}.linked-curriculum-preview:hover .curriculum-links-tooltip{opacity:1;visibility:visible}.curriculum-link-item{padding:6px 0;border-bottom:1px solid #f0f0f0;font-size:.85em}.curriculum-code{font-weight:700;color:#2563eb;margin-bottom:2px}.curriculum-path{color:#333;line-height:1.3;font-size:.8em}.curriculum-link-item:last-child{border-bottom:none}.more-links{margin-top:6px;padding-top:6px;border-top:1px solid #e0e0e0;font-size:.8em;color:#666;font-style:italic}.question-skills-manager{border:1px solid #ddd;border-radius:6px;padding:12px;background-color:#fafafa}.skills-list{margin-bottom:12px}.skill-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:white;border:1px solid #e0e0e0;border-radius:4px;margin-bottom:8px}.skill-item:last-child{margin-bottom:0}.skill-item.single-skill{justify-content:space-between}.skill-name{flex:1;font-weight:500;color:#333}.skill-weight-input{width:80px;padding:4px 8px;border:1px solid #ccc;border-radius:3px;text-align:center;font-size:.9em}.skill-weight-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #2563eb1a}.skill-marks-input{width:60px;padding:4px 8px;border:1px solid #ccc;border-radius:3px;text-align:center;font-size:.9em}.skill-marks-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #2563eb1a}.marks-label{font-size:.8em;color:#666;margin-left:4px;margin-right:8px}.skill-marks-total{font-size:.85em;color:#666;margin-top:8px;padding:6px 10px;background:#f8f9fa;border-radius:4px}.skill-marks-total .marks-warning{color:#dc3545;font-weight:500}.remove-skill-button{background:#dc3545;color:#fff;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;font-weight:700;transition:background-color .2s ease}.remove-skill-button:hover{background:#c82333}.skill-management-buttons{display:flex;gap:8px;flex-wrap:wrap}.add-skill-select,.add-skill-button,.auto-distribute-button{background-color:var(--primary-color);color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:.9em;transition:opacity .2s ease}.add-skill-select{background-color:#f8f9fa;color:#333;border:1px solid #ddd;min-width:150px}.add-skill-select:hover{background-color:#e9ecef;border-color:var(--primary-color)}.add-skill-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #2563eb1a}.add-skill-button:hover,.auto-distribute-button:hover{opacity:.9}.add-skill-select:disabled,.add-skill-button:disabled,.auto-distribute-button:disabled{opacity:.5;cursor:not-allowed}.no-skills-message{color:#666;font-style:italic;margin:8px 0;font-size:.9em}.question-curriculum-linker{display:none!important}.sticky-stats{position:sticky;top:0;background:white;border:2px solid #2563eb;border-radius:8px;padding:15px;margin-bottom:20px;box-shadow:0 4px 12px #0000001a;z-index:10}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-top:10px}.stats-section{background:#f8f9fa;padding:10px;border-radius:6px;border:1px solid #e9ecef}.stats-section h4{margin:0 0 8px;color:#2563eb;font-size:.9em;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stats-section p{margin:4px 0;font-size:.85em;color:#333}.stats-section strong{color:#2563eb}.difficulty-breakdown p{margin:2px 0;font-size:.8em}.no-data{color:#6c757d;font-style:italic;font-size:.8em}.right-panel{background:#f8f9fa!important}.right-panel h2{margin-top:0;color:#2563eb;border-bottom:2px solid #2563eb;padding-bottom:5px}.family-card{border:1px solid #ddd;border-radius:8px;overflow:hidden;transition:box-shadow .2s ease}.assessments-card{border-left:5px solid #ffc107}.library-card{border-left:5px solid #2563eb}.draft-indicator{color:#b45309;background:#fef3c7;padding:4px 8px;border-radius:4px;font-size:.8em;font-weight:700}.filters-toolbar{display:flex;gap:15px;margin-bottom:20px;background:#f8f9fa;padding:15px;border-radius:6px;align-items:center;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:8px}.filter-group label{font-weight:500;color:#555}.filter-group select{padding:6px 10px;border:1px solid #ccc;border-radius:4px;min-width:150px}.clear-filters{color:#666;text-decoration:underline;background:none;border:none;cursor:pointer;margin-left:auto}.badges{display:flex;gap:8px;align-items:center}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:.8em;font-weight:600;text-transform:uppercase}.status-draft{background-color:#ffeeba;color:#856404}.status-published{background-color:#d4edda;color:#155724}.status-pending_review{background-color:#fff3cd;color:#856404}.status-archived{background-color:#e2e3e5;color:#383d41}.subject-badge{background-color:#e9ecef;color:#495057;padding:4px 8px;border-radius:4px;font-size:.8em}.draft-alert{background-color:#fff3cd;border:1px solid #ffeeba;color:#856404;padding:10px;margin-bottom:15px;border-radius:4px;font-size:.9em;display:flex;align-items:center}.draft-alert:before{content:"✏️";margin-right:8px}.history-status{font-size:.8em;padding:2px 6px;border-radius:3px;margin-right:8px;text-transform:uppercase}.section-stimulus-block{background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);border-left:4px solid #3b82f6;padding:16px 20px;margin:12px 0 20px;border-radius:0 8px 8px 0;font-style:normal}.section-stimulus-content{line-height:1.6;color:#374151}.section-description-input{width:100%;min-height:80px;resize:vertical;font-family:inherit;font-size:.95em;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;transition:border-color .2s,box-shadow .2s}.section-description-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.section-description-input::placeholder{color:#9ca3af}.short-answer-customization{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;margin-top:10px}.short-answer-customization .form-group{flex:1;min-width:150px}.short-answer-customization label{font-weight:500;font-size:.9em;color:#374151}.short-answer-customization input[type=number],.short-answer-customization select{width:100%;padding:8px 10px;border:1px solid #d1d5db;border-radius:4px;font-size:.9em}.short-answer-customization .field-help{display:block;font-size:.8em;color:#6b7280;margin-top:4px}.answer-space.lined-style{border:1px solid #d1d5db;border-radius:4px;padding:8px 12px;background-color:#fff}.answer-space.blank-style{border:1px dashed #d1d5db;border-radius:4px;padding:8px 12px;background-color:#fafafa}.answer-space .writing-line{border-bottom:1px solid #e5e7eb;height:1.5em;margin-bottom:0}.answer-space.lined-style .writing-line{display:none}.image-layout-selector{margin-top:15px;padding:12px 16px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:6px}.image-layout-selector label{display:block;margin-bottom:6px;color:#0369a1}.image-layout-selector .layout-select{width:100%;padding:8px 12px;border:1px solid #7dd3fc;border-radius:4px;background:white;font-size:.9em;cursor:pointer}.image-layout-selector .layout-select:focus{outline:none;border-color:#0284c7;box-shadow:0 0 0 3px #0ea5e91a}.image-layout-selector .layout-help{display:block;font-size:.8em;color:#64748b;margin-top:6px}.question-image-display.layout-stack{display:flex;flex-direction:column;gap:10px}.question-image-display.layout-row{display:flex;flex-direction:row;gap:10px;flex-wrap:wrap;align-items:flex-start}.question-image-display.layout-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.question-image-display .image-layout-item{display:flex;flex-direction:column}.question-image-display.layout-row .image-layout-item{flex:1 1 auto;max-width:48%}.question-image-display.layout-grid .image-layout-item{width:100%}.lead-space-control{margin-top:15px;margin-bottom:10px}.lead-space-control label{display:block;margin-bottom:6px;font-weight:500;color:#374151}.lead-space-control input[type=number]{width:100px;padding:8px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:.95em}.lead-space-control input[type=number]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.lead-space-control .field-help{display:block;font-size:.8em;color:#6b7280;margin-top:4px}.question-lead-space{display:block;width:100%;background-color:transparent}.short-answer-customization .form-row{display:flex;gap:20px;flex-wrap:wrap}.short-answer-customization .form-row .form-group{flex:1;min-width:150px}@font-face{font-family:KaTeX_AMS;font-style:normal;font-weight:400;src:url(/assets/KaTeX_AMS-Regular-0cdd387c.woff2) format("woff2"),url(/assets/KaTeX_AMS-Regular-30da91e8.woff) format("woff"),url(/assets/KaTeX_AMS-Regular-68534840.ttf) format("truetype")}@font-face{font-family:KaTeX_Caligraphic;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Caligraphic-Bold-de7701e4.woff2) format("woff2"),url(/assets/KaTeX_Caligraphic-Bold-1ae6bd74.woff) format("woff"),url(/assets/KaTeX_Caligraphic-Bold-07d8e303.ttf) format("truetype")}@font-face{font-family:KaTeX_Caligraphic;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Caligraphic-Regular-5d53e70a.woff2) format("woff2"),url(/assets/KaTeX_Caligraphic-Regular-3398dd02.woff) format("woff"),url(/assets/KaTeX_Caligraphic-Regular-ed0b7437.ttf) format("truetype")}@font-face{font-family:KaTeX_Fraktur;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Fraktur-Bold-74444efd.woff2) format("woff2"),url(/assets/KaTeX_Fraktur-Bold-9be7ceb8.woff) format("woff"),url(/assets/KaTeX_Fraktur-Bold-9163df9c.ttf) format("truetype")}@font-face{font-family:KaTeX_Fraktur;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Fraktur-Regular-51814d27.woff2) format("woff2"),url(/assets/KaTeX_Fraktur-Regular-5e28753b.woff) format("woff"),url(/assets/KaTeX_Fraktur-Regular-1e6f9579.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Main-Bold-0f60d1b8.woff2) format("woff2"),url(/assets/KaTeX_Main-Bold-c76c5d69.woff) format("woff"),url(/assets/KaTeX_Main-Bold-138ac28d.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Main-BoldItalic-99cd42a3.woff2) format("woff2"),url(/assets/KaTeX_Main-BoldItalic-a6f7ec0d.woff) format("woff"),url(/assets/KaTeX_Main-BoldItalic-70ee1f64.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Main-Italic-97479ca6.woff2) format("woff2"),url(/assets/KaTeX_Main-Italic-f1d6ef86.woff) format("woff"),url(/assets/KaTeX_Main-Italic-0d85ae7c.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Main-Regular-c2342cd8.woff2) format("woff2"),url(/assets/KaTeX_Main-Regular-c6368d87.woff) format("woff"),url(/assets/KaTeX_Main-Regular-d0332f52.ttf) format("truetype")}@font-face{font-family:KaTeX_Math;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Math-BoldItalic-dc47344d.woff2) format("woff2"),url(/assets/KaTeX_Math-BoldItalic-850c0af5.woff) format("woff"),url(/assets/KaTeX_Math-BoldItalic-f9377ab0.ttf) format("truetype")}@font-face{font-family:KaTeX_Math;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Math-Italic-7af58c5e.woff2) format("woff2"),url(/assets/KaTeX_Math-Italic-8a8d2445.woff) format("woff"),url(/assets/KaTeX_Math-Italic-08ce98e5.ttf) format("truetype")}@font-face{font-family:KaTeX_SansSerif;font-style:normal;font-weight:700;src:url(/assets/KaTeX_SansSerif-Bold-e99ae511.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Bold-ece03cfd.woff) format("woff"),url(/assets/KaTeX_SansSerif-Bold-1ece03f7.ttf) format("truetype")}@font-face{font-family:KaTeX_SansSerif;font-style:italic;font-weight:400;src:url(/assets/KaTeX_SansSerif-Italic-00b26ac8.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Italic-91ee6750.woff) format("woff"),url(/assets/KaTeX_SansSerif-Italic-3931dd81.ttf) format("truetype")}@font-face{font-family:KaTeX_SansSerif;font-style:normal;font-weight:400;src:url(/assets/KaTeX_SansSerif-Regular-68e8c73e.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Regular-11e4dc8a.woff) format("woff"),url(/assets/KaTeX_SansSerif-Regular-f36ea897.ttf) format("truetype")}@font-face{font-family:KaTeX_Script;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Script-Regular-036d4e95.woff2) format("woff2"),url(/assets/KaTeX_Script-Regular-d96cdf2b.woff) format("woff"),url(/assets/KaTeX_Script-Regular-1c67f068.ttf) format("truetype")}@font-face{font-family:KaTeX_Size1;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size1-Regular-6b47c401.woff2) format("woff2"),url(/assets/KaTeX_Size1-Regular-c943cc98.woff) format("woff"),url(/assets/KaTeX_Size1-Regular-95b6d2f1.ttf) format("truetype")}@font-face{font-family:KaTeX_Size2;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size2-Regular-d04c5421.woff2) format("woff2"),url(/assets/KaTeX_Size2-Regular-2014c523.woff) format("woff"),url(/assets/KaTeX_Size2-Regular-a6b2099f.ttf) format("truetype")}@font-face{font-family:KaTeX_Size3;font-style:normal;font-weight:400;src:url(data:font/woff2;base64,d09GMgABAAAAAA4oAA4AAAAAHbQAAA3TAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAABmAAgRQIDgmcDBEICo1oijYBNgIkA14LMgAEIAWJAAeBHAyBHBvbGiMRdnO0IkRRkiYDgr9KsJ1NUAf2kILNxgUmgqIgq1P89vcbIcmsQbRps3vCcXdYOKSWEPEKgZgQkprQQsxIXUgq0DqpGKmIvrgkeVGtEQD9DzAO29fM9jYhxZEsL2FeURH2JN4MIcTdO049NCVdxQ/w9NrSYFEBKTDKpLKfNkCGDc1RwjZLQcm3vqJ2UW9Xfa3tgAHz6ivp6vgC2yD4/6352ndnN0X0TL7seypkjZlMsjmZnf0Mm5Q+JykRWQBKCVCVPbARPXWyQtb5VgLB6Biq7/Uixcj2WGqdI8tGSgkuRG+t910GKP2D7AQH0DB9FMDW/obJZ8giFI3Wg8Cvevz0M+5m0rTh7XDBlvo9Y4vm13EXmfttwI4mBo1EG15fxJhUiCLbiiyCf/ZA6MFAhg3pGIZGdGIVjtPn6UcMk9A/UUr9PhoNsCENw1APAq0gpH73e+M+0ueyHbabc3vkbcdtzcf/fiy+NxQEjf9ud/ELBHAXJ0nk4z+MXH2Ev/kWyV4k7SkvpPc9Qr38F6RPWnM9cN6DJ0AdD1BhtgABtmoRoFCvPsBAumNm6soZG2Gk5GyVTo2sJncSyp0jQTYoR6WDvTwaaEcHsxHfvuWhHA3a6bN7twRKtcGok6NsCi7jYRrM2jExsUFMxMQYuJbMhuWNOumEJy9hi29Dmg5zMp/A5+hhPG19j1vBrq8JTLr8ki5VLPmG/PynJHVul440bxg5xuymHUFPBshC+nA9I1FmwbRBTNHAcik3Oae0cxKoI3MOriM42UrPe51nsaGxJ+WfXubAsP84aabUlQSJ1IiE0iPETLUU4CATgfXSCSpuRFRmCGbO+wSpAnzaeaCYW1VNEysRtuXCEL1kUFUbbtMv3Tilt/1c11jt3Q5bbMa84cpWipp8Elw3MZhOHsOlwwVUQM3lAR35JiFQbaYCRnMF2lxAWoOg2gyoIV4PouX8HytNIfLhqpJtXB4vjiViUI8IJ7bkC4ikkQvKksnOTKICwnqWSZ9YS5f0WCxmpgjbIq7EJcM4aI2nmhLNY2JIUgOjXZFWBHb+x5oh6cwb0Tv1ackHdKi0I9OO2wE9aogIOn540CCCziyhN+IaejtgAONKznHlHyutPrHGwCx9S6B8kfS4Mfi4Eyv7OU730bT1SCBjt834cXsf43zVjPUqqJjgrjeGnBxSG4aYAKFuVbeCfkDIjAqMb6yLNIbCuvXhMH2/+k2vkNpkORhR59N1CkzoOENvneIosjYmuTxlhUzaGEJQ/iWqx4dmwpmKjrwTiTGTCVozNAYqk/zXOndWxuWSmJkQpJw3pK5KX6QrLt5LATMqpmPAQhkhK6PUjzHUn7E0gHE0kPE0iKkolgkUx9SZmVAdDgpffdyJKg3k7VmzYGCwVXGz/tXmkOIp+vcWs+EMuhhvN0h9uhfzWJziBQmCREGSIFmQIkgVpAnSBRmC//6hkLZwaVhwxlrJSOdqlFtOYxlau9F2QN5Y98xmIAsiM1HVp2VFX+DHHGg6Ecjh3vmqtidX3qHI2qycTk/iwxSt5UzTmEP92ZBnEWTk4Mx8Mpl78ZDokxg/KWb+Q0QkvdKVmq3TMW+RXEgrsziSAfNXFMhDc60N5N9jQzjfO0kBKpUZl0ZmwJ41j/B9Hz6wmRaJB84niNmQrzp9eSlQCDDzazGDdVi3P36VZQ+Jy4f9UBNp+3zTjqI4abaFAm+GShVaXlsGdF3FYzZcDI6cori4kMxUECl9IjJZpzkvitAoxKue+90pDMvcKRxLl53TmOKCmV/xRolNKSqqUxc6LStOETmFOiLZZptlZepcKiAzteG8PEdpnQpbOMNcMsR4RR2Bs0cKFEvSmIjAFcnarqwUL4lDhHmnVkwu1IwshbiCcgvOheZuYyOteufZZwlcTlLgnZ3o/WcYdzZHW/WGaqaVfmTZ1aWCceJjkbZqsfbkOtcFlUZM/jy+hXHDbaUobWqqXaeWobbLO99yG5N3U4wxco0rQGGcOLASFMXeJoham8M+/x6O2WywK2l4HGbq1CoUyC/IZikQhdq3SiuNrvAEj0AVu9x2x3lp/xWzahaxidezFVtdcb5uEnzyl0ZmYiuKI0exvCd4Xc9CV1KB0db00z92wDPde0kukbvZIWN6jUWFTmPIC/Y4UPCm8UfDTFZpZNon1qLFTkBhxzB+FjQRA2Q/YRJT8pQigslMaUpFyAG8TMlXigiqmAZX4xgijKjRlGpLE0GdplRfCaJo0JQaSxNBk6ZmMzcya0FmrcisDdn0Q3HI2sWSppYigmlM1XT/kLQZSNpMJG0WkjYbSZuDpM1F0uYhFc1HxU4m1QJjDK6iL0S5uSj5rgXc3RejEigtcRBtqYPQsiTskmO5vosV+q4VGIKbOkDg0jtRrq+Em1YloaTFar3EGr1EUC8R0kus1Uus00usL97ABr2BjXoDm/QGNhuWtMVBKOwg/i78lT7hBsAvDmwHc/ao3vmUbBmhjeYySZNWvGkfZAgISDSaDo1SVpzGDsAEkF8B+gEapViUoZgUWXcRIGFZNm6gWbAKk0bp0k1MHG9fLYtV4iS2SmLEQFARzRcnf9PUS0LVn05/J9MiRRBU3v2IrvW974v4N00L7ZMk0wXP1409CHo/an8zTRHD3eSJ6m8D4YMkZNl3M79sqeuAsr/m3f+8/yl7A50aiAEJgeBeMWzu7ui9UfUBCe2TIqZIoOd/3/udRBOQidQZUERzb2/VwZN1H/Sju82ew2H2Wfr6qvfVf3hqwDvAIpkQVFy4B9Pe9e4/XvPeceu7h3dvO56iJPf0+A6cqA2ip18ER+iFgggiuOkvj24bby0N9j2UHIkgqIt+sVgfodC4YghLSMjSZbH0VR/6dMDrYJeKHilKTemt6v6kvzvn3/RrdWtr0GoN/xL+Sex/cPYLUpepx9cz/D46UPU5KXgAQa+NDps1v6J3xP1i2HtaDB0M9aX2deA7SYff//+gUCovMmIK/qfsFcOk+4Y5ZN97XlG6zebqtMbKgeRFi51vnxTQYBUik2rS/Cn6PC8ADR8FGxsRPB82dzfND90gIcshOcYUkfjherBz53odpm6TP8txlwOZ71xmfHHOvq053qFF/MRlS3jP0ELudrf2OeN8DHvp6ZceLe8qKYvWz/7yp0u4dKPfli3CYq0O13Ih71mylJ80tOi10On8wi+F4+LWgDPeJ30msSQt9/vkmHq9/Lvo2b461mP801v3W4xTcs6CbvF9UDdrSt+A8OUbpSh55qAUFXWznBBfdeJ8a4d7ugT5tvxUza3h9m4H7ptTqiG4z0g5dc0X29OcGlhpGFMpQo9ytTS+NViZpNdvU4kWx+LKxNY10kQ1yqGXrhe4/1nvP7E+nd5A92TtaRplbHSqoIdOqtRWti+fkB5/n1+/VvCmz12pG1kpQWsfi1ftlBobm0bpngs16CHkbIwdLnParxtTV3QYRlfJ0KFskH7pdN/YDn+yRuSd7sNH3aO0DYPggk6uWuXrfOc+fa3VTxFVvKaNxHsiHmsXyCLIE5yuOeN3/Jdf8HBL/5M6shjyhxHx9BjB1O0+4NLOnjLLSxwO7ukN4jMbOIcD879KLSi6Pk61Oqm2377n8079PXEEQ7cy7OKEC9nbpet118fxweTafpt69x/Bt8UqGzNQt7aelpc44dn5cqhwf71+qKp/Zf/+a0zcizOUWpl/iBcSXip0pplkatCchoH5c5aUM8I7/dWxAej8WicPL1URFZ9BDJelUwEwTkGqUhgSlydVes95YdXvhh9Gfz/aeFWvgVb4tuLbcv4+wLdutVZv/cUonwBD/6eDlE0aSiKK/uoH3+J1wDE/jMVqY2ysGufN84oIXB0sPzy8ollX/LegY74DgJXJR57sn+VGza0x3DnuIgABFM15LmajjjsNlYj+JEZGbuRYcAMOWxFkPN2w6Wd46xo4gVWQR/X4lyI/R6K/YK0110GzudPRW7Y+UOBGTfNNzHeYT0fiH0taunBpq9HEW8OKSaBGj21L0MqenEmNRWBAWDWAk4CpNoEZJ2tTaPFgbQYj8HxtFilErs3BTRwT8uO1NXQaWfIotchmPkAF5mMBAliEmZiOGVgCG9LgRzpscMAOOwowlT3JhusdazXGSC/hxR3UlmWVwWHpOIKheqONvjyhSiTHIkVUco5bnji8m//zL7PKaT1Vl5I6UE609f+gkr6MZKVyKc7zJRmCahLsdlyA5fdQkRSan9LgnnLEyGSkaKJCJog0wAgvepWBt80+1yKln1bMVtCljfNWDueKLsWwaEbBSfSPTEmVRsUcYYMnEjcjeyCZzBXK9E9BYBXLKjOSpUDR+nEV3TFSUdQaz+ot98QxgXwx0GQ+EEUAKB2qZPkQQ0GqFD8UPFMqyaCHM24BZmSGic9EYMagKizOw9Hz50DMrDLrqqLkTAhplMictiCAx5S3BIUQdeJeLnBy2CNtMfz6cV4u8XKoFZQesbf9YZiIERiHjaNodDW6LgcirX/mPnJIkBGDUpTBhSa0EIr38D5hCIszhCM8URGBqImoWjpvpt1ebu/v3Gl3qJfMnNM+9V+kiRFyROTPHQWOcs1dNW94/ukKMPZBvDi55i5CttdeJz84DLngLqjcdwEZ87bFFR8CIG35OAkDVN6VRDZ7aq67NteYqZ2lpT8oYB2CytoBd6VuAx4WgiAsnuj3WohG+LugzXiQRDeM3XYXlULv4dp5VFYC) format("woff2"),url(/assets/KaTeX_Size3-Regular-6ab6b62e.woff) format("woff"),url(/assets/KaTeX_Size3-Regular-500e04d5.ttf) format("truetype")}@font-face{font-family:KaTeX_Size4;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size4-Regular-a4af7d41.woff2) format("woff2"),url(/assets/KaTeX_Size4-Regular-99f9c675.woff) format("woff"),url(/assets/KaTeX_Size4-Regular-c647367d.ttf) format("truetype")}@font-face{font-family:KaTeX_Typewriter;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Typewriter-Regular-71d517d6.woff2) format("woff2"),url(/assets/KaTeX_Typewriter-Regular-e14fed02.woff) format("woff"),url(/assets/KaTeX_Typewriter-Regular-f01f3e87.ttf) format("truetype")}.katex{font: 1.21em KaTeX_Main,Times New Roman,serif;line-height:1.2;text-indent:0;text-rendering:auto}.katex *{-ms-high-contrast-adjust:none!important;border-color:currentColor}.katex .katex-version:after{content:"0.16.22"}.katex .katex-mathml{clip:rect(1px,1px,1px,1px);border:0;height:1px;overflow:hidden;padding:0;position:absolute;width:1px}.katex .katex-html>.newline{display:block}.katex .base{position:relative;white-space:nowrap;width:-webkit-min-content;width:-moz-min-content;width:min-content}.katex .base,.katex .strut{display:inline-block}.katex .textbf{font-weight:700}.katex .textit{font-style:italic}.katex .textrm{font-family:KaTeX_Main}.katex .textsf{font-family:KaTeX_SansSerif}.katex .texttt{font-family:KaTeX_Typewriter}.katex .mathnormal{font-family:KaTeX_Math;font-style:italic}.katex .mathit{font-family:KaTeX_Main;font-style:italic}.katex .mathrm{font-style:normal}.katex .mathbf{font-family:KaTeX_Main;font-weight:700}.katex .boldsymbol{font-family:KaTeX_Math;font-style:italic;font-weight:700}.katex .amsrm,.katex .mathbb,.katex .textbb{font-family:KaTeX_AMS}.katex .mathcal{font-family:KaTeX_Caligraphic}.katex .mathfrak,.katex .textfrak{font-family:KaTeX_Fraktur}.katex .mathboldfrak,.katex .textboldfrak{font-family:KaTeX_Fraktur;font-weight:700}.katex .mathtt{font-family:KaTeX_Typewriter}.katex .mathscr,.katex .textscr{font-family:KaTeX_Script}.katex .mathsf,.katex .textsf{font-family:KaTeX_SansSerif}.katex .mathboldsf,.katex .textboldsf{font-family:KaTeX_SansSerif;font-weight:700}.katex .mathitsf,.katex .mathsfit,.katex .textitsf{font-family:KaTeX_SansSerif;font-style:italic}.katex .mainrm{font-family:KaTeX_Main;font-style:normal}.katex .vlist-t{border-collapse:collapse;display:inline-table;table-layout:fixed}.katex .vlist-r{display:table-row}.katex .vlist{display:table-cell;position:relative;vertical-align:bottom}.katex .vlist>span{display:block;height:0;position:relative}.katex .vlist>span>span{display:inline-block}.katex .vlist>span>.pstrut{overflow:hidden;width:0}.katex .vlist-t2{margin-right:-2px}.katex .vlist-s{display:table-cell;font-size:1px;min-width:2px;vertical-align:bottom;width:2px}.katex .vbox{align-items:baseline;display:inline-flex;flex-direction:column}.katex .hbox{width:100%}.katex .hbox,.katex .thinbox{display:inline-flex;flex-direction:row}.katex .thinbox{max-width:0;width:0}.katex .msupsub{text-align:left}.katex .mfrac>span>span{text-align:center}.katex .mfrac .frac-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline,.katex .hline,.katex .mfrac .frac-line,.katex .overline .overline-line,.katex .rule,.katex .underline .underline-line{min-height:1px}.katex .mspace{display:inline-block}.katex .clap,.katex .llap,.katex .rlap{position:relative;width:0}.katex .clap>.inner,.katex .llap>.inner,.katex .rlap>.inner{position:absolute}.katex .clap>.fix,.katex .llap>.fix,.katex .rlap>.fix{display:inline-block}.katex .llap>.inner{right:0}.katex .clap>.inner,.katex .rlap>.inner{left:0}.katex .clap>.inner>span{margin-left:-50%;margin-right:50%}.katex .rule{border:0 solid;display:inline-block;position:relative}.katex .hline,.katex .overline .overline-line,.katex .underline .underline-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline{border-bottom-style:dashed;display:inline-block;width:100%}.katex .sqrt>.root{margin-left:.2777777778em;margin-right:-.5555555556em}.katex .fontsize-ensurer.reset-size1.size1,.katex .sizing.reset-size1.size1{font-size:1em}.katex .fontsize-ensurer.reset-size1.size2,.katex .sizing.reset-size1.size2{font-size:1.2em}.katex .fontsize-ensurer.reset-size1.size3,.katex .sizing.reset-size1.size3{font-size:1.4em}.katex .fontsize-ensurer.reset-size1.size4,.katex .sizing.reset-size1.size4{font-size:1.6em}.katex .fontsize-ensurer.reset-size1.size5,.katex .sizing.reset-size1.size5{font-size:1.8em}.katex .fontsize-ensurer.reset-size1.size6,.katex .sizing.reset-size1.size6{font-size:2em}.katex .fontsize-ensurer.reset-size1.size7,.katex .sizing.reset-size1.size7{font-size:2.4em}.katex .fontsize-ensurer.reset-size1.size8,.katex .sizing.reset-size1.size8{font-size:2.88em}.katex .fontsize-ensurer.reset-size1.size9,.katex .sizing.reset-size1.size9{font-size:3.456em}.katex .fontsize-ensurer.reset-size1.size10,.katex .sizing.reset-size1.size10{font-size:4.148em}.katex .fontsize-ensurer.reset-size1.size11,.katex .sizing.reset-size1.size11{font-size:4.976em}.katex .fontsize-ensurer.reset-size2.size1,.katex .sizing.reset-size2.size1{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size2.size2,.katex .sizing.reset-size2.size2{font-size:1em}.katex .fontsize-ensurer.reset-size2.size3,.katex .sizing.reset-size2.size3{font-size:1.1666666667em}.katex .fontsize-ensurer.reset-size2.size4,.katex .sizing.reset-size2.size4{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size2.size5,.katex .sizing.reset-size2.size5{font-size:1.5em}.katex .fontsize-ensurer.reset-size2.size6,.katex .sizing.reset-size2.size6{font-size:1.6666666667em}.katex .fontsize-ensurer.reset-size2.size7,.katex .sizing.reset-size2.size7{font-size:2em}.katex .fontsize-ensurer.reset-size2.size8,.katex .sizing.reset-size2.size8{font-size:2.4em}.katex .fontsize-ensurer.reset-size2.size9,.katex .sizing.reset-size2.size9{font-size:2.88em}.katex .fontsize-ensurer.reset-size2.size10,.katex .sizing.reset-size2.size10{font-size:3.4566666667em}.katex .fontsize-ensurer.reset-size2.size11,.katex .sizing.reset-size2.size11{font-size:4.1466666667em}.katex .fontsize-ensurer.reset-size3.size1,.katex .sizing.reset-size3.size1{font-size:.7142857143em}.katex .fontsize-ensurer.reset-size3.size2,.katex .sizing.reset-size3.size2{font-size:.8571428571em}.katex .fontsize-ensurer.reset-size3.size3,.katex .sizing.reset-size3.size3{font-size:1em}.katex .fontsize-ensurer.reset-size3.size4,.katex .sizing.reset-size3.size4{font-size:1.1428571429em}.katex .fontsize-ensurer.reset-size3.size5,.katex .sizing.reset-size3.size5{font-size:1.2857142857em}.katex .fontsize-ensurer.reset-size3.size6,.katex .sizing.reset-size3.size6{font-size:1.4285714286em}.katex .fontsize-ensurer.reset-size3.size7,.katex .sizing.reset-size3.size7{font-size:1.7142857143em}.katex .fontsize-ensurer.reset-size3.size8,.katex .sizing.reset-size3.size8{font-size:2.0571428571em}.katex .fontsize-ensurer.reset-size3.size9,.katex .sizing.reset-size3.size9{font-size:2.4685714286em}.katex .fontsize-ensurer.reset-size3.size10,.katex .sizing.reset-size3.size10{font-size:2.9628571429em}.katex .fontsize-ensurer.reset-size3.size11,.katex .sizing.reset-size3.size11{font-size:3.5542857143em}.katex .fontsize-ensurer.reset-size4.size1,.katex .sizing.reset-size4.size1{font-size:.625em}.katex .fontsize-ensurer.reset-size4.size2,.katex .sizing.reset-size4.size2{font-size:.75em}.katex .fontsize-ensurer.reset-size4.size3,.katex .sizing.reset-size4.size3{font-size:.875em}.katex .fontsize-ensurer.reset-size4.size4,.katex .sizing.reset-size4.size4{font-size:1em}.katex .fontsize-ensurer.reset-size4.size5,.katex .sizing.reset-size4.size5{font-size:1.125em}.katex .fontsize-ensurer.reset-size4.size6,.katex .sizing.reset-size4.size6{font-size:1.25em}.katex .fontsize-ensurer.reset-size4.size7,.katex .sizing.reset-size4.size7{font-size:1.5em}.katex .fontsize-ensurer.reset-size4.size8,.katex .sizing.reset-size4.size8{font-size:1.8em}.katex .fontsize-ensurer.reset-size4.size9,.katex .sizing.reset-size4.size9{font-size:2.16em}.katex .fontsize-ensurer.reset-size4.size10,.katex .sizing.reset-size4.size10{font-size:2.5925em}.katex .fontsize-ensurer.reset-size4.size11,.katex .sizing.reset-size4.size11{font-size:3.11em}.katex .fontsize-ensurer.reset-size5.size1,.katex .sizing.reset-size5.size1{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size5.size2,.katex .sizing.reset-size5.size2{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size5.size3,.katex .sizing.reset-size5.size3{font-size:.7777777778em}.katex .fontsize-ensurer.reset-size5.size4,.katex .sizing.reset-size5.size4{font-size:.8888888889em}.katex .fontsize-ensurer.reset-size5.size5,.katex .sizing.reset-size5.size5{font-size:1em}.katex .fontsize-ensurer.reset-size5.size6,.katex .sizing.reset-size5.size6{font-size:1.1111111111em}.katex .fontsize-ensurer.reset-size5.size7,.katex .sizing.reset-size5.size7{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size5.size8,.katex .sizing.reset-size5.size8{font-size:1.6em}.katex .fontsize-ensurer.reset-size5.size9,.katex .sizing.reset-size5.size9{font-size:1.92em}.katex .fontsize-ensurer.reset-size5.size10,.katex .sizing.reset-size5.size10{font-size:2.3044444444em}.katex .fontsize-ensurer.reset-size5.size11,.katex .sizing.reset-size5.size11{font-size:2.7644444444em}.katex .fontsize-ensurer.reset-size6.size1,.katex .sizing.reset-size6.size1{font-size:.5em}.katex .fontsize-ensurer.reset-size6.size2,.katex .sizing.reset-size6.size2{font-size:.6em}.katex .fontsize-ensurer.reset-size6.size3,.katex .sizing.reset-size6.size3{font-size:.7em}.katex .fontsize-ensurer.reset-size6.size4,.katex .sizing.reset-size6.size4{font-size:.8em}.katex .fontsize-ensurer.reset-size6.size5,.katex .sizing.reset-size6.size5{font-size:.9em}.katex .fontsize-ensurer.reset-size6.size6,.katex .sizing.reset-size6.size6{font-size:1em}.katex .fontsize-ensurer.reset-size6.size7,.katex .sizing.reset-size6.size7{font-size:1.2em}.katex .fontsize-ensurer.reset-size6.size8,.katex .sizing.reset-size6.size8{font-size:1.44em}.katex .fontsize-ensurer.reset-size6.size9,.katex .sizing.reset-size6.size9{font-size:1.728em}.katex .fontsize-ensurer.reset-size6.size10,.katex .sizing.reset-size6.size10{font-size:2.074em}.katex .fontsize-ensurer.reset-size6.size11,.katex .sizing.reset-size6.size11{font-size:2.488em}.katex .fontsize-ensurer.reset-size7.size1,.katex .sizing.reset-size7.size1{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size7.size2,.katex .sizing.reset-size7.size2{font-size:.5em}.katex .fontsize-ensurer.reset-size7.size3,.katex .sizing.reset-size7.size3{font-size:.5833333333em}.katex .fontsize-ensurer.reset-size7.size4,.katex .sizing.reset-size7.size4{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size7.size5,.katex .sizing.reset-size7.size5{font-size:.75em}.katex .fontsize-ensurer.reset-size7.size6,.katex .sizing.reset-size7.size6{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size7.size7,.katex .sizing.reset-size7.size7{font-size:1em}.katex .fontsize-ensurer.reset-size7.size8,.katex .sizing.reset-size7.size8{font-size:1.2em}.katex .fontsize-ensurer.reset-size7.size9,.katex .sizing.reset-size7.size9{font-size:1.44em}.katex .fontsize-ensurer.reset-size7.size10,.katex .sizing.reset-size7.size10{font-size:1.7283333333em}.katex .fontsize-ensurer.reset-size7.size11,.katex .sizing.reset-size7.size11{font-size:2.0733333333em}.katex .fontsize-ensurer.reset-size8.size1,.katex .sizing.reset-size8.size1{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size8.size2,.katex .sizing.reset-size8.size2{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size8.size3,.katex .sizing.reset-size8.size3{font-size:.4861111111em}.katex .fontsize-ensurer.reset-size8.size4,.katex .sizing.reset-size8.size4{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size8.size5,.katex .sizing.reset-size8.size5{font-size:.625em}.katex .fontsize-ensurer.reset-size8.size6,.katex .sizing.reset-size8.size6{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size8.size7,.katex .sizing.reset-size8.size7{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size8.size8,.katex .sizing.reset-size8.size8{font-size:1em}.katex .fontsize-ensurer.reset-size8.size9,.katex .sizing.reset-size8.size9{font-size:1.2em}.katex .fontsize-ensurer.reset-size8.size10,.katex .sizing.reset-size8.size10{font-size:1.4402777778em}.katex .fontsize-ensurer.reset-size8.size11,.katex .sizing.reset-size8.size11{font-size:1.7277777778em}.katex .fontsize-ensurer.reset-size9.size1,.katex .sizing.reset-size9.size1{font-size:.2893518519em}.katex .fontsize-ensurer.reset-size9.size2,.katex .sizing.reset-size9.size2{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size9.size3,.katex .sizing.reset-size9.size3{font-size:.4050925926em}.katex .fontsize-ensurer.reset-size9.size4,.katex .sizing.reset-size9.size4{font-size:.462962963em}.katex .fontsize-ensurer.reset-size9.size5,.katex .sizing.reset-size9.size5{font-size:.5208333333em}.katex .fontsize-ensurer.reset-size9.size6,.katex .sizing.reset-size9.size6{font-size:.5787037037em}.katex .fontsize-ensurer.reset-size9.size7,.katex .sizing.reset-size9.size7{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size9.size8,.katex .sizing.reset-size9.size8{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size9.size9,.katex .sizing.reset-size9.size9{font-size:1em}.katex .fontsize-ensurer.reset-size9.size10,.katex .sizing.reset-size9.size10{font-size:1.2002314815em}.katex .fontsize-ensurer.reset-size9.size11,.katex .sizing.reset-size9.size11{font-size:1.4398148148em}.katex .fontsize-ensurer.reset-size10.size1,.katex .sizing.reset-size10.size1{font-size:.2410800386em}.katex .fontsize-ensurer.reset-size10.size2,.katex .sizing.reset-size10.size2{font-size:.2892960463em}.katex .fontsize-ensurer.reset-size10.size3,.katex .sizing.reset-size10.size3{font-size:.337512054em}.katex .fontsize-ensurer.reset-size10.size4,.katex .sizing.reset-size10.size4{font-size:.3857280617em}.katex .fontsize-ensurer.reset-size10.size5,.katex .sizing.reset-size10.size5{font-size:.4339440694em}.katex .fontsize-ensurer.reset-size10.size6,.katex .sizing.reset-size10.size6{font-size:.4821600771em}.katex .fontsize-ensurer.reset-size10.size7,.katex .sizing.reset-size10.size7{font-size:.5785920926em}.katex .fontsize-ensurer.reset-size10.size8,.katex .sizing.reset-size10.size8{font-size:.6943105111em}.katex .fontsize-ensurer.reset-size10.size9,.katex .sizing.reset-size10.size9{font-size:.8331726133em}.katex .fontsize-ensurer.reset-size10.size10,.katex .sizing.reset-size10.size10{font-size:1em}.katex .fontsize-ensurer.reset-size10.size11,.katex .sizing.reset-size10.size11{font-size:1.1996142719em}.katex .fontsize-ensurer.reset-size11.size1,.katex .sizing.reset-size11.size1{font-size:.2009646302em}.katex .fontsize-ensurer.reset-size11.size2,.katex .sizing.reset-size11.size2{font-size:.2411575563em}.katex .fontsize-ensurer.reset-size11.size3,.katex .sizing.reset-size11.size3{font-size:.2813504823em}.katex .fontsize-ensurer.reset-size11.size4,.katex .sizing.reset-size11.size4{font-size:.3215434084em}.katex .fontsize-ensurer.reset-size11.size5,.katex .sizing.reset-size11.size5{font-size:.3617363344em}.katex .fontsize-ensurer.reset-size11.size6,.katex .sizing.reset-size11.size6{font-size:.4019292605em}.katex .fontsize-ensurer.reset-size11.size7,.katex .sizing.reset-size11.size7{font-size:.4823151125em}.katex .fontsize-ensurer.reset-size11.size8,.katex .sizing.reset-size11.size8{font-size:.578778135em}.katex .fontsize-ensurer.reset-size11.size9,.katex .sizing.reset-size11.size9{font-size:.6945337621em}.katex .fontsize-ensurer.reset-size11.size10,.katex .sizing.reset-size11.size10{font-size:.8336012862em}.katex .fontsize-ensurer.reset-size11.size11,.katex .sizing.reset-size11.size11{font-size:1em}.katex .delimsizing.size1{font-family:KaTeX_Size1}.katex .delimsizing.size2{font-family:KaTeX_Size2}.katex .delimsizing.size3{font-family:KaTeX_Size3}.katex .delimsizing.size4{font-family:KaTeX_Size4}.katex .delimsizing.mult .delim-size1>span{font-family:KaTeX_Size1}.katex .delimsizing.mult .delim-size4>span{font-family:KaTeX_Size4}.katex .nulldelimiter{display:inline-block;width:.12em}.katex .delimcenter,.katex .op-symbol{position:relative}.katex .op-symbol.small-op{font-family:KaTeX_Size1}.katex .op-symbol.large-op{font-family:KaTeX_Size2}.katex .accent>.vlist-t,.katex .op-limits>.vlist-t{text-align:center}.katex .accent .accent-body{position:relative}.katex .accent .accent-body:not(.accent-full){width:0}.katex .overlay{display:block}.katex .mtable .vertical-separator{display:inline-block;min-width:1px}.katex .mtable .arraycolsep{display:inline-block}.katex .mtable .col-align-c>.vlist-t{text-align:center}.katex .mtable .col-align-l>.vlist-t{text-align:left}.katex .mtable .col-align-r>.vlist-t{text-align:right}.katex .svg-align{text-align:left}.katex svg{fill:currentColor;stroke:currentColor;fill-rule:nonzero;fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;display:block;height:inherit;position:absolute;width:100%}.katex svg path{stroke:none}.katex img{border-style:none;max-height:none;max-width:none;min-height:0;min-width:0}.katex .stretchy{display:block;overflow:hidden;position:relative;width:100%}.katex .stretchy:after,.katex .stretchy:before{content:""}.katex .hide-tail{overflow:hidden;position:relative;width:100%}.katex .halfarrow-left{left:0;overflow:hidden;position:absolute;width:50.2%}.katex .halfarrow-right{overflow:hidden;position:absolute;right:0;width:50.2%}.katex .brace-left{left:0;overflow:hidden;position:absolute;width:25.1%}.katex .brace-center{left:25%;overflow:hidden;position:absolute;width:50%}.katex .brace-right{overflow:hidden;position:absolute;right:0;width:25.1%}.katex .x-arrow-pad{padding:0 .5em}.katex .cd-arrow-pad{padding:0 .55556em 0 .27778em}.katex .mover,.katex .munder,.katex .x-arrow{text-align:center}.katex .boxpad{padding:0 .3em}.katex .fbox,.katex .fcolorbox{border:.04em solid;box-sizing:border-box}.katex .cancel-pad{padding:0 .2em}.katex .cancel-lap{margin-left:-.2em;margin-right:-.2em}.katex .sout{border-bottom-style:solid;border-bottom-width:.08em}.katex .angl{border-right:.049em solid;border-top:.049em solid;box-sizing:border-box;margin-right:.03889em}.katex .anglpad{padding:0 .03889em}.katex .eqn-num:before{content:"(" counter(katexEqnNo) ")";counter-increment:katexEqnNo}.katex .mml-eqn-num:before{content:"(" counter(mmlEqnNo) ")";counter-increment:mmlEqnNo}.katex .mtr-glue{width:50%}.katex .cd-vert-arrow{display:inline-block;position:relative}.katex .cd-label-left{display:inline-block;position:absolute;right:calc(50% + .3em);text-align:left}.katex .cd-label-right{display:inline-block;left:calc(50% + .3em);position:absolute;text-align:right}.katex-display{display:block;margin:1em 0;text-align:center}.katex-display>.katex{display:block;text-align:center;white-space:nowrap}.katex-display>.katex>.katex-html{display:block;position:relative}.katex-display>.katex>.katex-html>.tag{position:absolute;right:0}.katex-display.leqno>.katex>.katex-html>.tag{left:0;right:auto}.katex-display.fleqn>.katex{padding-left:2em;text-align:left}body{counter-reset:katexEqnNo mmlEqnNo}.equation-editor-container{border:1px solid #ccc;padding:10px;border-radius:4px}.editor-controls{margin-bottom:10px;display:flex;justify-content:flex-end}.mode-toggle{display:flex;border:1px solid #ccc;border-radius:4px;overflow:hidden}.mode-btn{padding:6px 12px;border:none;background-color:#f8f9fa;color:#495057;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease;border-right:1px solid #ccc}.mode-btn:last-child{border-right:none}.mode-btn:hover{background-color:#e9ecef}.mode-btn.active{background-color:#007bff;color:#fff}.equation-toolbar-container{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #eee}.equation-preview-container{margin-top:8px;padding:10px;border:1px dashed #ddd;min-height:40px;background-color:#f9f9f9}.subject-mode-selector-container{margin-bottom:8px;font-style:italic;color:#555}.toolbar-button{margin-right:5px;padding:8px 12px;border:1px solid #666;background-color:#fff;color:#333;cursor:pointer;border-radius:4px;font-weight:500;font-size:14px;box-shadow:0 1px 2px #0000001a;transition:all .2s ease}.toolbar-button:hover{background-color:#f8f9fa;border-color:#007bff;box-shadow:0 2px 4px #00000026}.toolbar-button:active{background-color:#e9ecef;transform:translateY(1px);box-shadow:0 1px 2px #0000001a}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size: 12px;--rc-drag-handle-mobile-size: 24px;--rc-drag-handle-bg-colour: rgba(0, 0, 0, .2);--rc-drag-bar-size: 6px;--rc-border-color: rgba(255, 255, 255, .7);--rc-focus-color: #0088ff}.ReactCrop{position:relative;display:inline-block;cursor:crosshair;max-width:100%}.ReactCrop *,.ReactCrop *:before,.ReactCrop *:after{box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{overflow:hidden;max-height:inherit}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-width:100%;max-height:inherit}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video{touch-action:none}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{touch-action:none}.ReactCrop__crop-mask{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;width:calc(100% + .5px);height:calc(100% + .5px)}.ReactCrop__crop-selection{position:absolute;top:0;left:0;transform:translateZ(0);cursor:move}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{pointer-events:none;content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border:1px solid var(--rc-border-color);opacity:.3}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed white}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){animation:marching-ants 1s;background-image:linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%);background-size:10px 1px,10px 1px,1px 10px,1px 10px;background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;color:#fff;animation-play-state:running;animation-timing-function:linear;animation-iteration-count:infinite}.ReactCrop__crop-selection:focus{outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{content:"";display:block;position:absolute;background-color:#fff6}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after{width:1px;height:100%}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{width:100%;height:1px}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{position:absolute;width:var(--rc-drag-handle-size);height:var(--rc-drag-handle-size);background-color:var(--rc-drag-handle-bg-colour);border:1px solid var(--rc-border-color)}.ReactCrop__drag-handle:focus{background:var(--rc-focus-color)}.ReactCrop .ord-nw{top:0;left:0;transform:translate(-50%,-50%);cursor:nw-resize}.ReactCrop .ord-n{top:0;left:50%;transform:translate(-50%,-50%);cursor:n-resize}.ReactCrop .ord-ne{top:0;right:0;transform:translate(50%,-50%);cursor:ne-resize}.ReactCrop .ord-e{top:50%;right:0;transform:translate(50%,-50%);cursor:e-resize}.ReactCrop .ord-se{bottom:0;right:0;transform:translate(50%,50%);cursor:se-resize}.ReactCrop .ord-s{bottom:0;left:50%;transform:translate(-50%,50%);cursor:s-resize}.ReactCrop .ord-sw{bottom:0;left:0;transform:translate(-50%,50%);cursor:sw-resize}.ReactCrop .ord-w{top:50%;left:0;transform:translate(-50%,-50%);cursor:w-resize}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{top:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(-50%)}.ReactCrop__drag-bar.ord-e{right:0;top:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(50%)}.ReactCrop__drag-bar.ord-s{bottom:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(50%)}.ReactCrop__drag-bar.ord-w{top:0;left:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(-50%)}.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle,.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w{display:none}@media (pointer: coarse){.ReactCrop .ord-n,.ReactCrop .ord-e,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{width:var(--rc-drag-handle-mobile-size);height:var(--rc-drag-handle-mobile-size)}}.image-gallery-icon{color:#fff;transition:all .3s ease-out;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#0000;border:0;cursor:pointer;outline:none;position:absolute;z-index:4;filter:drop-shadow(0 2px 2px rgb(25.5,25.5,25.5))}@media (hover: hover)and (pointer: fine){.image-gallery-icon:hover{color:#337ab7}.image-gallery-icon:hover .image-gallery-svg{transform:scale(1.1)}}.image-gallery-icon:focus{outline:2px solid #337ab7}.image-gallery-using-mouse .image-gallery-icon:focus{outline:none}.image-gallery-fullscreen-button,.image-gallery-play-button{bottom:0;padding:20px}.image-gallery-fullscreen-button .image-gallery-svg,.image-gallery-play-button .image-gallery-svg{height:28px;width:28px}@media (max-width: 768px){.image-gallery-fullscreen-button,.image-gallery-play-button{padding:15px}.image-gallery-fullscreen-button .image-gallery-svg,.image-gallery-play-button .image-gallery-svg{height:24px;width:24px}}@media (max-width: 480px){.image-gallery-fullscreen-button,.image-gallery-play-button{padding:10px}.image-gallery-fullscreen-button .image-gallery-svg,.image-gallery-play-button .image-gallery-svg{height:16px;width:16px}}.image-gallery-fullscreen-button{right:0}.image-gallery-play-button{left:0}.image-gallery-top-nav,.image-gallery-bottom-nav{padding:10px;left:50%;transform:translate(-50%)}.image-gallery-top-nav .image-gallery-svg,.image-gallery-bottom-nav .image-gallery-svg{height:120px;width:90px}@media (max-width: 768px){.image-gallery-top-nav .image-gallery-svg,.image-gallery-bottom-nav .image-gallery-svg{height:72px;width:48px}}@media (max-width: 480px){.image-gallery-top-nav .image-gallery-svg,.image-gallery-bottom-nav .image-gallery-svg{height:48px;width:36px}}.image-gallery-top-nav[disabled],.image-gallery-bottom-nav[disabled]{cursor:disabled;opacity:.6;pointer-events:none}.image-gallery-top-nav{top:0}.image-gallery-bottom-nav{bottom:0}.image-gallery-left-nav,.image-gallery-right-nav{padding:50px 10px;top:50%;transform:translateY(-50%)}.image-gallery-left-nav .image-gallery-svg,.image-gallery-right-nav .image-gallery-svg{height:120px;width:60px}@media (max-width: 768px){.image-gallery-left-nav .image-gallery-svg,.image-gallery-right-nav .image-gallery-svg{height:72px;width:36px}}@media (max-width: 480px){.image-gallery-left-nav .image-gallery-svg,.image-gallery-right-nav .image-gallery-svg{height:48px;width:24px}}.image-gallery-left-nav[disabled],.image-gallery-right-nav[disabled]{cursor:disabled;opacity:.6;pointer-events:none}.image-gallery-left-nav{left:0}.image-gallery-right-nav{right:0}.image-gallery{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;-webkit-tap-highlight-color:rgba(0,0,0,0);position:relative}.image-gallery.fullscreen-modal{background:#000;bottom:0;height:100%;left:0;position:fixed;right:0;top:0;width:100%;z-index:5}.image-gallery.fullscreen-modal .image-gallery-content{top:50%;transform:translateY(-50%)}.image-gallery-content{position:relative;line-height:0;top:0}.image-gallery-content.fullscreen{background:#000}.image-gallery-content .image-gallery-slide .image-gallery-image{max-height:calc(100vh - 80px)}.image-gallery-content.image-gallery-thumbnails-left .image-gallery-slide .image-gallery-image,.image-gallery-content.image-gallery-thumbnails-right .image-gallery-slide .image-gallery-image{max-height:100vh}.image-gallery-slide-wrapper{position:relative}.image-gallery-slide-wrapper.image-gallery-thumbnails-left,.image-gallery-slide-wrapper.image-gallery-thumbnails-right{display:inline-block;width:calc(100% - 110px)}@media (max-width: 768px){.image-gallery-slide-wrapper.image-gallery-thumbnails-left,.image-gallery-slide-wrapper.image-gallery-thumbnails-right{width:calc(100% - 87px)}}.image-gallery-slide-wrapper.image-gallery-rtl{direction:rtl}.image-gallery-slides{line-height:0;overflow:hidden;position:relative;white-space:nowrap;text-align:center;touch-action:none}.image-gallery-slide{left:0;position:absolute;top:0;width:100%}.image-gallery-slide.image-gallery-center{position:relative}.image-gallery-slide .image-gallery-image{width:100%;object-fit:contain}.image-gallery-slide .image-gallery-description{background:rgba(0,0,0,.4);bottom:70px;color:#fff;left:0;line-height:1;padding:10px 20px;position:absolute;white-space:normal}@media (max-width: 768px){.image-gallery-slide .image-gallery-description{bottom:45px;font-size:.8em;padding:8px 15px}}.image-gallery-bullets{bottom:20px;left:0;margin:0 auto;position:absolute;right:0;width:80%;z-index:4}.image-gallery-bullets .image-gallery-bullets-container{margin:0;padding:0;text-align:center}.image-gallery-bullets .image-gallery-bullet{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#0000;border:1px solid #fff;border-radius:50%;box-shadow:0 2px 2px #1a1a1a;cursor:pointer;display:inline-block;margin:0 5px;outline:none;padding:5px;transition:all .2s ease-out}@media (max-width: 768px){.image-gallery-bullets .image-gallery-bullet{margin:0 3px;padding:3px}}@media (max-width: 480px){.image-gallery-bullets .image-gallery-bullet{padding:2.7px}}.image-gallery-bullets .image-gallery-bullet:focus{transform:scale(1.2);background:#337ab7;border:1px solid #337ab7}.image-gallery-bullets .image-gallery-bullet.active{transform:scale(1.2);border:1px solid #fff;background:#fff}@media (hover: hover)and (pointer: fine){.image-gallery-bullets .image-gallery-bullet:hover{background:#337ab7;border:1px solid #337ab7}.image-gallery-bullets .image-gallery-bullet.active:hover{background:#337ab7}}.image-gallery-bullets.image-gallery-bullets-vertical{left:20px;right:auto;bottom:auto;width:auto;top:50%;transform:translateY(-50%)}.image-gallery-bullets.image-gallery-bullets-vertical .image-gallery-bullet{display:block;margin:12px 0}@media (max-width: 768px){.image-gallery-bullets.image-gallery-bullets-vertical .image-gallery-bullet{margin:6px 0;padding:3px}}@media (max-width: 480px){.image-gallery-bullets.image-gallery-bullets-vertical .image-gallery-bullet{padding:2.7px}}.image-gallery-thumbnails-wrapper{position:relative}.image-gallery-thumbnails-wrapper.thumbnails-swipe-horizontal{touch-action:pan-y}.image-gallery-thumbnails-wrapper.thumbnails-swipe-vertical{touch-action:pan-x}.image-gallery-thumbnails-wrapper.thumbnails-wrapper-rtl{direction:rtl}.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-left,.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-right{display:inline-block;vertical-align:top;width:100px}@media (max-width: 768px){.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-left,.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-right{width:81px}}.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-left .image-gallery-thumbnails,.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-right .image-gallery-thumbnails{height:100%;width:100%;left:0;padding:0;position:absolute;top:0}.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-left .image-gallery-thumbnails .image-gallery-thumbnail,.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-right .image-gallery-thumbnails .image-gallery-thumbnail{display:block;margin-right:0;padding:0}.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-left .image-gallery-thumbnails .image-gallery-thumbnail+.image-gallery-thumbnail,.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-right .image-gallery-thumbnails .image-gallery-thumbnail+.image-gallery-thumbnail{margin-left:0;margin-top:2px}.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-left,.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-right{margin:0 5px}@media (max-width: 768px){.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-left,.image-gallery-thumbnails-wrapper.image-gallery-thumbnails-right{margin:0 3px}}.image-gallery-thumbnails{overflow:hidden;padding:5px 0}@media (max-width: 768px){.image-gallery-thumbnails{padding:3px 0}}.image-gallery-thumbnails .image-gallery-thumbnails-container{cursor:pointer;text-align:center;white-space:nowrap}.image-gallery-thumbnail{display:inline-block;border:4px solid rgba(0,0,0,0);transition:border .3s ease-out;width:100px;background:rgba(0,0,0,0);padding:0}@media (max-width: 768px){.image-gallery-thumbnail{border:3px solid rgba(0,0,0,0);width:81px}}.image-gallery-thumbnail+.image-gallery-thumbnail{margin-left:2px}.image-gallery-thumbnail .image-gallery-thumbnail-inner{display:block;position:relative}.image-gallery-thumbnail .image-gallery-thumbnail-image{vertical-align:middle;width:100%;line-height:0}.image-gallery-thumbnail.active,.image-gallery-thumbnail:focus{outline:none;border:4px solid #337ab7}@media (max-width: 768px){.image-gallery-thumbnail.active,.image-gallery-thumbnail:focus{border:3px solid #337ab7}}@media (hover: hover)and (pointer: fine){.image-gallery-thumbnail:hover{outline:none;border:4px solid #337ab7}}@media (hover: hover)and (pointer: fine)and (max-width: 768px){.image-gallery-thumbnail:hover{border:3px solid #337ab7}}.image-gallery-thumbnail-label{box-sizing:border-box;color:#fff;font-size:1em;left:0;line-height:1em;padding:5%;position:absolute;top:50%;text-shadow:0 2px 2px hsl(0,0%,10%);transform:translateY(-50%);white-space:normal;width:100%}@media (max-width: 768px){.image-gallery-thumbnail-label{font-size:.8em;line-height:.8em}}.image-gallery-index{background:rgba(0,0,0,.4);color:#fff;line-height:1;padding:10px 20px;position:absolute;right:0;top:0;z-index:4}@media (max-width: 768px){.image-gallery-index{font-size:.8em;padding:5px 10px}}.image-editor{border:1px solid #ccc;padding:15px;border-radius:5px;background-color:#f9f9f9;font-family:sans-serif}.image-editor h3,.image-editor h4{margin-top:0;color:#333}.image-uploader{border:2px dashed #007bff;padding:20px;text-align:center;cursor:pointer;background-color:#fff;color:#007bff;border-radius:5px;margin-bottom:15px;transition:background-color .2s ease-in-out,border-color .2s ease-in-out}.image-uploader.active{border-color:#28a745;background-color:#e9f7ef}.image-uploader.disabled{border-color:#ced4da;background-color:#e9ecef;color:#6c757d;cursor:not-allowed}.image-uploader p{margin:0}.image-cropper{margin-top:15px;margin-bottom:15px;display:flex;flex-direction:column;align-items:center}.image-cropper .ReactCrop{max-width:100%;display:flex;justify-content:center;border:1px solid #ddd;background-color:#f0f0f0}.image-cropper .ReactCrop img{display:block;max-width:100%;object-fit:contain}.crop-actions{margin-top:10px;text-align:center;display:flex;gap:10px;justify-content:center}.crop-actions button{padding:8px 15px;cursor:pointer;border-radius:4px;border:1px solid transparent;font-weight:500;outline:none}.crop-actions button:focus-visible{outline:2px solid #007bff;outline-offset:2px}.image-editor-actions button{padding:8px 12px;cursor:pointer;border-radius:4px;border:1px solid;font-weight:500;transition:background-color .15s ease-in-out,border-color .15s ease-in-out;outline:none;background-color:#6c757d;color:#fff;border-color:#6c757d}.image-editor-actions button:hover:not(:disabled){background-color:#5a6268;border-color:#545b62}.image-editor-actions button:focus-visible{outline:2px solid #007bff;outline-offset:2px}.image-editor-actions button.confirm-action{background-color:#28a745;border-color:#28a745}.image-editor-actions button.confirm-action:hover:not(:disabled){background-color:#218838;border-color:#1e7e34}.image-editor-actions button.crop-action{background-color:#ffc107;border-color:#ffc107;color:#212529}.image-editor-actions button.crop-action:hover:not(:disabled){background-color:#e0a800;border-color:#d39e00}.image-editor-actions button:disabled{background-color:#adb5bd;border-color:#adb5bd;color:#e9ecef;cursor:not-allowed;opacity:.65}.crop-actions button:disabled{background-color:#adb5bd;border-color:#adb5bd;color:#fff;cursor:not-allowed}.crop-actions button:first-of-type{background-color:#28a745;color:#fff;border-color:#28a745}.crop-actions button:first-of-type:hover:not(:disabled){background-color:#218838}.crop-actions .cancel-button{background-color:#6c757d;color:#fff;border-color:#6c757d}.crop-actions .cancel-button:hover:not(:disabled){background-color:#5a6268}.image-positioner{margin:15px 0;padding:10px;background-color:#e9ecef;border-radius:4px;display:flex;align-items:center;gap:10px}.image-positioner label{margin:0;font-weight:500}.image-positioner select{padding:5px 8px;border-radius:4px;border:1px solid #ced4da;outline:none}.image-positioner select:focus-visible{outline:2px solid #007bff;outline-offset:1px;border-color:#80bdff}.image-positioner.disabled p{margin:0;color:#495057;font-style:italic}.image-preview-container{margin-top:15px;padding:10px;border:1px dashed #6c757d;border-radius:4px;min-height:50px;text-align:center;background-color:#fff}.image-preview-container.inline{display:inline-block;border:1px dashed #ced4da;padding:5px;vertical-align:middle}.image-preview-container img{border:1px solid #eee}.image-preview-container>p:first-child{color:#6c757d;margin:0}.image-preview-container .caption{font-size:.9em;color:#495057;margin-top:5px;clear:both}.image-toolbar{margin-top:20px;padding-top:15px;border-top:1px solid #dee2e6;display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-start}.image-toolbar button{padding:8px 12px;cursor:pointer;border-radius:4px;border:1px solid;font-weight:500;transition:background-color .15s ease-in-out,border-color .15s ease-in-out;outline:none}.image-toolbar button:focus-visible{outline:2px solid #007bff;outline-offset:2px}.image-toolbar button.confirm-button:disabled,.image-toolbar button.crop-button:disabled,.image-toolbar button.delete-button:disabled,.image-toolbar button:disabled{background-color:#adb5bd;border-color:#adb5bd;color:#e9ecef;cursor:not-allowed;opacity:.65}.image-toolbar .confirm-button{background-color:#007bff;border-color:#007bff;color:#fff}.image-toolbar .confirm-button:hover:not(:disabled){background-color:#0056b3;border-color:#0056b3}.image-toolbar .crop-button{background-color:#ffc107;border-color:#ffc107;color:#212529}.image-toolbar .crop-button:hover:not(:disabled){background-color:#e0a800;border-color:#d39e00}.image-toolbar .delete-button{background-color:#dc3545;border-color:#dc3545;color:#fff}.image-toolbar .delete-button:hover:not(:disabled){background-color:#c82333;border-color:#bd2130}.image-editor .form-group{margin-bottom:10px}.image-editor .form-group label{display:block;margin-bottom:5px;font-weight:500;color:#495057}.image-editor .form-group input[type=text]{width:100%;padding:8px;border:1px solid #ced4da;border-radius:4px;box-sizing:border-box;outline:none}.image-editor .form-group input[type=text]:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.image-editor .form-group input[type=text]:focus-visible{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40;outline:2px solid #007bff;outline-offset:1px}.image-editor-error-display{color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb;padding:10px 15px;margin-top:10px;border-radius:4px;font-size:.9em}.image-editor-error-display .error-message{margin:0;padding:0}.image-editor-error-display .error-message+.error-message{margin-top:8px}.image-editor-error-display .error-filename{font-weight:700}.image-editor .scale-slider{width:90%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#e2e8f0;border-radius:3px;outline:none;cursor:pointer;margin:6px 0}.image-editor .scale-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:#3b82f6;border-radius:50%;cursor:pointer;transition:background .2s}.image-editor .scale-slider::-webkit-slider-thumb:hover{background:#2563eb}.image-editor .scale-slider::-moz-range-thumb{width:16px;height:16px;background:#3b82f6;border-radius:50%;cursor:pointer;border:none}.image-editor .scale-presets{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}.image-editor .scale-presets button{flex:1;min-width:50px;padding:4px 8px;border:1px solid #d1d5db;background:white;border-radius:3px;font-size:.8em;color:#374151;font-weight:500;cursor:pointer;transition:all .2s}.image-editor .scale-presets button:hover{background:#e5e7eb;border-color:#9ca3af;color:#111827}.image-editor .scale-presets button.active{background:#dbeafe;border-color:#3b82f6;color:#1d4ed8;font-weight:600}.image-editor .form-group select{width:100%;padding:8px;border:1px solid #ced4da;border-radius:4px;box-sizing:border-box;background:white;font-size:.95em;cursor:pointer}.image-editor .form-group select:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40;outline:none}.input-mode-toggle{display:flex;border:1px solid #ced4da;border-radius:4px;overflow:hidden;margin-bottom:8px;width:fit-content;background-color:#fff}.toggle-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:none;background:#f8f9fa;cursor:pointer;transition:all .2s ease;font-size:14px;font-weight:500;color:#495057;border-right:1px solid #ced4da}.toggle-btn:last-child{border-right:none}.toggle-btn:hover:not(:disabled):not(.active){background:#e9ecef;color:#343a40}.toggle-btn.active{background:#007bff;color:#fff;box-shadow:inset 0 1px 2px #0000001a}.toggle-btn:disabled{cursor:not-allowed;opacity:.6;background:#f8f9fa;color:#6c757d}.toggle-icon{font-size:16px;line-height:1}.toggle-btn:focus{outline:none;box-shadow:0 0 0 2px #007bff40}.toggle-btn:focus:not(:focus-visible){box-shadow:none}.toggle-btn:focus-visible{box-shadow:0 0 0 2px #007bff40}.question-text-input-container{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.input-controls{display:flex;align-items:center;gap:16px;padding:8px 0;border-bottom:1px solid #e0e0e0;margin-bottom:8px}.subject-selector-container{display:flex;align-items:center;gap:8px}.subject-label{font-size:14px;font-weight:500;color:#333;margin:0}.subject-selector{padding:6px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:#fff;color:#333;cursor:pointer;transition:border-color .2s ease}.subject-selector:hover{border-color:#007bff}.subject-selector:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.subject-selector:disabled{background-color:#f5f5f5;color:#666;cursor:not-allowed}.input-field-container{position:relative}.question-text-textarea{width:100%;min-height:80px;padding:12px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;line-height:1.5;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease}.question-text-textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.question-text-textarea.error{border-color:#dc3545;box-shadow:0 0 0 2px #dc354540}.question-text-textarea:disabled{background-color:#f5f5f5;color:#666;cursor:not-allowed}.equation-editor-wrapper{border:1px solid #ddd;border-radius:4px;background-color:#fff;transition:border-color .2s ease,box-shadow .2s ease}.equation-editor-wrapper:focus-within{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.image-editor-wrapper{border:1px solid #ddd;border-radius:4px;background-color:#fff;transition:border-color .2s ease,box-shadow .2s ease}.image-editor-wrapper:focus-within{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.image-attachment-indicator{margin-top:8px;padding:8px 12px;background-color:#d1ecf1;border:1px solid #bee5eb;border-radius:4px;display:flex;align-items:center;justify-content:space-between}.attachment-status{display:flex;align-items:center;gap:8px;flex:1}.attachment-icon{font-size:16px;color:#0c5460}.attachment-text{font-size:14px;color:#0c5460;font-weight:500}.clear-attachment-btn{background:none;border:none;color:#0c5460;cursor:pointer;font-size:16px;padding:4px;border-radius:2px;transition:background-color .2s ease;line-height:1}.clear-attachment-btn:hover{background-color:#0c54601a}.clear-attachment-btn:disabled{color:#6c757d;cursor:not-allowed}.clear-attachment-btn:disabled:hover{background-color:transparent}.validation-error{display:flex;align-items:flex-start;gap:8px;padding:8px 12px;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;font-size:13px;line-height:1.4;margin-top:4px}.validation-error:before{content:"⚠";flex-shrink:0;font-weight:700}.latex-help,.image-help{margin-top:8px}.latex-help-details,.image-help-details{border:1px solid #e0e0e0;border-radius:4px;background-color:#f8f9fa}.latex-help-details summary,.image-help-details summary{padding:8px 12px;cursor:pointer;font-size:13px;font-weight:500;color:#495057;-webkit-user-select:none;user-select:none;border-radius:4px;transition:background-color .2s ease}.latex-help-details summary:hover,.image-help-details summary:hover{background-color:#e9ecef}.latex-help-details[open] summary,.image-help-details[open] summary{border-bottom:1px solid #e0e0e0;border-radius:4px 4px 0 0}.latex-help-content,.image-help-content{padding:12px;font-size:13px;line-height:1.5}.latex-help-content p,.image-help-content p{margin:0 0 8px}.latex-help-content p:last-child,.image-help-content p:last-child{margin-bottom:0}.latex-help-content ul,.image-help-content ul{margin:8px 0;padding-left:20px}.latex-help-content li,.image-help-content li{margin-bottom:4px}.latex-help-content code,.image-help-content code{background-color:#e9ecef;padding:2px 4px;border-radius:2px;font-family:Courier New,monospace;font-size:12px}@media (max-width: 768px){.input-controls{flex-direction:column;align-items:flex-start;gap:12px}.subject-selector-container{width:100%}.subject-selector{flex:1;min-width:150px}}@media (prefers-contrast: high){.question-text-textarea,.subject-selector,.equation-editor-wrapper{border-width:2px}.validation-error{border-width:2px;font-weight:500}}.inline-content-editor-container{display:flex;flex-direction:column;gap:0;border:1px solid #ddd;border-radius:4px;background-color:#fff;overflow:hidden}.markdown-toolbar{display:flex;gap:4px;padding:8px;background-color:#f8f9fa;border-bottom:1px solid #dee2e6}.markdown-toolbar button{background-color:transparent;border:1px solid transparent;border-radius:3px;color:#333;padding:2px 6px;min-width:24px;font-family:inherit;font-size:14px;cursor:pointer;transition:all .1s ease}.markdown-toolbar button:hover{background-color:#e2e6ea;border-color:#adb5bd}.markdown-toolbar button:active{background-color:#dae0e5;border-color:#95999c}.inline-content-textarea{border:none;border-radius:0;padding:12px;background-color:#fff;font-family:inherit;font-size:14px;line-height:1.5;resize:vertical;outline:none;width:100%;min-height:80px}.inline-content-textarea:focus{background-color:#fff}.inline-content-editor-container:focus-within{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.inline-content-textarea:disabled{background-color:#f8f9fa;cursor:not-allowed}.inline-editor-help{padding:8px 12px;background-color:#e7f3ff;border-top:1px solid #b3d8ff;font-size:12px;color:#1e40af;text-align:center}.inline-editor-help kbd{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:3px;padding:2px 4px;font-size:11px;font-family:monospace;color:#495057}.latex-helper-section{margin-top:16px;border:1px solid #e0e0e0;border-radius:8px;background-color:#f8f9fa;overflow:hidden}.latex-helper-header{padding:12px 16px;background-color:#fff;border-bottom:1px solid #e0e0e0}.latex-helper-header h4{margin:0 0 4px;color:#2563eb;font-size:14px;font-weight:600}.latex-helper-header p{margin:0;font-size:12px;color:#6b7280;line-height:1.4}.equation-editor-wrapper{padding:16px;background-color:#fff}.latex-helper-actions{display:flex;gap:8px;padding:12px 16px;background-color:#f9fafb;border-top:1px solid #e0e0e0}.insert-latex-button,.clear-latex-button{padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.insert-latex-button{background-color:#2563eb;color:#fff;border-color:#2563eb}.insert-latex-button:hover:not(:disabled){background-color:#1d4ed8;border-color:#1d4ed8}.insert-latex-button:disabled{background-color:#e5e7eb;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.clear-latex-button{background-color:#fff;color:#6b7280}.clear-latex-button:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.clear-latex-button:disabled{color:#d1d5db;cursor:not-allowed}.charts-editor-section{margin-top:16px;border:1px solid #e0e0e0;border-radius:8px;background-color:#f8f9fa;overflow:hidden}.charts-editor-header{padding:12px 16px;background-color:#fff;border-bottom:1px solid #e0e0e0}.charts-editor-header h4{margin:0 0 4px;color:#2563eb;font-size:14px;font-weight:600}.charts-editor-header p{margin:0;font-size:12px;color:#6b7280;line-height:1.4}.charts-editor-wrapper{padding:16px;background-color:#fff}.chart-actions{display:flex;gap:8px;padding:12px 16px;background-color:#f9fafb;border-top:1px solid #e0e0e0}.insert-chart-button,.clear-chart-button{padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.insert-chart-button{background-color:#2563eb;color:#fff;border-color:#2563eb}.insert-chart-button:hover:not(:disabled){background-color:#1d4ed8;border-color:#1d4ed8}.insert-chart-button:disabled{background-color:#e5e7eb;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.clear-chart-button{background-color:#fff;color:#6b7280}.clear-chart-button:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.clear-chart-button:disabled{color:#d1d5db;cursor:not-allowed}.image-editor-section{margin-top:16px;border:1px solid #e0e0e0;border-radius:8px;background-color:#f8f9fa;overflow:hidden}.image-editor-header{padding:12px 16px;background-color:#fff;border-bottom:1px solid #e0e0e0}.image-editor-header h4{margin:0 0 4px;color:#2563eb;font-size:14px;font-weight:600}.image-editor-header p{margin:0;font-size:12px;color:#6b7280;line-height:1.4}.image-editor-wrapper{padding:16px;background-color:#fff}.image-actions{display:flex;gap:8px;padding:12px 16px;background-color:#f9fafb;border-top:1px solid #e0e0e0}.clear-image-button{padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;background-color:#fff;color:#6b7280}.clear-image-button:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.clear-image-button:disabled{color:#d1d5db;cursor:not-allowed}.secondary-button{padding:6px 12px;border:1px solid #d1d5db;border-radius:4px;background-color:#fff;color:#6b7280;cursor:pointer;font-size:13px;transition:all .2s ease;margin-right:8px}.secondary-button:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af;color:#374151}.secondary-button:disabled{color:#d1d5db;cursor:not-allowed}.attachments-summary{margin-top:8px;padding:8px 12px;background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px}.attachment-indicator{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7280}.attachment-icon{font-size:16px}.attachment-text{flex:1;font-weight:500}.edit-attachment-btn{padding:4px 8px;border:1px solid #d1d5db;border-radius:4px;background-color:#fff;color:#6b7280;cursor:pointer;font-size:12px;transition:all .2s ease}.edit-attachment-btn:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af;color:#374151}.edit-attachment-btn:disabled{color:#d1d5db;cursor:not-allowed}.clickable-chart{cursor:pointer;transition:opacity .2s ease;border-radius:4px;padding:8px}.clickable-chart:hover{opacity:.8;background-color:#2563eb0d;border:1px solid rgba(37,99,235,.2)}@media (prefers-reduced-motion: reduce){.question-text-textarea,.subject-selector,.equation-editor-wrapper,.latex-help-details summary{transition:none}}._editorLayout_1wkau_2{display:flex;flex-direction:column;gap:1rem;padding:1rem;border:1px solid #ccc;border-radius:4px;background-color:#fff}._mainArea_1wkau_12{display:flex;gap:1rem;flex-wrap:wrap}._controls_1wkau_18{flex:2;min-width:300px;display:flex;flex-direction:column;gap:1rem}._preview_1wkau_26{flex:1;min-width:250px;padding:1rem;border:1px dashed #ddd;min-height:200px;background-color:#f9f9f9;border-radius:4px}._toolbar_1wkau_37{display:flex;gap:.5rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0;flex-wrap:wrap}._toolbarButton_1wkau_46{padding:.5rem 1rem;border:1px solid #ccc;background-color:#f7f7f7;cursor:pointer;border-radius:4px;font-size:.9em;display:flex;align-items:center;color:#333}._active_1wkau_59{background-color:#e0e0f0;font-weight:700;border-color:#a0a0d0;color:#333}._toolbarButton_1wkau_46:disabled{background-color:#f5f5f5;color:#aaa;cursor:not-allowed;border-color:#e0e0e0}._toolbarButton_1wkau_46:hover:not(:disabled){background-color:#e8e8e8}._validationError_1wkau_79{color:#d9534f;font-size:.9em;padding:.5rem;border:1px solid #d9534f;border-radius:4px;background-color:#f2dede}._helpStub_1wkau_88{font-size:.9em;color:#666;border-top:1px solid #eee;padding-top:1rem;margin-top:1rem}._blankModeToggle_1wkau_97{padding:.5rem 0;font-size:.9em}._blankModeToggle_1wkau_97 label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.curriculum-hierarchy-display{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#ffffff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.curriculum-hierarchy-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#666}.loading-spinner{width:32px;height:32px;border:3px solid #e3e3e3;border-top:3px solid #2196F3;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.curriculum-hierarchy-error{display:flex;flex-direction:column;align-items:center;padding:40px 20px;color:#d32f2f;background:#ffeaea;border:1px solid #ffcdd2;margin:16px;border-radius:8px}.error-icon{font-size:24px;margin-bottom:12px}.retry-button{margin-top:16px;padding:8px 16px;background:#2196F3;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.retry-button:hover{background:#1976D2}.modal.curriculum-linker-modal{max-width:1300px!important;width:92%!important;max-height:95vh!important;min-height:80vh!important;padding:30px!important}.modal.curriculum-linker-modal .curriculum-strand-list,.modal.curriculum-linker-modal .curriculum-tree-container,.modal.curriculum-linker-modal .curriculum-hierarchy-display{max-height:1000px!important}.curriculum-controls{padding:16px;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;gap:12px;flex-wrap:wrap;align-items:center}.search-control{position:relative;flex:1;min-width:200px;max-width:400px}.search-input{width:100%;padding:10px 40px 10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s,box-shadow .2s}.search-input:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.clear-search{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:#666;cursor:pointer;padding:4px;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:14px;transition:background-color .2s}.clear-search:hover{background:#f0f0f0}.filter-controls{display:flex;gap:8px;flex-wrap:wrap}.year-level-filter,.element-type-filter{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:white;min-width:140px}.year-level-filter:focus,.element-type-filter:focus{outline:none;border-color:#2196f3}.curriculum-tree-container{max-height:1200px;overflow-y:auto;overflow-x:hidden;background:white}.curriculum-tree-container::-webkit-scrollbar{width:8px}.curriculum-tree-container::-webkit-scrollbar-track{background:#f1f1f1}.curriculum-tree-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.curriculum-tree-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.curriculum-tree-level{position:relative}.curriculum-tree-level.level-1{margin-left:20px}.curriculum-tree-level.level-2{margin-left:40px}.curriculum-tree-level.level-3{margin-left:60px}.curriculum-tree-node{position:relative;margin:2px 0}.node-header{display:flex;align-items:center;padding:8px 12px;margin:1px 0;border-radius:6px;transition:all .2s ease;cursor:default;position:relative}.node-header:hover{background:#f8f9fa}.node-header.selectable{cursor:pointer}.node-header.selectable:hover{background:#e3f2fd;box-shadow:0 1px 3px #0000001a}.node-header.selected{background:#bbdefb;border:1px solid #2196F3;box-shadow:0 2px 4px #2196f333}.curriculum-tree-node.learning_area .node-header{background:linear-gradient(135deg,#e8f5e8 0%,#f0f8f0 100%);border-left:4px solid #4caf50;font-weight:600}.curriculum-tree-node.learning_area .node-header.selected{background:linear-gradient(135deg,#c8e6c9 0%,#dcedc8 100%);border-left:4px solid #388e3c}.curriculum-tree-node.strand .node-header{background:linear-gradient(135deg,#fff3e0 0%,#fef9e7 100%);border-left:4px solid #ff9800;font-weight:500}.curriculum-tree-node.strand .node-header.selected{background:linear-gradient(135deg,#ffe0b2 0%,#ffecb3 100%);border-left:4px solid #f57c00}.curriculum-tree-node.content_descriptor .node-header{background:linear-gradient(135deg,#f3e5f5 0%,#fce4ec 100%);border-left:4px solid #9c27b0}.curriculum-tree-node.content_descriptor .node-header.selected{background:linear-gradient(135deg,#e1bee7 0%,#f8bbd9 100%);border-left:4px solid #7b1fa2}.curriculum-tree-node.elaboration .node-header{background:linear-gradient(135deg,#e3f2fd 0%,#f3e5f5 100%);border-left:4px solid #2196f3}.curriculum-tree-node.elaboration .node-header.selected{background:linear-gradient(135deg,#bbdefb 0%,#ce93d8 100%);border-left:4px solid #0d47a1}.expand-toggle{position:absolute;left:-20px;top:50%;transform:translateY(-50%);background:none;border:none;color:#666;cursor:pointer;padding:2px;border-radius:3px;font-size:12px;line-height:1;transition:all .2s ease;width:16px;height:16px;display:flex;align-items:center;justify-content:center;z-index:1}.expand-toggle:hover{background:#e0e0e0;color:#333}.expand-toggle.expanded{transform:rotate(0)}.expand-toggle.collapsed{transform:rotate(-90deg)}.element-icon{font-size:16px;margin-right:8px;display:flex;align-items:center;justify-content:center;width:20px;height:20px}.node-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.node-title{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.element-name{font-size:14px;color:#333;font-weight:500;word-break:break-word;line-height:1.3}.element-code{font-size:12px;color:#666;font-family:Monaco,Menlo,Ubuntu Mono,monospace;background:rgba(0,0,0,.05);padding:2px 6px;border-radius:3px}.child-count{font-size:11px;color:#666;background:#f0f0f0;padding:2px 6px;border-radius:10px;white-space:nowrap}.year-levels{font-size:11px;color:#666;font-style:italic;background:#e3f2fd;padding:2px 6px;border-radius:3px;white-space:nowrap}.selection-indicator{margin-left:8px;width:20px;height:20px;border:2px solid #ddd;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;transition:all .2s ease}.selection-indicator.selected{background:#2196F3;border-color:#2196f3;color:#fff}.node-children{position:relative;margin-top:4px}.node-children:before{content:"";position:absolute;left:-8px;top:0;bottom:0;width:1px;background:#ddd}.selection-path{padding:16px;background:#f0f9ff;border:1px solid #e0f2fe;border-radius:8px;margin-bottom:15px}.selection-path h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#1f2937}.path-visualization{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.path-box{display:flex;align-items:center;padding:8px 12px;border-radius:6px;border:2px solid #e5e7eb;background:white;min-width:120px;max-width:200px;transition:all .2s ease;box-shadow:0 1px 3px #0000001a}.path-box.selected{border-color:#2563eb;background:linear-gradient(135deg,#eff6ff 0%,#f8fafc 100%)}.path-box.auto-selected{border-color:#6b7280;background:linear-gradient(135deg,#f9fafb 0%,#f3f4f6 100%);opacity:.8}.path-box.learning_area{border-color:#4caf50;background:linear-gradient(135deg,#e8f5e8 0%,#f0f8f0 100%)}.path-box.strand{border-color:#ff9800;background:linear-gradient(135deg,#fff3e0 0%,#fef9e7 100%)}.path-box.content_descriptor{border-color:#9c27b0;background:linear-gradient(135deg,#f3e5f5 0%,#fce4ec 100%)}.path-box.elaboration{border-color:#f9a825;background:linear-gradient(135deg,#fff8e1 0%,#fffde7 100%)}.path-box-header{font-size:16px;margin-right:8px}.path-box-content{flex:1;min-width:0}.path-box-title{font-size:12px;font-weight:600;color:#1f2937;line-height:1.2;margin-bottom:2px}.path-box-code{font-size:10px;color:#6b7280;font-weight:500}.path-arrow{font-size:14px;color:#6b7280;font-weight:700;margin:0 4px}.path-element.learning_area{background:linear-gradient(135deg,#e8f5e8 0%,#f0f8f0 100%);border-color:#4caf50;color:#2e7d32}.path-element.strand{background:linear-gradient(135deg,#fff3e0 0%,#fef9e7 100%);border-color:#ff9800;color:#f57c00}.path-element.content_descriptor{background:linear-gradient(135deg,#f3e5f5 0%,#fce4ec 100%);border-color:#9c27b0;color:#7b1fa2}.path-element.elaboration{background:linear-gradient(135deg,#fff8e1 0%,#fffde7 100%);border-color:#f9a825;color:#f57f17}.path-element.selected{box-shadow:0 0 0 2px #2196f34d;transform:scale(1.02)}.path-element.auto-selected{opacity:.8;border-style:dashed}.path-arrow{font-size:12px;color:#6b7280;font-weight:700}.path-details{font-size:12px;color:#374151;padding:6px 0;border-top:1px solid #e5e7eb}.selection-summary{padding:16px;background:#f8f9fa;border-top:1px solid #e9ecef}.selection-summary h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#333}.selected-items{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.selected-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:white;border:1px solid #ddd;border-radius:6px;transition:all .2s ease}.selected-item:hover{box-shadow:0 2px 4px #0000001a}.selected-item.learning_area{border-left:4px solid #4caf50}.selected-item.strand{border-left:4px solid #ff9800}.selected-item.content_descriptor{border-left:4px solid #9c27b0}.remove-selection{margin-left:auto;background:#f44336;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.remove-selection:hover{background:#d32f2f}.no-results{text-align:center;padding:40px 20px;color:#666;font-style:italic}@media (max-width: 768px){.curriculum-controls{flex-direction:column;align-items:stretch}.search-control{max-width:none}.filter-controls{justify-content:stretch}.year-level-filter,.element-type-filter{flex:1;min-width:0}.curriculum-tree-container{max-height:800px}.node-header{padding:12px 8px}.element-name{font-size:13px}.selected-items{max-height:150px}}@media (max-width: 480px){.curriculum-tree-level.level-1{margin-left:16px}.curriculum-tree-level.level-2{margin-left:32px}.curriculum-tree-level.level-3{margin-left:48px}.node-title{flex-direction:column;align-items:flex-start;gap:4px}.element-code,.child-count,.year-levels{font-size:10px}}@media (prefers-reduced-motion: reduce){.node-header,.expand-toggle,.selection-indicator,.selected-item{transition:none}.loading-spinner{animation:none}}.selection-path{margin-top:20px;padding:15px;border:2px solid #e0e0e0;border-radius:8px;background:#f9f9f9}.selection-path h4{margin:0 0 15px;color:#333;font-size:16px;font-weight:600}.path-visualization{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-start;margin-bottom:15px}.path-box{min-width:140px;max-width:180px;border-radius:8px;border:2px solid #ddd;background:white;overflow:hidden;box-shadow:0 2px 4px #0000001a;transition:all .2s ease}.path-box.selected{border-color:#4caf50;box-shadow:0 2px 8px #4caf504d;transform:translateY(-2px)}.path-box.auto-selected{border-color:#2196f3;box-shadow:0 2px 8px #2196f333;opacity:.8}.path-box.learning_area{border-left:4px solid #1565c0}.path-box.strand{border-left:4px solid #6a1b9a}.path-box.content_descriptor{border-left:4px solid #2e7d32}.path-box.elaboration{border-left:4px solid #2196f3}.path-box.section_header{border-left:4px solid #757575}.path-box-header{background:#f5f5f5;padding:8px;text-align:center;font-size:18px}.path-box-content{padding:10px}.path-box-title{font-size:10px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.path-box-name{font-size:12px;font-weight:500;color:#333;line-height:1.3;margin-bottom:4px}.path-box-code{font-size:11px;font-weight:600;color:#666;font-family:monospace}.path-connector{display:flex;align-items:center;justify-content:center;min-width:30px}.path-arrow{color:#666;font-size:16px;font-weight:700}.path-summary{margin-top:15px;border-top:2px solid #e0e0e0;font-size:14px;color:#333;background:#f8f8f8;padding:10px;border-radius:4px}.curriculum-tree-node:focus-within .node-header{outline:2px solid #2196F3;outline-offset:2px}@media (prefers-contrast: high){.node-header{border:2px solid transparent}.node-header.selected{border-color:#000}.curriculum-tree-node.learning_area .node-header,.curriculum-tree-node.strand .node-header,.curriculum-tree-node.content_descriptor .node-header{background:white;border-left-width:6px}}.curriculum-tree-node{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.node-children{animation:slideDown .2s ease-out;transform-origin:top}@keyframes slideDown{0%{opacity:0;transform:scaleY(.8)}to{opacity:1;transform:scaleY(1)}}.selection-indicator{transform:scale(1);transition:all .2s cubic-bezier(.4,0,.2,1)}.selection-indicator.selected{animation:selectionPulse .3s ease-out}@keyframes selectionPulse{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.curriculum-linker-enhanced{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#ffffff;border-radius:12px;box-shadow:0 4px 12px #0000001a;overflow:hidden;max-width:1200px;margin:0 auto}.curriculum-linker-header{padding:20px 24px;background:linear-gradient(135deg,#2563eb 0%,#1e40af 100%);color:#fff;position:relative}.curriculum-linker-header h3{margin:0 0 8px;font-size:24px;font-weight:600;color:#fff}.item-info{margin:0;opacity:.95;font-size:14px;color:#fffffff2}.unsaved-changes-warning{position:absolute;top:20px;right:24px;background:#f59e0b;color:#1f2937;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:.9}50%{opacity:1}}.version-selector-section{padding:20px 24px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.version-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.version-selector-header label{font-weight:600;color:#1f2937;font-size:14px}.advanced-options-toggle{background:white;border:1px solid #d1d5db;padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s;color:#374151;font-weight:500}.advanced-options-toggle:hover{background:#f3f4f6;border-color:#9ca3af;color:#1f2937}.version-select{width:100%;padding:12px 16px;border:2px solid #d1d5db;border-radius:8px;font-size:14px;background:white;color:#1f2937;transition:border-color .2s,box-shadow .2s}.version-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.version-warning{margin-top:12px;padding:12px;background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;color:#92400e;font-size:13px;font-weight:500}.advanced-options{margin-top:16px;padding:16px;background:white;border:1px solid #e5e7eb;border-radius:8px}.option-group{margin-bottom:12px}.option-group:last-child{margin-bottom:0}.option-group label{display:block;font-weight:600;color:#1f2937;font-size:13px;margin-bottom:8px}.selection-types{display:flex;gap:8px;flex-wrap:wrap}.selection-type-badge{padding:4px 8px;background:#dbeafe;color:#1d4ed8;border-radius:4px;font-size:12px;font-weight:600;text-transform:capitalize}.quick-actions{padding:16px 24px;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;gap:12px;align-items:center;flex-wrap:wrap}.quick-action-button{padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;background:white;color:#374151;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s}.quick-action-button:hover{background:#f3f4f6;border-color:#9ca3af;color:#1f2937}.quick-action-button:disabled{opacity:.5;cursor:not-allowed}.quick-action-button.clear:hover{background:#fef2f2;border-color:#fca5a5;color:#dc2626}.selection-stats{margin-left:auto;font-size:13px;color:#374151;display:flex;align-items:center;gap:8px;font-weight:500}.max-reached{color:#dc2626;font-weight:600}.curriculum-display-section{border-bottom:1px solid #e9ecef}.no-version-selected{padding:40px 24px;text-align:center;color:#6b7280;background:#f9fafb;font-weight:500}.selection-summary-detailed{padding:20px 24px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.selection-summary-detailed h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#1f2937}.stats-overview{display:flex;gap:16px;margin-bottom:16px;flex-wrap:wrap}.stat-item{display:flex;flex-direction:column;gap:4px;padding:12px 16px;background:white;border:1px solid #e5e7eb;border-radius:8px;min-width:120px}.stat-label{font-size:12px;color:#6b7280;font-weight:500}.stat-value{font-size:18px;font-weight:600;color:#1f2937}.selection-quality{padding:12px;border-radius:6px;font-size:13px;font-weight:500}.quality-good{color:#059669;background:#ecfdf5;border:1px solid #a7f3d0}.quality-moderate{color:#d97706;background:#fffbeb;border:1px solid #fde68a}.quality-high{color:#dc2626;background:#fef2f2;border:1px solid #fca5a5}.curriculum-linker-actions{padding:20px 24px;background:white;display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap}.save-button{padding:12px 24px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #2563eb33}.save-button:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 8px #2563eb4d}.save-button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;background:#9ca3af}.cancel-button{padding:12px 24px;background:white;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.cancel-button:hover{background:#f9fafb;border-color:#9ca3af;color:#1f2937}.curriculum-linker-help{padding:16px 24px;background:#f9fafb;border-top:1px solid #e5e7eb}.curriculum-linker-help details summary{cursor:pointer;font-weight:500;color:#2563eb;font-size:14px;padding:8px 0}.curriculum-linker-help details summary:hover{color:#1d4ed8}.help-content{margin-top:12px;padding:16px;background:white;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;line-height:1.5;color:#374151}.help-content p{margin:0 0 12px}.help-content ul{margin:0;padding-left:20px}.help-content li{margin-bottom:6px}.curriculum-linker-loading,.curriculum-linker-error{padding:40px 24px;text-align:center;background:#f9fafb}.curriculum-linker-error{color:#dc2626}.curriculum-linker-loading{color:#6b7280}.curriculum-linker-error .error-icon{font-size:32px;margin-bottom:16px}@media (max-width: 768px){.curriculum-linker-enhanced{margin:0;border-radius:0}.curriculum-linker-header{padding:16px 20px}.curriculum-linker-header h3{font-size:20px}.unsaved-changes-warning{position:static;margin-top:12px;text-align:center}.version-selector-section,.quick-actions,.selection-summary-detailed,.curriculum-linker-actions,.curriculum-linker-help{padding:16px 20px}.version-selector-header{flex-direction:column;align-items:flex-start;gap:8px}.quick-actions{flex-direction:column;align-items:stretch}.selection-stats{margin-left:0;justify-content:center}.stats-overview{flex-direction:column;gap:8px}.stat-item{min-width:0}.curriculum-linker-actions{flex-direction:column-reverse}.save-button,.cancel-button{width:100%;justify-content:center}}@media (max-width: 480px){.curriculum-linker-header,.version-selector-section,.quick-actions,.selection-summary-detailed,.curriculum-linker-actions,.curriculum-linker-help{padding:12px 16px}.selection-types{flex-direction:column}.selection-type-badge{text-align:center}}@media (prefers-color-scheme: dark){.curriculum-linker-enhanced{background:#1e1e1e;color:#e0e0e0}.version-selector-section,.quick-actions,.selection-summary-detailed,.curriculum-linker-help{background:#2a2a2a;border-color:#404040}.version-select,.quick-action-button,.stat-item,.help-content{background:#333;border-color:#404040;color:#e0e0e0}.version-warning{background:#4a3c1d;border-color:#5d4e2a;color:#ffd54f}.no-version-selected{background:#2a2a2a;color:#aaa}}@media (prefers-reduced-motion: reduce){.save-button,.quick-action-button,.advanced-options-toggle,.cancel-button{transition:none}.save-button:hover:not(:disabled){transform:none}.unsaved-changes-warning{animation:none}}.version-select:focus,.quick-action-button:focus,.advanced-options-toggle:focus,.save-button:focus,.cancel-button:focus{outline:2px solid #2563eb;outline-offset:2px}@media (prefers-contrast: high){.curriculum-linker-enhanced{border:2px solid #000}.version-select,.quick-action-button,.save-button,.cancel-button{border-width:2px}}.modal.curriculum-linker-modal{max-width:1300px!important;width:92%!important;max-height:90vh!important;min-height:75vh!important}.modal.curriculum-linker-modal .curriculum-hierarchy-display,.modal.curriculum-linker-modal .curriculum-tree-container{max-height:65vh!important;min-height:500px!important}.curriculum-content{display:inline;line-height:1.5;max-width:none;word-wrap:break-word;overflow-wrap:break-word}.curriculum-content.latex-enabled{line-height:1.6;max-width:none}.curriculum-content .text-segment{display:inline}.math-loading{font-style:italic;color:#666;background:#f5f5f5;padding:2px 6px;border-radius:3px;font-size:.9em}.curriculum-content .katex{font-size:1em!important}.curriculum-content .katex-display{margin:.5em 0!important;text-align:left!important}.curriculum-content .katex-html{display:inline-block;vertical-align:middle}.curriculum-content .katex-error{color:#d32f2f!important;border-bottom:1px dashed #d32f2f;background:rgba(211,47,47,.1);padding:1px 3px;border-radius:2px}.node-content .curriculum-content{max-width:100%;word-wrap:break-word;overflow-wrap:break-word;white-space:pre-wrap;-webkit-hyphens:auto;hyphens:auto;line-height:1.4}.element-name{max-width:none!important;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;line-height:1.4}@media (max-width: 768px){.curriculum-content .katex{font-size:.9em!important}.curriculum-content .katex-display{margin:.3em 0!important}.node-content .curriculum-content{white-space:pre-wrap;word-break:break-word}}.paginated-preview-container{position:relative}.pages-container{display:flex;flex-direction:column;gap:30px;padding:20px 0}.preview-page{width:100%;max-width:650px;min-height:900px;margin:0 auto;padding:40px;background-color:#fff;box-shadow:0 4px 20px #00000040;border-radius:2px;position:relative;box-sizing:border-box;display:flex;flex-direction:column}.preview-page.cover-page{justify-content:center}.preview-page.content-page{justify-content:flex-start}.page-content{flex:1;overflow:hidden}.preview-page .page-header{display:flex;justify-content:space-between;align-items:center;padding:8px 0 12px;margin-bottom:15px;border-bottom:1px solid #d1d5db;min-height:40px}.preview-page .page-header .header-left{display:flex;align-items:center;gap:10px;flex:1}.preview-page .page-header .header-left.left{justify-content:flex-start}.preview-page .page-header .header-left.center{justify-content:center}.preview-page .page-header .header-left.right{justify-content:flex-end}.preview-page .page-header .header-logo{max-height:35px;max-width:80px;object-fit:contain}.preview-page .page-header .header-school-name{font-size:.9em;font-weight:600;color:#374151}.preview-page .page-header .header-right{display:flex;align-items:center;gap:15px;flex-shrink:0}.preview-page .page-header .header-student-name{font-size:.85em;color:#4b5563}.preview-page .page-header .header-qr-placeholder{display:flex;align-items:center;justify-content:center;opacity:.7}.preview-page .page-header .page-number{font-size:.85em;color:#6b7280;font-weight:500}.page-number-indicator{position:absolute;bottom:15px;right:20px;font-size:.8em;color:#9ca3af;font-style:italic}.preview-page.cover-page{position:relative}.preview-page .cover-qr-code{position:absolute;top:15px;right:15px;opacity:.8}.preview-page .preview-cover-page{text-align:center;padding:40px 20px}.preview-page .cover-page-header{margin-bottom:40px}.preview-page .cover-logo{margin-bottom:20px}.preview-page .cover-logo img{max-height:100px;max-width:250px;object-fit:contain}.preview-page .school-name{font-size:2.2em;font-weight:700;margin:20px 0}.preview-page .cover-page-content{flex:1;display:flex;flex-direction:column;justify-content:center}.preview-page .assessment-title{font-size:1.8em;margin:20px 0;color:#1f2937}.preview-page .assessment-subtitle{font-size:1.1em;color:#6b7280;margin:10px 0;font-style:italic}.preview-page .cover-meta{margin-top:40px;font-size:.9em;color:#6b7280}.preview-page .cover-meta p{margin:5px 0}.preview-page .cover-meta .student-name-field{margin-top:15px;font-size:1.1em}.preview-page .assessment-header{margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e5e7eb}.preview-page .assessment-header h2{margin:0 0 10px;font-size:1.4em;color:#1f2937}.preview-page .assessment-header .assessment-description{margin:0;color:#6b7280;font-style:italic;font-size:.95em}.section-header-item{margin-top:20px;margin-bottom:10px}.section-header-item .section-title{font-size:1.2em;color:#374151;padding-bottom:8px;border-bottom:1px solid #e5e7eb;margin:0}.section-stimulus-block{background:#f9fafb;border-left:3px solid #3b82f6;padding:12px 15px;margin-bottom:15px;border-radius:0 4px 4px 0}.preview-page .question-preview-item{margin-bottom:20px;padding:15px;background:#f9fafb;border-radius:4px;border:1px solid #e5e7eb;width:100%;box-sizing:border-box}.preview-page .question-renderer{width:100%;display:flex;flex-direction:column}.preview-page .question-content,.preview-page .question-text{width:100%}.preview-page .question-options{width:100%;margin-top:15px}.preview-page .question-option{display:flex;align-items:flex-start;margin-bottom:8px;padding:8px 12px;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px}.preview-page .question-option .option-label{font-weight:700;color:#495057;margin-right:10px;min-width:25px}.preview-page .question-option .option-content{flex:1}.preview-page .question-options.layout-horizontal{display:flex;flex-wrap:wrap;gap:10px}.preview-page .question-options.layout-horizontal .question-option{flex:0 0 auto;margin-bottom:0}.preview-page .answer-space{width:100%}.measure-container{pointer-events:none}.measure-container .measure-item{margin-bottom:20px}.react-resizable{position:relative}.react-resizable-handle{position:absolute;width:20px;height:20px;background-repeat:no-repeat;background-origin:content-box;box-sizing:border-box;background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA2IDYiIHN0eWxlPSJiYWNrZ3JvdW5kLWNvbG9yOiNmZmZmZmYwMCIgeD0iMHB4IiB5PSIwcHgiIHdpZHRoPSI2cHgiIGhlaWdodD0iNnB4Ij48ZyBvcGFjaXR5PSIwLjMwMiI+PHBhdGggZD0iTSA2IDYgTCAwIDYgTCAwIDQuMiBMIDQgNC4yIEwgNC4yIDQuMiBMIDQuMiAwIEwgNiAwIEwgNiA2IEwgNiA2IFoiIGZpbGw9IiMwMDAwMDAiLz48L2c+PC9zdmc+);background-position:bottom right;padding:0 3px 3px 0}.react-resizable-handle-sw{bottom:0;left:0;cursor:sw-resize;transform:rotate(90deg)}.react-resizable-handle-se{bottom:0;right:0;cursor:se-resize}.react-resizable-handle-nw{top:0;left:0;cursor:nw-resize;transform:rotate(180deg)}.react-resizable-handle-ne{top:0;right:0;cursor:ne-resize;transform:rotate(270deg)}.react-resizable-handle-w,.react-resizable-handle-e{top:50%;margin-top:-10px;cursor:ew-resize}.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-resizable-handle-n,.react-resizable-handle-s{left:50%;margin-left:-10px;cursor:ns-resize}.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}._errorContainer_2i8y8_2{padding:20px;border:1px solid #dc2626;margin:10px;background-color:#fef2f2;border-radius:8px;color:#991b1b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}._errorContainer_2i8y8_2 h2{color:#991b1b;margin-top:0;margin-bottom:12px;font-size:1.25rem;font-weight:600}._errorContainer_2i8y8_2 p{margin-bottom:16px;line-height:1.5;color:#7f1d1d}._errorDetails_2i8y8_26{margin-top:20px;border:1px solid #f87171;border-radius:6px;background-color:#fff5f5}._errorDetails_2i8y8_26 summary{cursor:pointer;font-weight:600;padding:12px 16px;background-color:#fee2e2;border-radius:6px 6px 0 0;-webkit-user-select:none;user-select:none;color:#991b1b}._errorDetails_2i8y8_26 summary:hover{background-color:#fecaca}._errorDetails_2i8y8_26 summary:focus{outline:2px solid #f87171;outline-offset:2px}._errorDetails_2i8y8_26[open] summary{border-bottom:1px solid #f87171;border-radius:6px 6px 0 0}._errorText_2i8y8_57{padding:16px;border-bottom:1px solid #f87171;font-family:Courier New,Consolas,Monaco,monospace;font-size:.875rem;color:#7f1d1d;background-color:#fff}._errorText_2i8y8_57 strong{color:#991b1b;font-weight:600}._stackTrace_2i8y8_71{padding:16px;background-color:#fff}._stackTrace_2i8y8_71 strong{color:#991b1b;font-weight:600;display:block;margin-bottom:8px}._stackTrace_2i8y8_71 pre{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:4px;padding:12px;font-family:Courier New,Consolas,Monaco,monospace;font-size:.75rem;line-height:1.4;color:#374151;overflow-x:auto;margin:0;white-space:pre-wrap;word-break:break-all}@media (max-width: 768px){._errorContainer_2i8y8_2{margin:5px;padding:16px}._errorText_2i8y8_57,._stackTrace_2i8y8_71{padding:12px}._stackTrace_2i8y8_71 pre{font-size:.7rem;padding:8px}}._rendererLayout_cg8ic_2{display:flex;flex-direction:column;gap:1rem;padding:1rem;border:1px solid #e0e0e0;border-radius:4px}._subTypeSelector_cg8ic_11{display:flex;gap:.5rem;margin-bottom:1rem}._subTypeButton_cg8ic_17{padding:.4rem .8rem;border:1px solid #ccc;background-color:#f9f9f9;cursor:pointer;border-radius:4px}._subTypeButton_cg8ic_17._active_cg8ic_25{background-color:#e0e0f0;font-weight:700;border-color:#a0a0d0}._dataInputArea_cg8ic_31,._configArea_cg8ic_32,._csvArea_cg8ic_33{display:flex;flex-direction:column;gap:.5rem;padding:.5rem;border:1px solid #f0f0f0;border-radius:4px}._dataInputArea_cg8ic_31 h4,._configArea_cg8ic_32 h4,._csvArea_cg8ic_33 h4{margin-top:0;margin-bottom:.5rem;font-size:1em;font-weight:700}._dataRow_cg8ic_51{display:flex;gap:.5rem;align-items:center}._dataRow_cg8ic_51 input{width:100%;padding:.3rem;border:1px solid #ccc;border-radius:3px;flex-grow:1}._dataRow_cg8ic_51 input:focus{outline:2px solid #007bff;border-color:#007bff}._configItem_cg8ic_70{display:flex;flex-direction:column;gap:.25rem}._configItem_cg8ic_70 label{font-size:.9em;color:#333}._configItem_cg8ic_70 input[type=text],._configItem_cg8ic_70 input[type=color],._configItem_cg8ic_70 input[type=number]{padding:.4rem;border:1px solid #ccc;border-radius:3px;max-width:250px}._csvTextarea_cg8ic_90{width:100%;min-height:80px;padding:.5rem;border:1px solid #ccc;border-radius:3px;font-family:monospace;resize:vertical}._actionButtons_cg8ic_100{display:flex;gap:.5rem;margin-top:.5rem}._actionButtons_cg8ic_100 button{padding:.4rem .8rem;border:1px solid #007bff;background-color:#007bff;color:#fff;cursor:pointer;border-radius:4px}._actionButtons_cg8ic_100 button:hover{background-color:#0056b3}._actionButtons_cg8ic_100 button._secondary_cg8ic_119{background-color:#6c757d;border-color:#6c757d}._actionButtons_cg8ic_100 button._secondary_cg8ic_119:hover{background-color:#545b62}._actionButtons_cg8ic_100 button[disabled]{opacity:.5;cursor:not-allowed}._previewArea_cg8ic_133{margin-top:1rem;padding:1rem;border:1px dashed #ccc;background-color:#f8f9fa;min-height:300px;display:flex;justify-content:center;align-items:center}._validationError_cg8ic_144{color:#d9534f;font-size:.9em;padding:.5rem;border:1px solid #d9534f;border-radius:4px;background-color:#f2dede;margin-top:.5rem}._dataPointLimit_cg8ic_154{font-size:.8em;color:#666;margin-top:5px}.students-classes-page{padding:20px;max-width:1000px;margin:auto}.create-button,.edit-button,.delete-button,.view-button{margin-left:5px}.create-button{background-color:var(--primary-color);color:#fff;padding:10px 15px;border-radius:4px;text-decoration:none}.edit-button{background-color:#ffc107;color:#212529}.delete-button{background-color:#dc3545;color:#fff}.view-button{background-color:#17a2b8;color:#fff}.loading-message,.error-message,.empty-list-message{text-align:center;padding:20px;font-size:1.1em}.error-message{color:red;background-color:#ffebee;border:1px solid red}.empty-list-message{color:var(--secondary-color)}.data-table{width:100%;border-collapse:collapse;margin-top:20px;box-shadow:0 2px 8px #0000000d}.data-table th,.data-table td{border:1px solid #ddd;padding:12px 15px;text-align:left;vertical-align:middle}.data-table thead th{background-color:#f8f9fa;color:var(--primary-color);font-weight:700}.data-table tbody tr:nth-child(2n){background-color:#f9f9f9}.data-table tbody tr:hover{background-color:#f1f1f1}.actions-cell{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.actions-cell .button{padding:6px 10px;font-size:.9em}.student-details-grid,.class-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:20px}.detail-card{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000000d}.detail-card h2{color:var(--primary-color);margin-bottom:15px}.detail-card p{margin-bottom:10px}.detail-card strong{color:#555}.enrollment-list,.student-list{list-style:none;padding:0}.enrollment-list li,.student-list li{padding:8px 0;border-bottom:1px dotted #eee}.enrollment-list li:last-child,.student-list li:last-child{border-bottom:none}.manage-students-section h3{margin-top:20px;margin-bottom:10px}.manage-students-section .form-group{max-width:400px}.section-header h3{margin:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:white;border-radius:8px;width:90%;max-width:600px;max-height:80vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e9ecef}.modal-header h3{margin:0;color:var(--primary-color)}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#6c757d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:#495057}.modal-body{padding:20px}.modal-footer{padding:20px;border-top:1px solid #e9ecef;display:flex;justify-content:flex-end;gap:10px}.import-instructions{margin-bottom:20px}.import-instructions h4{margin-bottom:10px;color:var(--primary-color)}.import-instructions ul{margin:10px 0;padding-left:20px}.import-instructions li{margin-bottom:5px}.import-instructions em{color:#6c757d;font-size:.9em}.import-results{margin-top:20px;padding:15px;background:#f8f9fa;border-radius:4px}.import-results h4,.import-results h5{margin-top:0;margin-bottom:10px;color:var(--primary-color)}.results-summary p{margin:5px 0}.error-list{margin-top:15px;padding:10px;background:#ffebee;border:1px solid #f44336;border-radius:4px}.error-list ul{margin:0;padding-left:20px}.error-list li{color:#c62828;margin-bottom:3px}.class-dashboard{max-width:1200px}.class-dashboard-header{flex-direction:column;align-items:flex-start;gap:15px}.class-dashboard-header .header-main{display:flex;flex-direction:column;gap:8px}.class-dashboard-header .header-main h1{margin:0;font-size:1.8em}.class-dashboard-header .class-meta{display:flex;align-items:center;gap:10px;color:#6b7280;font-size:.95em}.class-meta .meta-divider{color:#d1d5db}.class-dashboard-header .header-actions{display:flex;gap:10px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:white;border:1px solid #e5e7eb;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;transition:all .2s ease}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #00000014}.stat-icon{font-size:2em;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px}.stat-content{flex:1}.stat-value{font-size:1.6em;font-weight:700;color:#1f2937}.stat-label{font-size:.85em;color:#6b7280;margin-top:2px}.tab-navigation{display:flex;gap:4px;margin-bottom:20px;background:#f3f4f6;padding:4px;border-radius:10px;width:fit-content}.tab-button{padding:10px 20px;background:transparent;border:none;border-radius:8px;cursor:pointer;font-size:.95em;font-weight:500;color:#6b7280;transition:all .2s ease}.tab-button:hover{color:#374151;background:rgba(255,255,255,.5)}.tab-button.active{background:white;color:var(--primary-color);box-shadow:0 1px 3px #0000001a}.tab-content{min-height:400px}.overview-tab{display:grid;gap:20px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.section-header h3{margin:0;color:#1f2937}.view-all-link{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:.9em;font-weight:500}.view-all-link:hover{text-decoration:underline}.empty-message{color:#9ca3af;text-align:center;padding:30px;font-style:italic}.recent-assessments-list{display:flex;flex-direction:column;gap:8px}.assessment-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f9fafb;border-radius:8px;transition:all .2s ease}.assessment-row.clickable{cursor:pointer}.assessment-row.clickable:hover{background:#f3f4f6;transform:translate(4px)}.assessment-info{display:flex;flex-direction:column;gap:4px}.assessment-title{font-weight:500;color:#1f2937;display:flex;align-items:center;gap:8px}.task-badge{font-size:.7em;padding:2px 6px;border-radius:4px;font-weight:600}.task-badge.summative{background:#fef3c7;color:#92400e}.assessment-date{font-size:.85em;color:#6b7280}.assessment-status{display:flex;gap:8px;flex-wrap:wrap}.status-badge{font-size:.75em;padding:4px 8px;border-radius:4px;font-weight:500}.status-badge.needs-print{background:#fff3cd;color:#856404}.status-badge.printed{background:#d4edda;color:#155724}.status-badge.results-done{background:#d1ecf1;color:#0c5460}.status-badge.needs-marking{background:#e2e3e5;color:#383d41}.quick-actions-grid{display:flex;gap:12px;flex-wrap:wrap}.quick-action-btn{padding:12px 20px;background:linear-gradient(135deg,var(--primary-color),#1d4ed8);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.9em;font-weight:500;transition:all .2s ease}.quick-action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.assessments-table th,.assessments-table td{padding:12px}.type-badge{font-size:.75em;padding:3px 8px;border-radius:4px;font-weight:600}.type-badge.summative{background:#fef3c7;color:#92400e}.type-badge.formative{background:#dbeafe;color:#1e40af}.print-status-badge,.results-status-badge{font-size:.8em;padding:4px 8px;border-radius:4px}.print-status-badge.not_printed{background:#fff3cd;color:#856404}.print-status-badge.confirmed,.results-status-badge.published{background:#d4edda;color:#155724}.results-status-badge.draft{background:#e2e3e5;color:#383d41}.small-button{padding:6px 12px!important;font-size:.8em!important;margin:2px!important}.small-button.secondary{background:#6c757d!important}.students-table tr.clickable{cursor:pointer;transition:background .2s ease}.students-table tr.clickable:hover{background:#f0f9ff}.student-name-cell{display:flex;align-items:center;gap:12px}.student-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--primary-color),#3b82f6);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8em;font-weight:600}.status-badge.status-active{background:#d4edda;color:#155724}.status-badge.status-inactive{background:#f8d7da;color:#721c24}.quick-actions-bar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.quick-action-btn.secondary{background:linear-gradient(135deg,#6b7280,#4b5563)}.overview-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:20px}@media (max-width: 900px){.overview-grid{grid-template-columns:1fr}}.overview-left,.overview-right{display:flex;flex-direction:column;gap:20px}.skills-breakdown{display:flex;flex-direction:column;gap:16px}.skill-bar{display:flex;flex-direction:column;gap:6px}.skill-info{display:flex;justify-content:space-between;align-items:center}.skill-name{font-weight:500;color:#374151;font-size:.9em}.skill-percent{font-weight:600;color:#1f2937;font-size:.9em}.skill-progress{height:10px;background:#e5e7eb;border-radius:5px;overflow:hidden}.skill-marks{font-size:.8em;color:#6b7280;font-weight:500}.skill-fill{height:100%;background:linear-gradient(90deg,#10b981,#34d399);border-radius:4px;transition:width .5s ease-out}.skill-fill.pending{background:linear-gradient(90deg,#60a5fa,#93c5fd)}.skill-fill.good{background:linear-gradient(90deg,#10b981,#34d399)}.skill-fill.moderate{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.skill-fill.needs-work{background:linear-gradient(90deg,#ef4444,#f87171)}.skill-fill.warning{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.skill-fill.danger{background:linear-gradient(90deg,#ef4444,#f87171)}.skill-percentage{font-weight:600;font-size:.9em}.skill-percentage.good{color:#10b981}.skill-percentage.moderate{color:#f59e0b}.skill-percentage.needs-work{color:#ef4444}.skill-gc-tags{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}.gc-tag{font-size:.7em;background:#e0e7ff;color:#4f46e5;padding:2px 6px;border-radius:10px}.skill-insights{margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.skill-insights .insight{font-size:.85em;padding:6px 10px;border-radius:6px;margin-bottom:6px}.skill-insights .insight.good{background:#d1fae5;color:#065f46}.skill-insights .insight.needs-attention{background:#fef3c7;color:#92400e}.student-rank.top-three{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;font-weight:700}.avg-score.good{color:#10b981;font-weight:600}.avg-score.moderate{color:#f59e0b;font-weight:600}.avg-score.needs-work{color:#ef4444;font-weight:600}.assessment-count{font-size:.75em;color:#9ca3af;margin-left:4px}.data-note{font-size:.8em;color:#9ca3af;margin-top:8px;font-style:italic}.gc-profile-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe)}.gc-profile-list{display:flex;flex-direction:column;gap:10px}.gc-profile-item{display:flex;flex-direction:column;gap:4px}.gc-name{font-size:.85em;font-weight:500;color:#1e40af}.gc-performance{display:flex;align-items:center;gap:8px}.gc-bar{flex:1;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.gc-fill{height:100%;border-radius:4px;transition:width .5s ease-out}.gc-fill.good{background:linear-gradient(90deg,#10b981,#34d399)}.gc-fill.moderate{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.gc-fill.needs-work{background:linear-gradient(90deg,#ef4444,#f87171)}.gc-pct{font-size:.85em;font-weight:600;min-width:45px;text-align:right}.gc-pct.good{color:#10b981}.gc-pct.moderate{color:#f59e0b}.gc-pct.needs-work{color:#ef4444}.gc-note{font-size:.75em;color:#64748b;margin-top:10px;font-style:italic}.student-performance-list{display:flex;flex-direction:column;gap:8px}.student-perf-row{display:flex;align-items:center;gap:12px;padding:10px;background:#f9fafb;border-radius:8px;transition:all .2s ease}.student-perf-row.clickable{cursor:pointer}.student-perf-row.clickable:hover{background:#f0f9ff;transform:translate(4px)}.student-rank{width:24px;height:24px;background:#e5e7eb;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75em;font-weight:600;color:#6b7280}.student-avatar-small{width:32px;height:32px;background:linear-gradient(135deg,var(--primary-color),#3b82f6);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7em;font-weight:600}.student-perf-info{flex:1;display:flex;flex-direction:column;gap:2px}.student-perf-info .student-name{font-weight:500;color:#1f2937;font-size:.9em}.student-stats{display:flex;gap:10px;font-size:.8em;color:#6b7280}.avg-score{font-weight:600}.trend.up{color:#10b981}.trend.down{color:#ef4444}.trend.neutral{color:#9ca3af}.insights-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe)}.insights-list{display:flex;flex-direction:column;gap:10px}.insight-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:.9em}.insight-icon{font-size:1.1em}.insight-item.warning{background:#fff7ed;color:#c2410c}.insight-item.info{background:#eff6ff;color:#1e40af}.insight-item.attention{background:#fef3c7;color:#b45309}.insight-item.success{background:#ecfdf5;color:#047857}.curriculum-mini-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86efac}.curriculum-mini-content{display:flex;align-items:center;gap:20px}.mini-coverage-circle{width:80px;height:80px;flex-shrink:0}.circular-chart.mini{width:100%;height:100%}.mini-coverage-stats{display:flex;flex-wrap:wrap;gap:15px;flex:1}.mini-stat{display:flex;flex-direction:column;gap:2px}.mini-stat-value{font-size:1.4em;font-weight:700;color:#166534}.mini-stat-label{font-size:.75em;color:#4b5563}.curriculum-tab{padding:0}.curriculum-analysis-layout{display:grid;grid-template-columns:2fr 1fr;gap:20px}.curriculum-main-content{display:flex;flex-direction:column;gap:20px}.gc-ccp-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.curriculum-sidebar{display:flex;flex-direction:column;gap:20px;align-self:start}.curriculum-sidebar .gaps-card{max-height:550px;overflow:hidden}.curriculum-sidebar .covered-card{max-height:450px;overflow:hidden}.gaps-list.scrollable{max-height:450px;overflow-y:auto;padding-right:8px}.covered-list.scrollable{max-height:350px;overflow-y:auto;padding-right:8px}.scrollable::-webkit-scrollbar{width:6px}.scrollable::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.covered-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86efac}.covered-summary{font-size:.9em;color:#166534;margin-bottom:10px}.covered-list{display:flex;flex-direction:column;gap:8px}.covered-cd-item{background:white;border-radius:6px;border-left:4px solid #86efac}.covered-cd-item.fully-covered{border-left-color:#22c55e}.covered-cd-item.partial{border-left-color:#fbbf24}.cd-header{display:flex;align-items:flex-start;gap:8px;padding:10px}.cd-header.clickable:hover{background:#f8fafc}.cd-header .expand-toggle{font-size:.7em;color:#6b7280;margin-top:2px}.cd-status{font-size:.75em;font-weight:600;padding:2px 6px;border-radius:4px;white-space:nowrap}.cd-status.full{background:#22c55e;color:#fff}.cd-status.partial{background:#fbbf24;color:#78350f}.cd-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.cd-code{font-size:.75em;font-weight:600;color:#059669}.cd-name{font-size:.85em;color:#374151;line-height:1.3}.elaborations-list{margin:0;padding:0 10px 10px 25px;list-style:none;border-top:1px dashed #e5e7eb}.elab-item{display:flex;align-items:flex-start;gap:8px;padding:6px 0;font-size:.8em;border-bottom:1px dotted #f3f4f6}.elab-item:last-child{border-bottom:none}.elab-check{font-weight:600;width:16px;text-align:center}.elab-item.covered .elab-check{color:#22c55e}.elab-item.not-covered .elab-check{color:#ef4444}.elab-name{flex:1;color:#4b5563;line-height:1.4;word-wrap:break-word}.elab-item.not-covered .elab-name{color:#6b7280}@media (max-width: 1200px){.curriculum-analysis-layout{grid-template-columns:1fr}.curriculum-gaps-sidebar{position:static}.curriculum-gaps-sidebar .gaps-card{max-height:none}}@media (max-width: 768px){.gc-ccp-row{grid-template-columns:1fr}}.curriculum-analysis-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 900px){.curriculum-analysis-grid{grid-template-columns:1fr}}.curriculum-overview-card{grid-column:span 2}@media (max-width: 900px){.curriculum-overview-card{grid-column:span 1}}.coverage-summary{display:flex;gap:40px;align-items:center;padding:20px}.coverage-circle{width:150px;height:150px;flex-shrink:0}.circular-chart{display:block;margin:0 auto;max-width:100%;max-height:100%}.circle-bg{fill:none;stroke:#e5e7eb;stroke-width:3.8}.circle-progress{fill:none;stroke-width:2.8;stroke-linecap:round;stroke:#10b981;animation:progress 1s ease-out forwards}@keyframes progress{0%{stroke-dasharray:0 100}}.percentage-text{fill:#1f2937;font-size:.5em;font-weight:700;text-anchor:middle}.coverage-stats{flex:1;display:flex;flex-direction:column;gap:12px}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background:#f9fafb;border-radius:8px}.stat-label{color:#6b7280;font-size:.95em}.stat-value{font-weight:600;color:#1f2937;font-size:1.1em}.achievement-standards-card{grid-column:span 2;max-height:400px;overflow-y:auto}@media (max-width: 900px){.achievement-standards-card{grid-column:span 1}}.standards-list{display:flex;flex-direction:column;gap:15px}.standard-item{padding:15px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:10px;border-left:4px solid #0284c7}.standard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.standard-code{font-weight:600;color:#0284c7;font-size:.85em;padding:2px 8px;background:white;border-radius:4px}.standard-area{font-size:.85em;color:#64748b;font-style:italic}.standard-description{color:#334155;font-size:.9em;line-height:1.5;margin:0}.standard-description p{margin:0}.gc-card h3{margin-bottom:15px}.gc-list{display:flex;flex-direction:column;gap:12px}.gc-category{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86efac;border-radius:10px;padding:14px 18px;transition:all .2s ease}.gc-category:hover{box-shadow:0 2px 8px #22c55e26}.gc-category-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.gc-icon{font-size:1.3em}.gc-category-name{font-weight:600;color:#166534;flex:1;font-size:1em}.gc-hit-badge{background:#22c55e;color:#fff;padding:3px 10px;border-radius:12px;font-size:.75em;font-weight:600}.gc-elements-list{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 0;padding:0;list-style:none}.gc-element{display:inline-block}.gc-level-badge{background:white;border:1px solid #86efac;color:#166534;padding:3px 10px;border-radius:4px;font-size:.8em;font-weight:500}.gc-element-more{color:#6b7280;font-size:.8em;font-style:italic;padding:3px 0}.gc-elements-list-detailed{margin:10px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:6px}.gc-element-detailed{display:flex;align-items:flex-start;gap:8px;background:white;padding:8px 12px;border-radius:6px;border-left:3px solid #22c55e;font-size:.85em}.gc-level-num{background:#16a34a;color:#fff;padding:2px 6px;border-radius:4px;font-size:.75em;font-weight:600;white-space:nowrap}.gc-element-desc{color:#374151;line-height:1.4;flex:1}.cross-links-list{display:flex;flex-direction:column;gap:12px}.cross-link-category{border-radius:10px;padding:14px 18px;transition:all .2s ease}.cross-link-category.gc-category{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86efac}.cross-link-category.ccp-category{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #93c5fd}.cross-link-category:hover{box-shadow:0 2px 8px #00000014}.category-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(0,0,0,.08)}.category-icon{font-size:1.3em}.category-name{font-weight:600;color:#166534;flex:1;font-size:1em}.ccp-category .category-name{color:#1e40af}.cross-link-items{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:6px}.cross-link-item{background:white;padding:8px 12px;border-radius:6px;font-size:.85em}.link-header{display:flex;align-items:center;gap:8px}.link-level-badge{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:2px 8px;border-radius:10px;font-size:.75em;font-weight:600;white-space:nowrap}.cross-link-item .link-header.clickable:hover{background:rgba(0,0,0,.03);border-radius:4px}.cross-link-item .expand-toggle{font-size:.7em;color:#6b7280;margin-right:6px;width:12px;display:inline-block}.cross-link-item.expanded{background:#f8fafc}.indicators-list{margin:8px 0 0 20px;padding:0;list-style:none;border-left:2px solid #e5e7eb}.indicator-item{padding:6px 12px;font-size:.85em;color:#4b5563;line-height:1.4;position:relative}.indicator-item:before{content:"→";position:absolute;left:-2px;color:#9ca3af}.gc-link .indicators-list{border-left-color:#22c55e}.ccp-link .indicators-list{border-left-color:#3b82f6}.ccp-content{display:flex;flex-direction:column;gap:4px}.ccp-theme{font-size:.75em;font-weight:600;color:#1e40af;text-transform:uppercase;letter-spacing:.5px}.ccp-organising-idea{color:#374151;line-height:1.5;font-size:.9em}.cross-link-item.gc-link{border-left:3px solid #22c55e}.cross-link-item.ccp-link{border-left:3px solid #3b82f6}.link-name{font-weight:500;color:#374151}.link-description{font-size:.9em;color:#6b7280;line-height:1.3}.cross-link-more{color:#6b7280;font-size:.8em;font-style:italic;padding:4px 0}.gc-note,.ccp-note,.coverage-note{font-size:.75em;color:#6b7280;margin-bottom:15px;font-style:italic}.coverage-note{margin-top:12px;padding-top:8px;border-top:1px dashed #e5e7eb}.gc-item{flex-direction:column;align-items:flex-start;gap:8px}.gc-item .gc-name{flex:1}.gc-elements,.ccp-elements{display:flex;flex-wrap:wrap;gap:4px;width:100%}.gc-element-tag,.ccp-element-tag{font-size:.7em;padding:2px 6px;background:rgba(255,255,255,.7);border-radius:4px;color:#4b5563;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gc-element-more,.ccp-element-more{font-size:.7em;color:#6b7280;font-style:italic}.ccp-list{display:flex;flex-direction:column;gap:10px}.ccp-item{display:flex;flex-direction:column;gap:8px;padding:12px 15px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:8px;border-left:3px solid #2563eb}.ccp-header{display:flex;justify-content:space-between;align-items:center;width:100%}.ccp-code{font-weight:600;color:#1e40af;font-size:.8em;padding:2px 6px;background:white;border-radius:3px}.ccp-name{flex:1;font-size:.95em;font-weight:500;color:#374151}.ccp-count{font-size:.8em;color:#1e40af;background:white;padding:2px 8px;border-radius:10px}.gaps-card{background:linear-gradient(135deg,#fff7ed,#ffedd5)}.gaps-summary{font-size:1.1em;margin-bottom:15px;padding:10px;background:white;border-radius:8px}.gaps-summary strong{color:#c2410c;font-size:1.2em}.gaps-list h4{font-size:.9em;color:#92400e;margin-bottom:10px}.gap-item{display:flex;flex-direction:column;gap:4px;padding:10px 12px;background:white;border-radius:6px;margin-bottom:8px;border-left:3px solid #f59e0b}.gap-item .gap-header{display:flex;align-items:center;gap:8px}.gap-code{font-size:.7em;font-weight:600;color:#92400e;background:#fef3c7;padding:2px 8px;border-radius:4px;white-space:nowrap}.gap-name{font-size:.85em;color:#374151;line-height:1.4}.gap-strand{font-size:.7em;color:#6b7280;font-style:italic;background:#f3f4f6;padding:2px 6px;border-radius:3px}.success-message{color:#047857;text-align:center;padding:20px;font-size:1.1em}.student-profile-page{padding:20px;max-width:1200px;margin:0 auto}.student-profile-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:linear-gradient(135deg,#1e3a5f 0%,#2d5a87 100%);border-radius:12px;color:#fff;margin-bottom:20px}.student-header-left{display:flex;align-items:center;gap:20px}.student-avatar.large{width:72px;height:72px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:1.8em;font-weight:600;color:#fff;border:3px solid rgba(255,255,255,.4)}.student-header-info h1{margin:0 0 8px;font-size:1.8em;color:#fff}.student-meta{display:flex;align-items:center;gap:10px;opacity:.9;font-size:.95em}.student-meta .separator{opacity:.5}.student-id{background:rgba(255,255,255,.15);padding:3px 10px;border-radius:4px;font-family:monospace}.student-header-right{display:flex;gap:10px}.student-header-right .button{padding:10px 16px;border-radius:6px;text-decoration:none;font-weight:500;transition:all .2s}.student-header-right .edit-button{background:rgba(255,255,255,.2);color:#fff;border:1px solid rgba(255,255,255,.3)}.student-header-right .edit-button:hover{background:rgba(255,255,255,.3)}.student-header-right .secondary-button{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3)}.student-quick-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}.student-quick-stats .stat-card{display:flex;align-items:center;gap:14px;padding:18px;background:white;border-radius:10px;box-shadow:0 2px 8px #0000000f;border:1px solid #e5e7eb}.student-quick-stats .stat-card.highlight-green{background:linear-gradient(135deg,#ecfdf5 0%,#d1fae5 100%);border-color:#6ee7b7}.student-quick-stats .stat-card.highlight-amber{background:linear-gradient(135deg,#fffbeb 0%,#fef3c7 100%);border-color:#fcd34d}.student-quick-stats .stat-icon{font-size:1.8em;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border-radius:10px}.student-quick-stats .stat-icon.trend-up{background:#d1fae5}.student-quick-stats .stat-icon.trend-down{background:#fee2e2}.student-quick-stats .stat-icon.trend-stable{background:#e0e7ff}.student-quick-stats .stat-value{font-size:1.5em;font-weight:700;color:#1e3a5f}.student-quick-stats .stat-label{font-size:.85em;color:#6b7280}.class-filter-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f8fafc;border-radius:8px;margin-bottom:20px;border:1px solid #e2e8f0}.class-filter-bar label{font-weight:500;color:#475569}.class-filter-select{padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;background:white;font-size:.95em;min-width:250px}.student-tabs{display:flex;gap:4px;border-bottom:2px solid #e5e7eb;margin-bottom:20px}.student-tabs .tab-button{padding:12px 20px;background:transparent;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;cursor:pointer;font-size:.95em;color:#6b7280;transition:all .2s}.student-tabs .tab-button:hover{color:#1e3a5f;background:#f8fafc}.student-tabs .tab-button.active{color:#1e3a5f;border-bottom-color:#2d5a87;font-weight:600}.student-tab-content{min-height:400px}.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.overview-card{background:white;border-radius:10px;padding:20px;box-shadow:0 2px 8px #0000000f;border:1px solid #e5e7eb}.overview-card h3{margin:0 0 16px;font-size:1.1em;color:#1e3a5f;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.overview-card.skills-mini-card{grid-column:1 / -1}.assessment-list{display:flex;flex-direction:column;gap:12px}.assessment-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f8fafc;border-radius:8px}.assessment-name{font-weight:500;color:#1e3a5f;margin-bottom:4px}.assessment-meta{display:flex;gap:12px;font-size:.85em;color:#6b7280}.assessment-score{display:flex;align-items:center;gap:8px}.assessment-score .score{font-weight:700;font-size:1.1em;padding:4px 12px;border-radius:6px}.assessment-score .grade{font-weight:600;color:#6b7280;background:#e5e7eb;padding:4px 8px;border-radius:4px}.score.excellent,.pct.excellent{color:#047857;background:#d1fae5}.score.good,.pct.good{color:#0369a1;background:#e0f2fe}.score.average,.pct.average{color:#92400e;background:#fef3c7}.score.below-average,.pct.below-average{color:#c2410c;background:#ffedd5}.score.poor,.pct.poor{color:#b91c1c;background:#fee2e2}.score.muted{color:#6b7280;background:#f3f4f6;font-weight:500}.class-performance-list{display:flex;flex-direction:column;gap:12px}.class-performance-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f8fafc;border-radius:8px}.class-info .class-name{font-weight:600;color:#1e3a5f;margin-bottom:4px}.class-info .class-meta{font-size:.85em;color:#6b7280}.class-scores{display:flex;align-items:center;gap:16px}.student-score,.class-avg-score,.rank{display:flex;flex-direction:column;align-items:center;gap:2px}.score-label,.rank-label{font-size:.75em;color:#9ca3af}.rank-value{font-weight:700;color:#1e3a5f}.skills-highlights{display:grid;grid-template-columns:1fr 1fr;gap:20px}.highlight-section h4{margin:0 0 12px;font-size:.95em;color:#6b7280}.skill-highlight{display:flex;justify-content:space-between;padding:10px 12px;border-radius:6px;margin-bottom:8px}.skill-highlight.good{background:#ecfdf5;border-left:3px solid #10b981}.skill-highlight.needs-work{background:#fef3c7;border-left:3px solid #f59e0b}.skill-highlight .skill-name{font-weight:500;color:#374151}.skill-highlight .skill-pct{font-weight:600}.skills-tab-content{padding:10px 0}.subject-filter{display:flex;align-items:center;gap:12px;margin-bottom:20px}.subject-filter select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;min-width:200px}.skills-list{display:flex;flex-direction:column;gap:16px}.skill-bar-item{background:white;border-radius:10px;padding:16px;box-shadow:0 2px 8px #0000000d;border:1px solid #e5e7eb}.skill-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.skill-bar-header .skill-info{display:flex;align-items:center;gap:10px}.skill-bar-header .skill-name{font-weight:600;color:#1e3a5f}.skill-bar-header .skill-subject{font-size:.85em;color:#6b7280;background:#f3f4f6;padding:3px 8px;border-radius:4px}.skill-bar-header .skill-percentage .pct{font-weight:700;font-size:1.3em;padding:4px 12px;border-radius:6px}.skill-bar-container{height:20px;background:#e5e7eb;border-radius:10px;overflow:hidden;position:relative;margin-bottom:8px}.skill-bar-fill{height:100%;border-radius:10px;transition:width .5s ease}.skill-bar-fill.excellent{background:linear-gradient(90deg,#10b981,#34d399)}.skill-bar-fill.good{background:linear-gradient(90deg,#0ea5e9,#38bdf8)}.skill-bar-fill.average{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.skill-bar-fill.below-average{background:linear-gradient(90deg,#f97316,#fb923c)}.skill-bar-fill.poor{background:linear-gradient(90deg,#ef4444,#f87171)}.class-avg-marker{position:absolute;top:0;width:3px;height:100%;background:#1e3a5f;z-index:2}.class-avg-marker:after{content:"▼";position:absolute;top:-12px;left:-5px;font-size:10px;color:#1e3a5f}.skill-meta{display:flex;justify-content:space-between;font-size:.85em;color:#6b7280}.skill-meta .comparison.above{color:#059669}.skill-meta .comparison.below{color:#dc2626}.capabilities-tab-content{padding:10px 0}.capabilities-intro{margin-bottom:24px}.capabilities-intro h3{margin:0 0 8px;color:#1e3a5f}.intro-text{color:#6b7280;margin:0}.gc-list{display:flex;flex-direction:column;gap:20px}.gc-card{background:white;border-radius:12px;padding:20px;box-shadow:0 2px 10px #0000000f;border:1px solid #e5e7eb}.gc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.gc-name{margin:0;font-size:1.15em;color:#1e3a5f}.gc-overall{font-size:1.5em;font-weight:700;display:flex;flex-direction:column;align-items:center;padding:8px 16px;border-radius:8px}.gc-overall .overall-label{font-size:.45em;font-weight:400;color:inherit;opacity:.8}.gc-subjects{display:flex;flex-direction:column;gap:10px}.gc-subject-item{display:grid;grid-template-columns:120px 1fr 60px;align-items:center;gap:12px}.gc-subject-item .subject-name{font-weight:500;color:#374151}.subject-bar-container{height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden}.subject-bar-fill{height:100%;border-radius:6px}.subject-bar-fill.excellent{background:#10b981}.subject-bar-fill.good{background:#0ea5e9}.subject-bar-fill.average{background:#f59e0b}.subject-bar-fill.below-average{background:#f97316}.subject-bar-fill.poor{background:#ef4444}.subject-pct{font-weight:600;text-align:right}.gc-insight{margin-top:12px;padding-top:12px;border-top:1px dashed #e5e7eb}.insight-text{font-size:.9em;font-style:italic}.insight-text.warning{color:#92400e}.insight-text.success{color:#059669}.trends-tab-content h3{margin:0 0 20px;color:#1e3a5f}.trends-timeline{position:relative;padding-left:30px;border-left:3px solid #e5e7eb;margin-left:60px}.trend-item{position:relative;margin-bottom:24px;padding-bottom:24px;border-bottom:1px dashed #e5e7eb}.trend-item:last-child{border-bottom:none;margin-bottom:0}.trend-date{position:absolute;left:-95px;top:0;font-size:.85em;color:#6b7280;width:60px;text-align:right}.trend-dot{position:absolute;left:-37px;top:4px;width:12px;height:12px;background:#2d5a87;border-radius:50%;border:3px solid white;box-shadow:0 0 0 2px #2d5a87}.trend-content{display:flex;justify-content:space-between;align-items:center;background:white;padding:14px 18px;border-radius:8px;box-shadow:0 2px 6px #0000000d}.trend-assessment{font-weight:600;color:#1e3a5f}.trend-subject{font-size:.85em;color:#6b7280;background:#f3f4f6;padding:3px 8px;border-radius:4px}.trend-score{font-size:1.3em;font-weight:700;color:#2d5a87}.subject-breakdown{margin-top:30px;padding:20px;background:#f8fafc;border-radius:10px}.subject-breakdown h4{margin:0 0 16px;color:#475569}.subject-trend-summary{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid #e2e8f0}.subject-trend-summary:last-child{border-bottom:none}.subject-trend-summary .subject-name{font-weight:600;color:#1e3a5f}.subject-trend-summary .subject-count{color:#6b7280}.subject-trend-summary .subject-avg{font-weight:600;color:#0ea5e9}.details-tab-content{display:flex;flex-direction:column;gap:20px}.details-tab-content .detail-card{background:white;border-radius:10px;padding:20px;box-shadow:0 2px 8px #0000000d;border:1px solid #e5e7eb}.details-tab-content .detail-card h3{margin:0 0 16px;color:#1e3a5f;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item label{font-size:.85em;color:#6b7280;font-weight:500}.detail-item span{font-size:1em;color:#1e3a5f}.status-active{color:#059669;font-weight:600}.status-inactive{color:#dc2626;font-weight:600}.future-placeholder{background:#f8fafc;border-style:dashed}.placeholder-text{color:#9ca3af;font-style:italic;margin:0}.empty-state{text-align:center;padding:60px 20px;color:#6b7280}.empty-state h3{margin:0 0 12px;color:#374151}.empty-state .hint{font-size:.9em;color:#9ca3af;margin-top:8px}.empty-message{color:#9ca3af;font-style:italic;text-align:center;padding:20px}@media (max-width: 900px){.student-quick-stats{grid-template-columns:repeat(2,1fr)}.overview-grid,.skills-highlights{grid-template-columns:1fr}.student-profile-header{flex-direction:column;gap:20px;text-align:center}.student-header-left{flex-direction:column}.student-meta{flex-wrap:wrap;justify-content:center}.gc-subject-item{grid-template-columns:80px 1fr 50px}.trends-timeline{margin-left:20px}.trend-date{left:-55px;font-size:.75em;width:45px}}@media (max-width: 600px){.student-quick-stats{grid-template-columns:1fr}.student-tabs{overflow-x:auto}.student-tabs .tab-button{white-space:nowrap;padding:10px 14px;font-size:.85em}.detail-grid{grid-template-columns:1fr}}.assessments-tab-content{padding:10px 0}.assessments-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.assessments-header h3{margin:0;color:#1e3a5f}.subject-filter-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;min-width:180px;background:white}.assessments-table{background:white;border-radius:10px;overflow:hidden;box-shadow:0 2px 8px #0000000f;border:1px solid #e5e7eb}.assessments-table table{width:100%;border-collapse:collapse}.assessments-table th{background:#f8fafc;padding:14px 16px;text-align:left;font-weight:600;color:#475569;font-size:.85em;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e5e7eb}.assessments-table td{padding:14px 16px;border-bottom:1px solid #f1f5f9;color:#374151}.assessments-table tbody tr:hover{background:#f8fafc}.assessment-name-cell{font-weight:500;color:#1e3a5f;max-width:250px}.subject-badge{background:#e0e7ff;color:#4338ca;padding:3px 8px;border-radius:4px;font-size:.8em;font-weight:500}.score-pill{padding:4px 10px;border-radius:20px;font-weight:600;font-size:.9em}.grade-badge{background:#f3f4f6;color:#374151;padding:4px 10px;border-radius:4px;font-weight:600}.class-avg-cell{color:#6b7280}.assessments-summary{display:flex;gap:24px;margin-top:16px;padding:16px 20px;background:#f8fafc;border-radius:8px}.summary-item{display:flex;gap:8px}.summary-label{color:#6b7280}.summary-value{font-weight:600;color:#1e3a5f}.details-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-bottom:20px}@media (max-width: 900px){.details-grid{grid-template-columns:1fr}}.qr-code-card{display:flex;flex-direction:column}.qr-code-display{display:flex;flex-direction:column;gap:12px}.qr-code-value{display:flex;flex-direction:column;gap:6px}.qr-label{font-size:.85em;color:#6b7280}.qr-code-text{font-family:Courier New,monospace;background:#f1f5f9;padding:12px 16px;border-radius:6px;font-size:1em;color:#1e3a5f;border:1px solid #e2e8f0;word-break:break-all}.qr-hint{font-size:.85em;color:#9ca3af;margin:0;font-style:italic}.detail-item.full-width{grid-column:1 / -1}.classes-list{display:flex;flex-wrap:wrap;gap:8px}.class-tag{display:inline-flex;align-items:center;gap:6px;background:#e0e7ff;color:#3730a3;padding:6px 12px;border-radius:6px;font-weight:500}.class-tag .class-subject{font-size:.8em;background:#c7d2fe;padding:2px 6px;border-radius:4px;color:#4338ca}.assessment-item.clickable{text-decoration:none;color:inherit;cursor:pointer;transition:all .2s;position:relative}.assessment-item.clickable:hover{background:#f0f9ff;transform:translate(4px)}.assessment-item .click-hint{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#0ea5e9;font-size:.85em;opacity:0;transition:opacity .2s}.assessment-item.clickable:hover .click-hint{opacity:1}.assessments-table .clickable-row{cursor:pointer;transition:background .2s}.assessments-table .clickable-row:hover{background:#f0f9ff!important}.assessments-table .clickable-row td a{color:#1e3a5f;text-decoration:none}.assessments-table .clickable-row:hover td a{color:#0ea5e9;text-decoration:underline}.ccp-section{margin-top:40px;padding-top:32px;border-top:2px solid #e5e7eb}.ccp-list{display:flex;flex-direction:column;gap:20px}.ccp-card{background:linear-gradient(135deg,#f0fff4 0%,#f8fff0 100%);border-radius:12px;padding:20px;border:1px solid #d4e6da}.ccp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.ccp-name{margin:0;font-size:1.1rem;color:#1e3a5f;display:flex;align-items:center;gap:8px}.ccp-overall{display:flex;flex-direction:column;align-items:center;font-size:1.25rem;font-weight:700;padding:8px 16px;border-radius:8px;background:white;box-shadow:0 2px 4px #00000014}.ccp-overall .overall-label{font-size:.7rem;font-weight:500;opacity:.8;margin-top:2px}.ccp-subjects{display:flex;flex-direction:column;gap:10px}.ccp-subject-item{display:grid;grid-template-columns:60px 1fr 50px;align-items:center;gap:12px}.ccp-subject-item .subject-name{font-size:.9rem;font-weight:600;color:#374151}.ccp-subject-item .subject-bar-container{height:10px;background:#e5e7eb;border-radius:5px;overflow:hidden}.ccp-subject-item .subject-bar-fill{height:100%;border-radius:5px;transition:width .4s ease}.ccp-subject-item .subject-pct{font-size:.9rem;font-weight:600;text-align:right}.form-page-container{max-width:800px;margin:2rem auto;padding:2rem;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a}.data-form .form-group{margin-bottom:1.5rem}.data-form label{display:block;margin-bottom:.5rem;font-weight:600;color:#333}.data-form input[type=text],.data-form input[type=email],.data-form input[type=password],.data-form input[type=date],.data-form input[type=number],.data-form textarea,.data-form select{width:100%;padding:.75rem;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:1rem}.data-form textarea{min-height:100px;resize:vertical}.data-form .form-group-checkbox{display:flex;align-items:center}.data-form .form-group-checkbox input[type=checkbox]{width:auto;margin-right:.75rem}.form-actions{margin-top:2rem;display:flex;gap:1rem;justify-content:flex-start}.button-primary,.button-secondary{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer;text-decoration:none;display:inline-block;text-align:center}.button-primary{background-color:#007bff;color:#fff}.button-primary:hover{background-color:#0056b3}.button-secondary{background-color:#6c757d;color:#fff}.button-secondary:hover{background-color:#545b62}.error-message{color:#d9534f;background-color:#f8d7da;border:1px solid #f5c6cb;padding:.75rem;border-radius:4px;margin-bottom:1rem}.success-message{color:#28a745;background-color:#d4edda;border:1px solid #c3e6cb;padding:.75rem;border-radius:4px;margin-bottom:1rem}.data-form input:disabled,.data-form textarea:disabled,.data-form select:disabled,.button-primary:disabled,.button-secondary:disabled{background-color:#e9ecef;opacity:.7;cursor:not-allowed}.results-page{padding:20px;max-width:1000px;margin:auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:1px solid #eee}.loading-message,.error-message,.success-message,.info-message{text-align:center;padding:15px;margin:15px 0;border-radius:4px;font-size:1.05em}.success-message{color:#155724;background-color:#d4edda;border:1px solid #c3e6cb}.info-message{color:#0c5460;background-color:#d1ecf1;border:1px solid #bee5eb}.results-form .selection-row{display:flex;gap:20px;margin-bottom:20px;flex-wrap:wrap}.results-form .simplified-selection{background:#f8f9fa;padding:20px;border-radius:8px;border:1px solid #e9ecef;margin-bottom:24px}.results-form .simplified-selection .form-group{flex:1;min-width:200px}.results-form .simplified-selection label{color:var(--primary-color);font-size:.9em;margin-bottom:8px}.results-form .assessment-select-group{flex:2}.results-form .class-select-group{flex:1}.show-all-checkbox{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:.85em;font-weight:400;color:#666;cursor:pointer}.show-all-checkbox input[type=checkbox]{margin:0;cursor:pointer}.selected-student-info-container{display:flex;flex-wrap:wrap;align-items:center;gap:20px;padding:12px 16px;background:#f0f4ff;border-radius:8px;margin-top:12px}.selected-student-info{flex:1}.attendance-status-selector{display:flex;align-items:center;gap:10px}.attendance-status-selector label{font-weight:500;color:#555;font-size:.9em}.attendance-select{padding:6px 12px;border:1px solid #ccc;border-radius:4px;font-size:.9em;min-width:100px}.attendance-select.absent{background-color:#fff3cd;border-color:#ffc107;color:#856404}.attendance-select.exempt{background-color:#d1ecf1;border-color:#17a2b8;color:#0c5460}.absence-reason-input{padding:6px 10px;border:1px solid #ccc;border-radius:4px;font-size:.9em;width:200px}.absence-reason-input::placeholder{color:#999}.results-table tbody tr.absent-row,.results-table tbody tr.absent-row td{background-color:#fff3cd!important}.results-table tbody tr.exempt-row,.results-table tbody tr.exempt-row td{background-color:#d1ecf1!important}.attendance-badge{display:inline-block;padding:2px 6px;margin-left:8px;border-radius:3px;font-size:.7em;font-weight:700;vertical-align:middle}.attendance-badge.absent{background-color:#ffc107;color:#856404}.attendance-badge.exempt{background-color:#17a2b8;color:#fff}.table-attendance-select{width:100%;padding:3px 5px;font-size:.75em;border:1px solid #ddd;border-radius:3px;margin-top:4px;cursor:pointer}.table-attendance-select.absent{background-color:#ffc107;color:#856404;border-color:#ffc107}.table-attendance-select.exempt{background-color:#17a2b8;color:#fff;border-color:#17a2b8}.results-actions{margin-top:20px;padding:20px;background:#f8f9fa;border-radius:8px;border:1px solid #dee2e6}.results-status-indicator{margin-bottom:15px}.status-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-weight:500;font-size:.9em}.status-badge.status-not_started{background-color:#e9ecef;color:#6c757d}.status-badge.status-in_progress{background-color:#fff3cd;color:#856404}.status-badge.status-draft{background-color:#d1ecf1;color:#0c5460}.status-badge.status-published{background-color:#d4edda;color:#155724}.publish-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24;padding:12px 15px;border-radius:6px;margin-bottom:15px}.publish-error ul{margin:8px 0 0 20px;padding:0}.publish-error li{margin:4px 0}.results-buttons{display:flex;gap:15px;align-items:center;flex-wrap:wrap}.publish-button{padding:12px 24px;background-color:#28a745;color:#fff;border:none;border-radius:6px;font-size:1em;font-weight:500;cursor:pointer;transition:background-color .2s}.publish-button:hover:not(:disabled){background-color:#218838}.publish-button:disabled{background-color:#94d3a2;cursor:not-allowed}.published-notice{color:#155724;font-style:italic;font-size:.9em}.instance-actions-secondary{padding:12px;background:#fff3cd;border-radius:6px;margin-bottom:16px;display:flex;align-items:center;gap:12px}.instance-actions-secondary p{margin:0;font-size:.9em}.btn-secondary.btn-small{padding:6px 12px;font-size:.85em}.results-form .selection-row .form-group{flex:1;min-width:250px}.results-form label{font-weight:700;display:block;margin-bottom:5px}.results-form select,.results-form input[type=text],.results-form textarea{width:100%;padding:10px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box}.instance-actions{margin-top:10px;padding:15px;background-color:#f8f9fa;border-radius:6px;border:1px solid #dee2e6}.instance-actions .info-message-small{margin:0 0 15px;font-size:.95em}.results-entry-grid{margin-top:20px}.results-entry-grid h2{margin-bottom:15px;color:var(--primary-color)}.student-selector-container{margin:20px 0;padding:15px;background-color:#f5f8fa;border-radius:8px;border:1px solid #e1e8ed}.student-selector-container h3{margin-top:0;margin-bottom:15px;color:var(--secondary-color)}.student-search-container{position:relative;margin-bottom:15px}.student-dropdown-wrapper{position:relative}.student-search-input{width:100%;padding:10px 15px;border:1px solid #ccc;border-radius:4px;font-size:16px;box-shadow:0 1px 3px #0000001a}.student-dropdown{position:absolute;top:100%;left:0;right:0;max-height:300px;overflow-y:auto;border:1px solid #ddd;border-radius:4px;background-color:#fff;box-shadow:0 2px 5px #00000026;z-index:1000;display:none}.student-dropdown.open{display:block}.student-option{padding:10px 15px;cursor:pointer;border-bottom:1px solid #eee}.student-option:hover{background-color:#f0f7ff}.student-option.selected{background-color:#e3f2fd;font-weight:500}.no-students-found{padding:15px;text-align:center;color:#666;font-style:italic}.selected-student-info{margin-top:10px;padding:10px;background-color:#e8f5e9;border-radius:4px;border-left:4px solid var(--primary-color)}.student-results-section{margin-bottom:30px;padding:20px;border:1px solid #e0e0e0;border-radius:6px;background-color:#f9f9f9}.student-results-section h3{margin-top:0;margin-bottom:15px;color:var(--secondary-color);border-bottom:1px solid #eee;padding-bottom:10px}.section-entry{margin-bottom:20px;padding-left:10px}.section-entry h4{font-style:italic;color:#555;margin-bottom:10px}.question-entry{margin-bottom:15px}.question-entry label{font-weight:400;color:#333}.question-entry .option-input{display:flex;align-items:center;margin-top:5px}.question-entry .option-input input[type=radio],.question-entry .option-input input[type=checkbox]{width:auto;margin-right:8px}.question-entry .option-input label{font-weight:400;margin-bottom:0}.results-submit-button{width:100%;padding:12px;font-size:1.1em;margin-top:20px;background-color:var(--primary-color);color:#fff}.results-submit-button:disabled{background-color:#ccc}.question-input{margin-top:15px;padding:10px;background-color:#f8f9fa;border-radius:6px;border:1px solid #e9ecef}.question-input.marks-input{padding:8px 12px}.question-input.marks-input .marks-row{display:flex;align-items:center;gap:10px}.question-input label{font-weight:700;color:#495057;margin:0;white-space:nowrap}.question-input .marks-input-field{width:60px;padding:6px 8px;border:1px solid #ced4da;border-radius:4px;font-size:14px;text-align:center}.question-input .max-marks{font-weight:700;color:#6c757d;white-space:nowrap}.question-input .student-answer-section{margin-top:8px}.question-input .answer-details{border:none;background:none}.question-input .answer-summary{cursor:pointer;font-size:12px;color:#6c757d;margin:4px 0;padding:2px 0;border:none;background:none;font-weight:400}.question-input .answer-summary:hover{color:#495057}.question-input .student-answer-textarea{width:100%;padding:6px 8px;border:1px solid #ced4da;border-radius:3px;font-size:13px;resize:vertical;min-height:50px;margin-top:4px}.question-input .marks-comment{margin-top:8px}.question-input .comment-textarea{width:100%;padding:4px 6px;border:1px solid #ced4da;border-radius:3px;font-size:12px;resize:vertical;min-height:24px}.question-input.text-input{margin-top:15px;padding:12px;background-color:#f8f9fa;border-radius:6px;border:1px solid #dee2e6}.question-input.text-input .text-input-label{display:block;font-weight:700;color:#495057;margin-bottom:8px;font-size:14px}.question-input.text-input .text-input-field{width:100%;padding:10px;border:1px solid #ced4da;border-radius:4px;font-size:14px;line-height:1.4;resize:vertical;min-height:80px;background-color:#fff;font-family:inherit}.question-input.text-input .text-input-field:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.question-input.text-input-preview{margin-top:20px;padding:0}.question-input.text-input-preview .answer-space-container{border:2px solid #6c757d;border-radius:8px;background-color:#fff;padding:0;overflow:hidden}.question-input.text-input-preview .answer-space-header{background-color:#f8f9fa;padding:8px 12px;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;align-items:center}.question-input.text-input-preview .answer-label{font-weight:700;color:#495057;font-size:14px}.question-input.text-input-preview .lines-hint{font-size:12px;color:#6c757d;font-style:italic}.question-input.text-input-preview .answer-space{padding:15px;min-height:200px;position:relative}.question-input.text-input-preview .writing-line{border-bottom:1px solid #dee2e6;height:24px;margin-bottom:8px;width:100%}.question-input.text-input-preview .writing-line:last-child{margin-bottom:0}.question-input.text-input-preview .extra-space{height:40px;border-bottom:1px solid #dee2e6;margin-top:10px}.results-message{text-align:center;padding:40px 20px;background-color:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.results-message p{margin:10px 0;color:#6c757d}.results-view-page .results-filters{background-color:#fff;padding:20px;border-radius:8px;margin-bottom:25px;box-shadow:0 2px 4px #0000000d}.results-view-page .results-filters h3{margin-top:0;margin-bottom:15px}.results-view-page .filter-options{display:flex;gap:15px;align-items:center;flex-wrap:wrap}.results-view-page .filter-options select{min-width:200px;padding:10px;border-radius:4px;border:1px solid #ccc}.results-view-page .filter-button{padding:10px 15px;background-color:var(--primary-color);color:#fff}.results-display-area{margin-top:20px}.results-display-area h2{margin-bottom:15px}.result-group{background-color:#fff;padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px #0000000d}.result-group h4{margin-top:0;margin-bottom:15px;color:var(--primary-color)}.result-item{padding:8px 0;border-bottom:1px dotted #eee}.result-item:last-child{border-bottom:none}.result-item p{margin:5px 0}.result-item .comment{font-size:.9em;color:#555;padding-left:15px}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.results-header h2{margin:0;color:var(--primary-color)}.view-mode-toggle{display:flex;gap:10px}.toggle-btn{padding:8px 16px;border:1px solid #ddd;background:white;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease}.question-options{margin-top:15px}.question-option{display:flex;align-items:flex-start;margin-bottom:8px;padding:8px;background-color:#f8f9fa;border-radius:4px;border:1px solid #e9ecef}.option-label{font-weight:700;color:#495057;margin-right:8px;min-width:20px}.option-content{flex:1}.option-text{margin-bottom:8px}.correct-indicator{color:#28a745;font-weight:700;margin-left:8px}.toggle-btn:hover{background:#f8f9fa}.toggle-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.student-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.student-selector-header h3{margin:0}.results-entry-table{margin-top:20px}.results-entry-table h2{margin-bottom:15px;color:var(--primary-color)}.table-container{overflow-x:auto;border-radius:8px;box-shadow:0 2px 4px #0000001a;background-color:#fff}.results-table th,.results-table td{padding:8px 12px;text-align:left;border-bottom:1px solid #e9ecef}.results-table th{background-color:#f8f9fa;font-weight:600;color:#495057;position:sticky;top:0;z-index:10}.student-column{min-width:200px;max-width:250px;position:sticky;left:0;background-color:#fff;z-index:5}.student-column:after{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background-color:#dee2e6}.student-info{display:flex;flex-direction:column}.student-name{font-weight:500;color:#212529}.question-column{min-width:120px;max-width:200px}.question-header{display:flex;flex-direction:column;gap:2px}.question-number{font-weight:700;font-size:12px;color:var(--primary-color)}.question-text{font-size:12px;color:#495057;line-height:1.3}.question-marks{font-size:11px;color:#6c757d;font-weight:500}.marks-column{text-align:center;min-width:80px}.table-marks-input{width:100%;min-width:60px;padding:6px 8px;border:1px solid #ced4da;border-radius:4px;font-size:14px;text-align:center;transition:border-color .15s ease-in-out}.table-marks-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 .2rem #007bff40}.table-marks-input:disabled{background-color:#e9ecef;cursor:not-allowed}.multi-skill-cell{padding:4px!important}.skill-inputs-compact{display:flex;flex-direction:column;gap:3px}.skill-input-row{display:flex;align-items:center;gap:3px;font-size:.8em}.skill-abbrev{font-weight:500;color:#555;min-width:30px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.table-skill-marks-input{width:40px;padding:2px 4px;border:1px solid #ced4da;border-radius:3px;font-size:.9em;text-align:center}.table-skill-marks-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 .1rem #007bff40}.skill-max-tiny{font-size:.75em;color:#888}.skill-total-row{font-size:.75em;color:#666;text-align:right;margin-top:2px;padding-top:2px;border-top:1px solid #eee}.per-skill-marks .skill-marks-header{margin-bottom:8px;font-weight:500}.per-skill-marks .skill-marks-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.per-skill-marks .skill-mark-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#f8f9fa;border-radius:4px}.per-skill-marks .skill-name{flex:1;font-weight:500;color:#333}.per-skill-marks .skill-marks-input-field{width:60px;padding:4px 8px;border:1px solid #ced4da;border-radius:4px;text-align:center}.per-skill-marks .skill-max{color:#666;font-size:.9em}.per-skill-marks .skill-marks-total{font-size:.9em;color:#666;padding:6px 10px;background:#e9ecef;border-radius:4px;margin-bottom:8px}.per-skill-marks .skill-marks-total.warning{background:#fff3cd;color:#856404}.per-skill-marks .marks-warning{color:#dc3545}.results-table tbody tr.selected-row,.results-table tbody tr.selected-row .student-column{background-color:#e3f2fd}.results-table tbody tr:hover,.results-table tbody tr:hover .student-column{background-color:#f8f9fa}.table-instructions{margin-top:15px;padding:12px 16px;background-color:#e7f3ff;border-radius:6px;border-left:4px solid var(--primary-color)}.table-instructions p{margin:0;color:#495057;font-size:14px}@media (max-width: 768px){.question-column{min-width:100px;max-width:150px}.student-column{min-width:150px;max-width:200px}.question-text{font-size:11px}.question-marks{font-size:10px}}.results-entry-table.loading{opacity:.6;pointer-events:none}.results-table tbody tr.clickable-row{cursor:pointer;transition:background-color .2s ease}.results-table tbody tr.clickable-row:hover,.results-table tbody tr.clickable-row:hover .student-column{background-color:#e3f2fd}.row-indicator{font-size:11px;color:#6c757d;margin-top:2px;font-weight:500}.row-indicator.selected{color:var(--primary-color)}.missing-students-notice{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;padding:15px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.missing-students-notice p{margin:0;color:#856404;font-weight:500}.initialize-button{background:#28a745;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s}.initialize-button:hover:not(:disabled){background:#218838}.initialize-button:disabled{background:#6c757d;cursor:not-allowed}.detailed-results{display:grid;gap:20px}.student-result-card{background:white;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;border:1px solid #e9ecef}.student-result-card.absent{background:#fff3cd;border-color:#ffeaa7}.student-result-card.exempt{background:#cce5ff;border-color:#b8daff}.student-result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e9ecef}.student-result-header h4{margin:0;font-size:1.1rem;color:#333;display:flex;align-items:center;gap:8px}.view-visual-btn{background:var(--primary-color, #2563eb);color:#fff;padding:8px 16px;border-radius:6px;text-decoration:none;font-size:.85rem;font-weight:500;transition:background-color .2s}.view-visual-btn:hover{background:#1d4ed8;color:#fff}.attendance-badge{font-size:.75rem;padding:3px 8px;border-radius:12px;font-weight:600;text-transform:uppercase}.absence-notice{padding:16px;background:rgba(0,0,0,.05);border-radius:8px;font-style:italic;color:#666}.result-summary{display:flex;gap:24px;margin-bottom:20px;flex-wrap:wrap}.summary-item{display:flex;flex-direction:column;gap:4px}.summary-item .label{font-size:.8rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.summary-item .value{font-size:1.25rem;font-weight:600;color:#333}.summary-item .value.grade{color:var(--primary-color, #2563eb)}.question-results-visual{margin-top:16px}.section-results{margin-bottom:16px}.section-results h5{margin:0 0 10px;font-size:.9rem;color:#555;font-weight:500}.questions-grid{display:flex;flex-wrap:wrap;gap:8px}.question-result-item{display:flex;flex-direction:column;align-items:center;padding:8px 12px;border-radius:8px;min-width:60px;border:2px solid}.question-result-item.good{background:#d4edda;border-color:#28a745}.question-result-item.partial{background:#fff3cd;border-color:#ffc107}.question-result-item.poor{background:#f8d7da;border-color:#dc3545}.question-result-item.no-data{background:#f8f9fa;border-color:#dee2e6}.question-result-item .q-label{font-size:.75rem;font-weight:600;color:#555;margin-bottom:2px}.question-result-item .q-marks{font-size:.9rem;font-weight:500}.results-table-container{background:white;border-radius:8px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.results-table-header{display:flex;justify-content:space-between;align-items:center;padding:20px;background:#f8f9fa;border-bottom:1px solid #e9ecef}.results-table-header h3{margin:0;color:#495057}.results-table-actions{display:flex;gap:10px}.export-button{background:#007bff;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px}.export-button:hover{background:#0056b3}.results-table-wrapper{max-height:70vh;overflow-y:auto}.results-table{width:100%;border-collapse:collapse;font-size:14px}.results-table th,.results-table td{padding:12px 8px;text-align:center;border-bottom:1px solid #e9ecef}.results-table th{background:#f8f9fa;font-weight:600;color:#495057;position:sticky;top:0;z-index:10}.student-column{text-align:left;min-width:200px;position:sticky;left:0;background:#f8f9fa;z-index:20}.question-column{min-width:80px;max-width:120px}.results-table-row:hover{background:#f8f9fa}.student-cell{text-align:left;background:white;position:sticky;left:0;z-index:15}.student-info{display:flex;flex-direction:column;gap:2px}.student-info .student-name{display:inline}.student-name{font-weight:500;color:#495057}.student-id{font-size:12px;color:#6c757d}.question-cell{background:white}.result-input{width:100%;padding:6px 8px;border:1px solid #ced4da;border-radius:4px;text-align:center;font-size:14px}.result-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.result-value{font-weight:500;color:#495057}.total-cell,.percentage-cell,.grade-cell{font-weight:600;background:#e9ecef}.total-cell{color:#28a745}.percentage-cell{color:#007bff}.grade-cell{color:#6f42c1}@media (max-width: 1200px){.results-table th,.results-table td{padding:8px 4px;font-size:12px}.student-column{min-width:150px}.question-column{min-width:60px;max-width:80px}}.results-table-row.absent-row{background:#fff3cd}.results-table-row.absent-row:hover{background:#ffe8a1}.results-table-row.absent-row .student-cell{background:#fff3cd}.results-table-row.exempt-row{background:#cce5ff}.results-table-row.exempt-row:hover{background:#b3d7ff}.results-table-row.exempt-row .student-cell{background:#cce5ff}.attendance-badge{font-size:10px;padding:2px 6px;border-radius:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.attendance-badge.absent{background:#dc3545;color:#fff}.attendance-badge.exempt{background:#17a2b8;color:#fff}.absence-reason{font-size:11px;color:#856404;font-style:italic;margin-top:2px}.result-value.not-present{color:#adb5bd}.results-table-loading{text-align:center;padding:40px;color:#6c757d}.student-test-view{max-width:900px;margin:0 auto;padding:24px}.test-view-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e9ecef}.header-left .back-link{color:#666;text-decoration:none;font-size:.9rem;display:inline-block;margin-bottom:8px}.header-left .back-link:hover{color:#2563eb}.test-view-header h1{margin:0 0 8px;font-size:1.5rem;color:#333}.test-meta{display:flex;gap:12px;color:#666;font-size:.9rem}.test-meta .divider{color:#ccc}.print-btn{background:#2563eb;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s;box-shadow:0 2px 4px #2563eb4d}.print-btn:hover{background:#1d4ed8;box-shadow:0 4px 8px #2563eb66}.student-info-card{display:flex;align-items:center;gap:20px;background:white;padding:20px;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:24px}.student-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:600;flex-shrink:0}.student-details{flex:1}.student-details h2{margin:0 0 4px;font-size:1.25rem;color:#333}.student-id{color:#666;font-size:.85rem}.status-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;margin-left:12px}.status-badge.absent{background:#dc3545;color:#fff}.status-badge.exempt{background:#17a2b8;color:#fff}.result-summary{display:flex;gap:24px;margin-left:auto}.summary-stat{text-align:center}.summary-stat .label{display:block;font-size:.75rem;color:#666;text-transform:uppercase;margin-bottom:4px}.summary-stat .value{font-size:1.25rem;font-weight:600;color:#333}.summary-stat .value.grade{color:#2563eb}.absence-notice{padding:20px;border-radius:12px;margin-bottom:24px;font-size:1rem}.absence-notice.absent{background:#fff3cd;border:1px solid #ffeaa7;color:#856404}.absence-notice.exempt{background:#cce5ff;border:1px solid #b8daff;color:#004085}.test-content{background:white;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.test-section{padding:24px;border-bottom:1px solid #e9ecef}.test-section:last-child{border-bottom:none}.section-title{margin:0 0 16px;font-size:1.1rem;color:#333;font-weight:600}.section-description{padding:16px;background:#f8f9fa;border-radius:8px;margin-bottom:20px;font-size:.95rem;line-height:1.6}.questions-list{display:flex;flex-direction:column;gap:16px}.question-card{background:#f8f9fa;border-radius:10px;padding:16px;border-left:4px solid;position:relative}.question-card.excellent{border-left-color:#28a745;background:linear-gradient(135deg,#f8fff9 0%,#f0fff2 100%)}.question-card.good{border-left-color:#20c997;background:linear-gradient(135deg,#f0fffc 0%,#e8fff8 100%)}.question-card.partial{border-left-color:#ffc107;background:linear-gradient(135deg,#fffef0 0%,#fffce8 100%)}.question-card.poor{border-left-color:#dc3545;background:linear-gradient(135deg,#fff8f8 0%,#fff0f0 100%)}.question-card.no-data{border-left-color:#6c757d}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.question-number{font-weight:700;font-size:1rem;color:#333}.marks-badge{padding:6px 12px;border-radius:20px;font-weight:600;font-size:.9rem}.marks-badge.excellent{background:#28a745;color:#fff}.marks-badge.good{background:#20c997;color:#fff}.marks-badge.partial{background:#ffc107;color:#333}.marks-badge.poor{background:#dc3545;color:#fff}.marks-badge.no-data{background:#6c757d;color:#fff}.question-content{margin-bottom:12px}.question-text{margin:0;color:#333;line-height:1.5}.question-skills{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.skill-tag{display:inline-block;padding:4px 10px;background:#e9ecef;border-radius:12px;font-size:.75rem;color:#495057}.mark-indicator{height:6px;background:#e9ecef;border-radius:3px;overflow:hidden}.mark-fill{height:100%;transition:width .3s ease;border-radius:3px}.mark-fill.excellent{background:#28a745}.mark-fill.good{background:#20c997}.mark-fill.partial{background:#ffc107}.mark-fill.poor{background:#dc3545}.feedback-section{background:white;padding:24px;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-top:24px}.feedback-section h3{margin:0 0 12px;color:#333}.feedback-section p{margin:0;color:#555;line-height:1.6}@media print{.test-view-header .print-btn,.back-link{display:none!important}.student-test-view{padding:0;max-width:100%}.test-content,.student-info-card{box-shadow:none;border:1px solid #ddd}.question-card{page-break-inside:avoid}}.student-test-view .loading,.student-test-view .error-message{padding:40px;text-align:center;background:white;border-radius:12px;margin:40px 0}.student-test-view .error-message{color:#dc3545}.report-page{padding:20px;max-width:900px;margin:auto}.page-header{margin-bottom:25px;padding-bottom:15px;border-bottom:1px solid #eee}.page-header h1{margin:0;color:var(--primary-color)}.report-section{background-color:#fff;padding:20px;border-radius:8px;margin-bottom:30px;box-shadow:0 2px 4px #0000000d}.report-section h2{margin-top:0;margin-bottom:20px;color:var(--primary-color);font-size:1.4em;border-bottom:1px solid #f0f0f0;padding-bottom:10px}.loading-message,.error-message{text-align:center;padding:15px;margin:10px 0;border-radius:4px}.error-message{color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb}.loading-message{color:#0c5460;background-color:#d1ecf1;border:1px solid #bee5eb}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.stat-item{background-color:#f9f9f9;padding:15px;border-radius:6px;border:1px solid #eee;text-align:center}.stat-item strong{display:block;margin-bottom:8px;color:var(--secondary-color);font-size:.95em}.stat-item span{font-size:1.5em;font-weight:700;color:var(--primary-color)}.filter-controls{display:flex;gap:15px;align-items:center;margin-bottom:20px;flex-wrap:wrap}.filter-controls select{padding:10px;border-radius:4px;border:1px solid #ccc;min-width:200px}.filter-controls .button{padding:10px 15px}.class-average-display{margin-top:15px;padding:15px;background-color:#f9f9f9;border-radius:6px;border:1px solid #eee}.class-average-display h3{margin-top:0;margin-bottom:10px;color:var(--secondary-color)}.class-average-display p{font-size:1.1em;margin-bottom:10px}.class-average-display p strong{color:var(--primary-color)}.class-average-display ul{list-style:disc;padding-left:25px}.class-average-display ul li{margin-bottom:5px;font-size:1em}.latex-test-page{max-width:1400px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f8fafc;min-height:100vh}.page-header{text-align:center;margin-bottom:40px;padding:30px;background:white;border-radius:12px;box-shadow:0 2px 8px #0000001a}.page-header h1{color:#1e293b;margin-bottom:10px;font-size:2.5rem}.page-description{color:#64748b;font-size:1.1rem;margin-bottom:20px}.controls{display:flex;justify-content:center;gap:20px;margin-top:20px;flex-wrap:wrap}.debug-toggle{display:flex;align-items:center;gap:8px;font-weight:500;cursor:pointer}.debug-toggle input{transform:scale(1.2)}.custom-input-section{background:white;border-radius:12px;padding:30px;margin-bottom:30px;box-shadow:0 2px 8px #0000001a}.custom-input-section h2{color:#1e293b;margin-bottom:20px;font-size:1.5rem}.input-group{display:flex;gap:10px;margin-bottom:20px}.custom-textarea{flex:1;padding:12px;border:2px solid #e2e8f0;border-radius:8px;font-family:Monaco,Menlo,monospace;font-size:14px;resize:vertical;min-height:80px;transition:border-color .2s}.custom-textarea:focus{outline:none;border-color:#3b82f6}.clear-button{padding:12px 20px;background:#ef4444;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:background-color .2s}.clear-button:hover:not(:disabled){background:#dc2626}.clear-button:disabled{background:#9ca3af;cursor:not-allowed}.custom-result{background:#f1f5f9;border-radius:8px;padding:20px;border-left:4px solid #3b82f6}.renderer-comparison{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:15px 0}.renderer-comparison.single-renderer{grid-template-columns:1fr}.renderer-section{padding:15px;border-radius:8px;border:2px solid transparent;transition:border-color .2s}.renderer-section.old-renderer{background:#fef2f2;border-color:#fca5a5}.renderer-section.new-renderer{background:#f0fdf4;border-color:#86efac}.renderer-section h4{margin:0 0 10px;color:#374151;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:8px}.renderer-section.old-renderer h4{color:#dc2626}.renderer-section.new-renderer h4{color:#16a34a}.result-container{margin-bottom:15px}.result-input{padding:15px;background:white;border-radius:6px;border:1px solid #e2e8f0;margin-bottom:15px}.result-input code{background:#f8fafc;padding:4px 8px;border-radius:4px;font-family:monospace;font-size:13px}.result-output,.rendered-output{background:white;padding:12px;border-radius:6px;border:1px solid #e2e8f0;min-height:40px;font-size:14px;line-height:1.6}.test-cases-section{margin-bottom:30px}.test-cases-section h2{color:#1e293b;margin-bottom:20px;font-size:1.5rem}.legend{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:25px;padding:15px;background:white;border-radius:8px;border:1px solid #e2e8f0}.legend-item{font-size:14px;font-weight:500;padding:5px 10px;border-radius:4px}.legend-item--failing{background:#fee2e2;color:#dc2626}.legend-item--partial{background:#fef3c7;color:#d97706}.legend-item--working{background:#dcfce7;color:#16a34a}.legend-item--prototype{background:#dbeafe;color:#2563eb}.test-cases-grid{display:grid;gap:25px}.test-case{background:white;border-radius:12px;padding:25px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #e2e8f0;transition:transform .2s,box-shadow .2s}.test-case:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.test-case--failing{border-left-color:#dc2626}.test-case--partial{border-left-color:#d97706}.test-case--working{border-left-color:#16a34a}.test-case--prototype{border-left-color:#2563eb}.test-case__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.test-case__header h3{color:#1e293b;margin:0;font-size:1.2rem}.status-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge--failing{background:#fee2e2;color:#dc2626}.status-badge--partial{background:#fef3c7;color:#d97706}.status-badge--working{background:#dcfce7;color:#16a34a}.status-badge--prototype{background:#dbeafe;color:#2563eb}.test-case__description{color:#64748b;margin-bottom:20px;font-style:italic}.test-case__content{margin-bottom:20px}.input-section{background:#f8fafc;padding:15px;border-radius:8px;border:1px solid #e2e8f0;margin-bottom:15px}.input-section h4{margin:0 0 10px;color:#374151;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.raw-input{background:#1e293b;color:#e2e8f0;padding:12px;border-radius:6px;font-family:Monaco,Menlo,monospace;font-size:13px;line-height:1.4;word-break:break-all;display:block;width:100%;box-sizing:border-box}.debug-info{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:8px;padding:15px;margin-top:15px}.debug-info h4{color:#1e293b;margin:0 0 10px;font-size:14px}.debug-stats{display:flex;gap:15px;margin-bottom:15px;font-size:13px;flex-wrap:wrap}.debug-stats span{background:white;padding:4px 8px;border-radius:4px;border:1px solid #e2e8f0;font-weight:500}.matches-section{margin-bottom:15px}.matches-section h5{color:#374151;margin:0 0 8px;font-size:13px;font-weight:600}.match-item{background:white;padding:8px 12px;border-radius:4px;border:1px solid #e2e8f0;margin-bottom:5px;font-size:12px;font-family:monospace}.match-item strong{color:#1e293b}.match-item code{background:#f1f5f9;padding:2px 4px;border-radius:2px;margin:0 4px}.match-content{color:#059669;font-weight:500;background:#ecfdf5;padding:2px 4px;border-radius:2px;margin-left:4px}.no-matches{background:#fef2f2;color:#dc2626;padding:10px;border-radius:4px;border:1px solid #fecaca;font-weight:500;text-align:center}.technical-notes{background:white;border-radius:12px;padding:30px;box-shadow:0 2px 8px #0000001a}.technical-notes h2{color:#1e293b;margin-bottom:20px;font-size:1.5rem}.notes-content h3{color:#374151;margin:20px 0 10px;font-size:1.1rem}.notes-content ul{color:#4b5563;line-height:1.6}.notes-content li{margin-bottom:8px}.notes-content code{background:#f1f5f9;color:#1e293b;padding:2px 6px;border-radius:4px;font-family:Monaco,Menlo,monospace;font-size:13px}@media (max-width: 768px){.latex-test-page{padding:15px}.renderer-comparison{grid-template-columns:1fr;gap:15px}.legend{flex-direction:column;gap:8px}.input-group{flex-direction:column}.clear-button{align-self:flex-start}.controls{flex-direction:column;gap:10px}.debug-stats{flex-direction:column;gap:8px}}@media print{.latex-test-page{background:white;color:#000}.test-case{box-shadow:none;border:1px solid #ccc;page-break-inside:avoid;margin-bottom:20px}.debug-info,.controls,.custom-input-section{display:none}}.performance-indicator{position:relative;display:inline-block}.performance-indicator:after{content:"";position:absolute;top:-2px;right:-2px;width:8px;height:8px;border-radius:50%;background:#10b981;border:2px solid white;box-shadow:0 0 0 1px #10b981}.performance-indicator.slow:after{background:#f59e0b;box-shadow:0 0 0 1px #f59e0b}.performance-indicator.error:after{background:#ef4444;box-shadow:0 0 0 1px #ef4444}.latex-test-renderer{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}.latex-test-renderer.inline{display:inline}.latex-test-renderer.block{display:block}.latex-content{margin-bottom:15px}.latex-loading{color:#6b7280;font-style:italic;background:#f3f4f6;padding:2px 6px;border-radius:3px;font-size:.9em}.latex-error-segment{background:#fef2f2;color:#dc2626;padding:2px 6px;border-radius:3px;border:1px solid #fecaca;cursor:help}.latex-unknown-segment{background:#fef3c7;color:#d97706;padding:2px 6px;border-radius:3px;border:1px solid #fde68a}.debug-source{font-size:10px;color:#6b7280;background:#f3f4f6;padding:1px 4px;border-radius:2px;margin-left:4px;cursor:help;font-family:Monaco,Menlo,monospace}.latex-debug-info{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:15px;margin-top:15px;font-size:14px}.latex-debug-info h4{margin:0 0 12px;color:#1e293b;font-size:16px;border-bottom:1px solid #e2e8f0;padding-bottom:8px}.latex-debug-info h5{margin:12px 0 8px;color:#374151;font-size:14px;font-weight:600}.debug-stats{display:flex;gap:20px;margin-bottom:15px;flex-wrap:wrap}.stat-item{background:white;padding:8px 12px;border-radius:6px;border:1px solid #e2e8f0;font-size:13px}.stat-item strong{color:#374151}.debug-metrics{background:white;padding:12px;border-radius:6px;border:1px solid #e2e8f0;margin-bottom:15px}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;margin-top:8px;font-size:13px;font-family:Monaco,Menlo,monospace}.metrics-grid>div{background:#f8fafc;padding:6px 10px;border-radius:4px;border:1px solid #f1f5f9}.debug-segments{background:white;padding:12px;border-radius:6px;border:1px solid #e2e8f0}.segment-detail{background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;padding:8px 10px;margin-bottom:6px;font-size:13px;font-family:Monaco,Menlo,monospace}.segment-detail:last-child{margin-bottom:0}.segment-detail--text{border-left:3px solid #6b7280}.segment-detail--inline{border-left:3px solid #3b82f6}.segment-detail--display{border-left:3px solid #8b5cf6}.segment-type{font-weight:600;color:#374151;margin-left:8px;padding:2px 6px;background:#e2e8f0;border-radius:3px;font-size:11px}.segment-source{color:#059669;margin-left:8px;font-size:11px;background:#ecfdf5;padding:2px 6px;border-radius:3px}.segment-content{display:block;margin-top:6px;padding:6px 8px;background:#1e293b;color:#e2e8f0;border-radius:3px;font-size:12px;word-break:break-all;overflow-wrap:break-word}.segment-debug{margin-top:6px;padding-top:6px;border-top:1px solid #e2e8f0;font-size:11px;color:#6b7280}.segment-debug code{background:#f1f5f9;padding:2px 4px;border-radius:2px;margin-left:4px}.debug-error{background:#fef2f2;color:#dc2626;padding:10px;border-radius:6px;border:1px solid #fecaca;font-weight:500}@media (max-width: 768px){.debug-stats{flex-direction:column;gap:8px}.metrics-grid{grid-template-columns:1fr}.latex-debug-info{padding:12px;font-size:13px}}@keyframes segmentHighlight{0%{background-color:#fef3c7}to{background-color:transparent}}.latex-content .latex-text-segment,.latex-content .katex{animation:segmentHighlight .3s ease-out}@media print{.latex-debug-info,.debug-source{display:none}}.instance-view-page{max-width:1200px;margin:0 auto;padding:20px}.instance-view-page .page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.instance-view-page h1{margin:0;color:#1f2937}.back-link{color:#6366f1;text-decoration:none}.back-link:hover{text-decoration:underline}.instance-info-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:20px;margin-bottom:24px;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px}.info-row{display:flex;flex-direction:column;gap:4px}.info-row .label{font-size:.85em;color:#64748b;font-weight:500}.info-row .value{font-size:1em;color:#1f2937}.status-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:.9em;font-weight:500}.status-badge.status-draft{background:#fef3c7;color:#92400e}.status-badge.status-published{background:#d1fae5;color:#065f46}.print-status-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:.9em}.print-status-badge.print-not_printed{background:#f1f5f9;color:#475569}.print-status-badge.print-print_initiated{background:#fef3c7;color:#92400e}.print-status-badge.print-print_confirmed{background:#d1fae5;color:#065f46}.print-status-badge.print-print_bypassed{background:#e0e7ff;color:#4338ca}.print-section{background:white;border:1px solid #e2e8f0;border-radius:12px;padding:24px;margin-bottom:24px}.print-section h2{margin:0 0 20px;color:#1f2937;font-size:1.3em}.student-selection{margin-bottom:20px}.selection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.selection-header h3{margin:0;font-size:1em;color:#374151}.selection-buttons{display:flex;gap:8px}.selection-buttons button{padding:6px 12px;font-size:.85em;border:1px solid #d1d5db;background:white;border-radius:6px;cursor:pointer}.selection-buttons button:hover{background:#f3f4f6}.student-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px;max-height:300px;overflow-y:auto;padding:10px;border:1px solid #e5e7eb;border-radius:8px;background:#fafafa}.student-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:white;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .15s ease}.student-item:hover{border-color:#6366f1;background:#f5f3ff}.student-item.selected{border-color:#6366f1;background:#eef2ff}.student-item input[type=checkbox]{accent-color:#6366f1}.student-name{flex:1;font-weight:500;color:#1f2937}.student-identifier{font-size:.85em;color:#6b7280}.qr-indicator{font-size:1.1em}.print-actions{display:flex;gap:12px;flex-wrap:wrap}.print-button{display:flex;align-items:center;gap:8px;padding:12px 24px;font-size:1em;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.print-button.primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.print-button.primary:hover:not(:disabled){background:linear-gradient(135deg,#4f46e5,#7c3aed);transform:translateY(-1px)}.print-button.confirm{background:#10b981;color:#fff}.print-button.confirm:hover{background:#059669}.print-button.bypass{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.print-button.bypass:hover{background:#e2e8f0}.print-button:disabled{opacity:.6;cursor:not-allowed}.actions-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.actions-section h3{margin:0 0 15px;font-size:1.1em;color:#374151}.action-buttons{display:flex;gap:12px;flex-wrap:wrap}.action-button{padding:10px 20px;font-size:.95em;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;background:#1f2937;color:#fff}.action-button:hover{background:#111827}.action-button.secondary{background:white;color:#374151;border:1px solid #d1d5db}.action-button.secondary:hover{background:#f3f4f6}.error-message{background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:16px}.success-message{background:#f0fdf4;color:#16a34a;padding:12px 16px;border-radius:8px;margin-bottom:16px}.preview-section{background:white;border:1px solid #e2e8f0;border-radius:12px;padding:24px;margin-top:24px}.preview-section h2{margin:0 0 8px;color:#1f2937;font-size:1.3em}.preview-hint{color:#6b7280;font-size:.9em;margin:0 0 20px}.preview-container{border:1px solid #e5e7eb;border-radius:8px;overflow:auto;max-height:600px;background:#f9fafb;padding:20px}.document-import-page{max-width:900px;margin:0 auto;padding:20px}.document-import-page .page-header{margin-bottom:30px;border-bottom:none}.document-import-page .page-header h1{margin:0 0 10px;color:#1e293b}.page-description{color:#64748b;font-size:1rem;margin:0}.import-container{display:flex;flex-direction:column;gap:24px}.import-section{background:#ffffff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0}.import-section h2{display:flex;align-items:center;gap:12px;margin:0 0 20px;font-size:1.25rem;color:#1e293b}.step-number{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-radius:50%;font-weight:600;font-size:.9rem}.file-upload-area{margin-bottom:20px}.file-input{display:none}.file-label{display:block;padding:40px 20px;border:2px dashed #cbd5e1;border-radius:8px;text-align:center;cursor:pointer;transition:all .2s ease;background:#f8fafc}.file-label:hover{border-color:#6366f1;background:#f1f5f9}.file-upload-area.dragging .file-label{border-color:#6366f1;border-style:solid;background:#eef2ff;transform:scale(1.02)}.file-placeholder.dragging{color:#6366f1;font-weight:500}.file-placeholder{color:#64748b;font-size:1rem}.file-selected{display:flex;flex-direction:column;align-items:center;gap:4px;color:#1e293b;font-weight:500}.file-selected small{color:#64748b;font-weight:400}.confirmation-checkbox{margin-bottom:20px;padding:16px;background:#fef3c7;border-radius:8px;border:1px solid #fcd34d}.confirmation-checkbox label{display:flex;gap:12px;align-items:flex-start;cursor:pointer}.confirmation-checkbox input[type=checkbox]{margin-top:3px;width:18px;height:18px;flex-shrink:0}.confirmation-checkbox span{color:#92400e;font-size:.9rem;line-height:1.5}.parsing-mode-selector{margin-bottom:20px}.parsing-mode-selector>label{display:block;font-weight:500;color:#374151;margin-bottom:10px}.mode-options{display:flex;gap:12px}.mode-option{flex:1;display:flex;flex-direction:column;align-items:center;padding:12px;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:center}.mode-option:hover{border-color:#6366f1;background:#f8fafc}.mode-option.selected{border-color:#6366f1;background:#eef2ff}.mode-option input[type=radio]{display:none}.mode-option span{font-weight:500;color:#1e293b;margin-bottom:4px}.mode-option small{font-size:.75rem;color:#64748b}.model-quality-selector{margin-bottom:20px}.model-quality-selector>label{display:block;font-weight:500;color:#374151;margin-bottom:10px}.quality-options{display:flex;gap:12px}.quality-option{flex:1;display:flex;flex-direction:column;align-items:center;padding:10px;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:center}.quality-option:hover{border-color:#8b5cf6;background:#f8fafc}.quality-option.selected{border-color:#8b5cf6;background:#f3e8ff}.quality-option input[type=radio]{display:none}.quality-option span{font-weight:500;color:#1e293b;margin-bottom:2px}.quality-option small{font-size:.7rem;color:#64748b}.upload-button{width:100%;padding:14px 24px;font-size:1rem}.upload-button:disabled{background:#94a3b8;cursor:not-allowed}.results-section{border-color:#c7d2fe;background:linear-gradient(to bottom,#eef2ff,#ffffff)}.parsing-summary{display:flex;gap:16px;margin-bottom:24px}.summary-card{flex:1;display:flex;flex-direction:column;align-items:center;padding:16px;background:white;border-radius:8px;border:1px solid #e2e8f0}.summary-card.method{flex:1.5}.summary-card.quality{flex:1}.ai-suggestion{background:#eef2ff;border:1px solid #c7d2fe;border-radius:8px;padding:12px 16px;margin-bottom:16px;color:#3730a3;font-size:.9rem}.ai-unavailable-notice{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;padding:12px 16px;margin-bottom:16px;color:#666;font-size:.9rem}.extracted-images-section{background:#f0fdf4;border:1px solid #86efac;border-radius:8px;padding:16px;margin-top:16px}.extracted-images-section h4{margin:0 0 8px;color:#166534;font-size:1rem}.images-note{font-size:.85rem;color:#15803d;margin:0 0 12px}.extracted-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.extracted-image-card{display:flex;flex-direction:column;align-items:center;background:white;border-radius:6px;padding:8px;border:1px solid #e5e7eb}.extracted-image-thumb{width:80px;height:80px;object-fit:contain;border-radius:4px;background:#f9fafb}.image-label{font-size:.75rem;color:#6b7280;margin-top:4px}.question-image-preview{display:flex;align-items:center;gap:8px;margin-top:8px;padding:8px;background:#ecfdf5;border-radius:6px;border:1px solid #10b981}.question-preview-thumb{width:50px;height:50px;object-fit:contain;border-radius:4px;background:white}.image-attached-badge{font-size:.75rem;color:#059669;font-weight:500}.summary-value{font-size:1.5rem;font-weight:700;color:#1e293b}.summary-label{font-size:.8rem;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.parsed-preview{background:white;border-radius:8px;padding:16px;border:1px solid #e2e8f0;max-height:400px;overflow-y:auto}.parsed-preview h3{margin:0 0 16px;font-size:1rem;color:#475569}.preview-section{margin-bottom:20px}.preview-section:last-child{margin-bottom:0}.preview-section h4{margin:0 0 12px;font-size:.95rem;color:#1e293b;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.preview-questions{list-style:none;padding:0;margin:0}.preview-question{display:flex;gap:8px;padding:8px 0;border-bottom:1px dashed #e2e8f0;font-size:.9rem}.preview-question:last-child{border-bottom:none}.q-number{font-weight:600;color:#6366f1;flex-shrink:0}.q-content{flex:1;display:flex;flex-direction:column;gap:4px}.q-text{color:#475569}.q-type-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;width:fit-content}.q-type-badge.multiple_choice{background:#dbeafe;color:#1e40af}.q-options-preview{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px;padding-left:8px;border-left:2px solid #c7d2fe}.q-option{background:#f1f5f9;padding:2px 8px;border-radius:4px;font-size:.8rem;color:#334155}.q-marks{color:#94a3b8;font-size:.8rem;flex-shrink:0}.json-toggle{margin-top:16px}.json-response{margin-top:16px;background:#1e293b;color:#e2e8f0;padding:16px;border-radius:8px;overflow-x:auto;font-size:.8rem}.json-response pre{margin:0;white-space:pre-wrap;word-break:break-word}.action-section{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff}.action-section h2{color:#fff}.action-section .step-number{background:rgba(255,255,255,.2)}.action-description{margin:0 0 20px;opacity:.9}.create-button{width:100%;padding:16px 24px;font-size:1.1rem;background:white;color:#6366f1;font-weight:600}.create-button:hover{background:#f8fafc;opacity:1}.error-message{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;padding:12px 16px;border-radius:8px;margin-top:16px}.button{border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s ease}.primary-button{background:#6366f1;color:#fff}.primary-button:hover{background:#4f46e5}.secondary-button{background:#f1f5f9;color:#475569;padding:10px 16px}.secondary-button:hover{background:#e2e8f0}.custom-prompt-group{margin-bottom:20px;margin-top:10px}.custom-prompt-group>label{display:block;font-weight:500;color:#374151;margin-bottom:10px}.custom-prompt-group>label small{display:block;font-weight:400;color:#64748b;font-size:.85rem;margin-top:4px}.custom-prompt-input{width:100%;padding:12px;border:2px solid #e2e8f0;border-radius:8px;font-size:.9rem;resize:vertical;font-family:inherit;transition:border-color .2s ease}.custom-prompt-input:focus{outline:none;border-color:#6366f1}.custom-prompt-input::placeholder{color:#94a3b8}.direct-pdf-group{margin-bottom:20px;padding:12px;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px}.direct-pdf-group .checkbox-label{display:flex;gap:12px;align-items:flex-start;cursor:pointer}.direct-pdf-group input[type=checkbox]{margin-top:3px;width:18px;height:18px;flex-shrink:0}.direct-pdf-group span{color:#92400e;font-weight:500}.direct-pdf-group small{display:block;font-weight:400;color:#78716c;font-size:.85rem;margin-top:4px}.admin-dashboard,.admin-school-settings,.admin-users{max-width:1200px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.admin-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:30px;border-radius:12px;margin-bottom:30px;box-shadow:0 4px 12px #0000001a}.admin-header h1{margin:0 0 10px;font-size:2.5rem;font-weight:600}.admin-header p{margin:0;font-size:1.1rem;opacity:.9}.school-info{margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.2)}.school-info h2{margin:0 0 5px;font-size:1.5rem}.school-info p{margin:0;opacity:.8}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:white;padding:25px;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e1e5e9;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.stat-card h3{margin:0 0 10px;color:#2c3e50;font-size:1.2rem}.stat-number{font-size:2.5rem;font-weight:700;color:#667eea;margin:10px 0}.stat-link{background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s ease}.stat-link:hover{background:#5a6fd8}.admin-actions{margin-bottom:30px}.admin-actions h2{color:#2c3e50;margin-bottom:20px;font-size:1.8rem}.action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.action-card{background:white;padding:25px;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e1e5e9;transition:transform .2s ease,box-shadow .2s ease}.action-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.action-card h3{margin:0 0 10px;color:#2c3e50;font-size:1.3rem}.action-card p{color:#6c757d;margin-bottom:20px;line-height:1.5}.action-button{background:#28a745;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s ease;width:100%}.action-button:hover:not(:disabled){background:#218838}.action-button:disabled{background:#6c757d;cursor:not-allowed}.settings-form{background:white;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e1e5e9}.settings-section{padding:30px;border-bottom:1px solid #e1e5e9}.settings-section h2{margin:0 0 20px;color:#2c3e50;font-size:1.5rem;border-bottom:2px solid #667eea;padding-bottom:10px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#2c3e50;font-weight:500}.form-group select,.form-group input[type=number]{width:100%;padding:12px;border:1px solid #ced4da;border-radius:6px;font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.form-group select:focus,.form-group input[type=number]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.checkbox-group label{display:flex;align-items:center;cursor:pointer}.checkbox-group input[type=checkbox]{margin-right:12px;width:18px;height:18px;cursor:pointer}.custom-subjects-list{border:1px solid #e1e5e9;border-radius:6px;padding:15px;background:#f8f9fa}.custom-subject-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:white;border-radius:4px;margin-bottom:8px;border:1px solid #e1e5e9}.custom-subject-item:last-of-type{margin-bottom:12px}.remove-button{background:#dc3545;color:#fff;border:none;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center}.remove-button:hover{background:#c82333}.add-button{background:#667eea;color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s ease}.add-button:hover{background:#5a6fd8}.form-actions{padding:20px 30px;background:#f8f9fa;border-top:1px solid #e1e5e9;border-radius:0 0 12px 12px}.save-button{background:#28a745;color:#fff;border:none;padding:15px 30px;border-radius:6px;cursor:pointer;font-size:1.1rem;font-weight:500;transition:background-color .2s ease}.save-button:hover:not(:disabled){background:#218838}.save-button:disabled{background:#6c757d;cursor:not-allowed}.error-message{background:#f8d7da;color:#721c24;padding:15px;border-radius:6px;border:1px solid #f5c6cb;margin-bottom:20px}.success-message{background:#d4edda;color:#155724;padding:15px;border-radius:6px;border:1px solid #c3e6cb;margin-bottom:20px}.loading-message{text-align:center;padding:40px;color:#6c757d;font-size:1.1rem}.recent-activity{background:white;padding:30px;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e1e5e9}.recent-activity h2{margin:0 0 20px;color:#2c3e50;font-size:1.5rem}.activity-feed{color:#6c757d;line-height:1.6}.users-actions{margin-bottom:30px;display:flex;gap:15px;flex-wrap:wrap}.users-list{background:white;padding:30px;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e1e5e9}.users-list ul{color:#6c757d;line-height:1.8}.users-list li{margin-bottom:8px}@media (max-width: 768px){.admin-dashboard,.admin-school-settings,.admin-users{padding:15px}.admin-header{padding:20px}.admin-header h1{font-size:2rem}.admin-stats,.action-grid{grid-template-columns:1fr}.users-actions{flex-direction:column}.action-button{width:100%}}.admin-school-settings{max-width:1200px;margin:0 auto;padding:20px;background:#f8fafc;min-height:100vh}.settings-form{background:#ffffff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:0;margin-top:20px}.settings-section{padding:24px;border-bottom:1px solid #e2e8f0}.settings-section:last-child{border-bottom:none}.settings-section h2{margin:0 0 20px;color:#1e293b;font-size:1.25rem;font-weight:600;border-bottom:2px solid #e2e8f0;padding-bottom:8px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:16px}.form-group{display:flex;flex-direction:column;margin-bottom:16px}.form-group label{font-weight:500;color:#374151;margin-bottom:6px;font-size:.875rem}.form-group input,.form-group select,.form-group textarea{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .2s,box-shadow .2s;background:#ffffff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.help-text{color:#6b7280;font-size:.75rem;margin-top:4px;line-height:1.4}.help-text.success{color:#059669}.section-description{color:#64748b;font-size:.875rem;margin-bottom:16px;line-height:1.5}.checkbox-group{flex-direction:row;align-items:center;margin-bottom:12px}.checkbox-group input[type=checkbox]{width:auto;margin-right:8px;margin-bottom:0}.checkbox-group label{margin-bottom:0;font-weight:400;cursor:pointer;display:flex;align-items:center}.custom-subjects-list,.domain-list{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start}.custom-subject-item,.domain-item{display:flex;align-items:center;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;padding:4px 8px;font-size:.875rem}.custom-subject-item span,.domain-item span{margin-right:6px;color:#475569}.remove-button-small,.add-button-small,.view-details-button,.create-custom-button,.save-button,.create-set-button,.cancel-button{all:unset;display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;border-radius:4px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none;box-sizing:border-box;line-height:1;white-space:nowrap}.remove-button-small{background:#ef4444;color:#fff;padding:2px 6px;font-size:.875rem;border-radius:3px;min-width:20px;min-height:20px}.remove-button-small:hover{background:#dc2626}.add-button-small{background:#10b981;color:#fff;padding:6px 12px;margin-top:8px}.add-button-small:hover{background:#059669}.view-details-button{background:#3b82f6;color:#fff;padding:6px 12px}.view-details-button:hover{background:#2563eb}.create-custom-button{background:#8b5cf6;color:#fff;padding:6px 12px}.create-custom-button:hover{background:#7c3aed}.save-button{background:#059669;color:#fff;padding:12px 24px;font-size:.875rem;font-weight:600}.save-button:hover:not(:disabled){background:#047857}.save-button:disabled{background:#9ca3af;cursor:not-allowed}.create-set-button{background:#059669;color:#fff;padding:8px 16px}.create-set-button:hover:not(:disabled){background:#047857}.create-set-button:disabled{background:#9ca3af;cursor:not-allowed}.cancel-button{background:#6b7280;color:#fff;padding:8px 16px}.cancel-button:hover{background:#4b5563}.select-with-view,.select-with-actions{display:flex;gap:12px;align-items:flex-end}.select-with-view select,.select-with-actions select{flex:1;min-width:0}.action-buttons{display:flex;gap:8px;flex-shrink:0}.logo-upload-area{display:flex;flex-direction:column;gap:12px}.logo-preview{width:100px;height:100px;border:2px dashed #d1d5db;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#f9fafb}.logo-preview img{max-width:100%;max-height:100%;object-fit:contain}.color-input-group{display:flex;gap:8px;align-items:center}.color-input-group input[type=color]{width:40px;height:32px;padding:0;border:1px solid #d1d5db;border-radius:4px;cursor:pointer}.color-input-group input[type=text]{flex:1;font-family:monospace;font-size:.875rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:white;border-radius:8px;max-width:800px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 25px #0000004d}.modal-header{padding:20px 24px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;background:#f8fafc}.modal-header h3{margin:0;color:#1e293b;font-size:1.125rem;font-weight:600}.modal-close{all:unset;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;cursor:pointer;color:#6b7280;font-size:1.25rem;font-weight:700;transition:all .2s}.modal-close:hover{background:#e5e7eb;color:#374151}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:12px;background:#f8fafc}.boundary-table,.boundary-editor-table{width:100%;border-collapse:collapse;margin-top:12px}.boundary-table th,.boundary-table td,.boundary-editor-table th,.boundary-editor-table td{padding:8px 12px;text-align:left;border-bottom:1px solid #e2e8f0}.boundary-table th,.boundary-editor-table th{background:#f8fafc;font-weight:600;color:#374151;font-size:.875rem}.boundary-editor-table input{width:100%;padding:4px 8px;border:1px solid #d1d5db;border-radius:3px;font-size:.875rem}.boundary-editor-table input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.subject-list{columns:2;column-gap:20px;list-style:none;padding:0;margin:12px 0}.subject-list li{padding:4px 0;border-bottom:1px solid #f1f5f9;break-inside:avoid;font-size:.875rem;color:#374151}.form-actions{padding:24px;background:#f8fafc;border-top:1px solid #e2e8f0;text-align:right}.success-message{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46;padding:12px 16px;border-radius:6px;margin-bottom:20px;font-size:.875rem}.error-message{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;padding:12px 16px;border-radius:6px;margin-bottom:20px;font-size:.875rem}.validation-error{color:#dc2626;font-size:.875rem;margin-top:4px;margin-bottom:0;font-weight:500}@media (max-width: 768px){.admin-school-settings{padding:12px}.form-row{grid-template-columns:1fr;gap:16px}.select-with-view,.select-with-actions{flex-direction:column;align-items:stretch}.action-buttons{justify-content:flex-start}.modal-content{margin:10px;max-height:calc(100vh - 20px)}.boundary-table,.boundary-editor-table{font-size:.75rem}.subject-list{columns:1}}.loading-message{text-align:center;padding:40px;color:#6b7280;font-size:1rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus,button:focus{outline:2px solid #3b82f6;outline-offset:2px}button{min-height:32px;border:none;font-family:inherit}.admin-school-settings button{background:unset!important;color:unset!important;border-radius:unset!important;padding:unset!important}.admin-school-settings .remove-button-small{background:#ef4444!important;color:#fff!important;border-radius:3px!important;padding:2px 6px!important}.admin-school-settings .add-button-small{background:#10b981!important;color:#fff!important;border-radius:4px!important;padding:6px 12px!important}.admin-school-settings .view-details-button{background:#3b82f6!important;color:#fff!important;border-radius:4px!important;padding:6px 12px!important}.admin-school-settings .create-custom-button{background:#8b5cf6!important;color:#fff!important;border-radius:4px!important;padding:6px 12px!important}.admin-school-settings .save-button{background:#059669!important;color:#fff!important;border-radius:4px!important;padding:12px 24px!important}.admin-school-settings .create-set-button{background:#059669!important;color:#fff!important;border-radius:4px!important;padding:8px 16px!important}.admin-school-settings .cancel-button{background:#6b7280!important;color:#fff!important;border-radius:4px!important;padding:8px 16px!important}.app-header{background-color:var(--primary-color);color:#fff;padding:0 20px;height:var(--header-height);display:flex;align-items:center;box-shadow:0 2px 4px #0000001a;position:fixed;top:0;left:0;width:100%;z-index:1000}.header-container{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:1200px;margin:0 auto}.logo{font-size:1.5em;font-weight:700;color:#fff;text-decoration:none}.app-header nav ul{list-style:none;margin:0;padding:0;display:flex;align-items:center}.app-header nav ul li{margin-left:20px}.app-header nav ul li a{color:#fff;text-decoration:none;font-size:1em}.app-header nav ul li a:hover,.app-header nav ul li a.active{text-decoration:underline}.logout-button{background-color:var(--secondary-color);color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:.9em}.logout-button:hover{opacity:.9}.dropdown{position:relative;display:inline-block}.dropbtn{background-color:transparent;color:#fff;border:none;cursor:pointer;font-size:1em;padding:8px 12px;border-radius:4px}.dropbtn:hover{background-color:#ffffff1a}.dropdown-content{display:none;position:absolute;background-color:var(--primary-color);min-width:160px;box-shadow:0 8px 16px #0003;z-index:1001;border-radius:4px;top:100%;left:0}.dropdown-content a{color:var(--text-color);padding:12px 16px;text-decoration:none;display:block;border-radius:0}.dropdown-content a:hover{background-color:#003c78}.dropdown:hover .dropdown-content{display:block}.notification-container{position:relative}.notification-bell-btn{background:none;border:none;font-size:1.3rem;cursor:pointer;position:relative;padding:5px 10px;transition:transform .2s ease}.notification-bell-btn:hover{transform:scale(1.1)}.notification-badge{position:absolute;top:0;right:0;background:#dc3545;color:#fff;font-size:.65rem;padding:2px 5px;border-radius:10px;min-width:16px;text-align:center;font-weight:600}.notification-dropdown{position:absolute;top:100%;right:0;background:white;min-width:300px;max-width:350px;box-shadow:0 4px 20px #00000026;border-radius:8px;z-index:1002;overflow:hidden}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8f9fa;border-bottom:1px solid #e9ecef}.notification-header h4{margin:0;color:#2c3e50;font-size:.95rem}.mark-all-read{background:none;border:none;color:#667eea;font-size:.8rem;cursor:pointer;text-decoration:underline}.mark-all-read:hover{color:#5a6fd8}.notification-list{max-height:300px;overflow-y:auto}.no-notifications{padding:20px;text-align:center;color:#6c757d;font-style:italic;margin:0}.notification-item{padding:12px 16px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background-color .2s ease}.notification-item:hover{background-color:#f8f9fa}.notification-item:last-child{border-bottom:none}.notification-title{display:block;font-weight:600;color:#2c3e50;font-size:.9rem;margin-bottom:4px}.notification-message{display:block;color:#6c757d;font-size:.8rem}.app-footer{background-color:#e9ecef;color:var(--secondary-color);padding:20px;text-align:center;border-top:1px solid #dee2e6;margin-top:auto}.footer-container{max-width:1200px;margin:0 auto}.app-footer p{margin:0 0 10px;font-size:.9em}.app-footer nav ul{list-style:none;padding:0;margin:0;display:flex;justify-content:center;gap:15px}.app-footer nav ul li a{color:var(--secondary-color);text-decoration:none;font-size:.9em}.app-footer nav ul li a:hover{color:var(--primary-color);text-decoration:underline}.app-container{display:flex;flex-direction:column;min-height:100vh}.main-content{flex-grow:1;padding-top:20px;padding-bottom:20px}.container{width:90%;max-width:1200px;margin:auto;padding:20px}:root{--primary-color: #007bff;--secondary-color: #6c757d;--background-color: #f8f9fa;--text-color: #212529;--font-family: Arial, sans-serif;--header-height: 60px}body{font-family:var(--font-family);color:var(--text-color);background-color:var(--background-color);margin:0;padding-top:var(--header-height)}h1,h2,h3,h4,h5,h6{color:var(--primary-color)}body{margin:0;font-family:var(--font-family);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background-color);color:var(--text-color)}#root{display:flex;flex-direction:column;min-height:calc(100vh - var(--header-height))}main{flex-grow:1;padding:20px}a{color:var(--primary-color);text-decoration:none}a:hover{text-decoration:underline}button,.button{background-color:var(--primary-color);color:#fff;border:none;padding:10px 15px;border-radius:4px;cursor:pointer;font-size:1em}button:hover,.button:hover{opacity:.9}input[type=text],input[type=email],input[type=password],input[type=number],textarea,select{width:100%;padding:10px;margin-bottom:10px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box}label{display:block;margin-bottom:5px;font-weight:700}.container{max-width:1200px;margin:0 auto;padding:0 20px}.text-center{text-align:center}.error-message{color:red;margin-bottom:10px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.rating-input{margin-top:15px}.rating-input-label{display:block;font-weight:700;margin-bottom:8px;color:var(--text-color)}.rating-scale{display:flex;align-items:center;justify-content:center;gap:6px;max-width:100%;box-sizing:border-box}.rating-buttons{display:flex;align-items:center;flex:0 0 auto;gap:max(2px,min(6px,calc(24px / var(--rating-count, 5))))}.rating-button{border-radius:50%;border:2px solid var(--primary-color);background-color:#fff;color:var(--primary-color);font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;width:max(24px,min(36px,calc(240px / var(--rating-count, 5))));height:max(24px,min(36px,calc(240px / var(--rating-count, 5))));font-size:max(10px,min(14px,calc(20px / var(--rating-count, 5))))}.rating-button:hover{background-color:var(--primary-color);color:#fff;transform:scale(1.05)}.rating-button.selected{background-color:var(--primary-color);color:#fff}.rating-button:disabled{opacity:.5;cursor:not-allowed}.rating-label{font-size:12px;color:var(--text-color);font-weight:500;opacity:.8;flex-shrink:0;max-width:60px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.min-label{text-align:right}.max-label{text-align:left}.rating-preview{margin-top:15px}.rating-scale-preview{display:flex;align-items:center;justify-content:center;gap:6px;padding:15px;background-color:var(--background-color);border-radius:8px;border:1px solid #e0e0e0;overflow:hidden;max-width:100%;box-sizing:border-box;min-height:60px}.rating-options{display:flex;align-items:center;justify-content:center;flex:0 0 auto;gap:max(2px,min(6px,calc(24px / var(--rating-count, 5))));overflow:hidden}.rating-option{display:flex;align-items:center;justify-content:center;flex-shrink:0}.rating-circle{border-radius:50%;border:2px solid var(--primary-color);background-color:#fff;color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-weight:700;text-align:center;line-height:1;flex-shrink:0;width:max(18px,min(28px,calc(200px / var(--rating-count, 5))));height:max(18px,min(28px,calc(200px / var(--rating-count, 5))));font-size:max(8px,min(12px,calc(16px / var(--rating-count, 5))))}
