body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.help-panel-overlay{background:#00000080}.help-panel{background:#fff;background:var(--background-surface,#fff);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:800px}.help-panel-header{background:#2563eb;background:var(--primary-blue,#2563eb);color:#fff;padding:16px 24px}.help-panel-header h1{font-size:1.25rem}.help-close-btn{border-radius:4px;color:#fff;font-size:1.5rem;padding:4px 8px;transition:background .2s}.help-close-btn:hover{background:#fff3}.help-sidebar{background:#1f2937;background:var(--gray-800,#1f2937);flex-shrink:0;overflow-y:auto;padding:12px}.help-nav-item{background:#0000;border-radius:8px;color:#d1d5db;color:var(--gray-300,#d1d5db);font-size:.9rem;gap:10px;padding:12px 16px;transition:all .2s;width:100%}.help-nav-item:hover{background:#ffffff1a;color:#fff}.help-nav-item.active{background:#2563eb;background:var(--primary-blue,#2563eb);color:#fff}.help-nav-icon{font-size:1.1rem;text-align:center;width:24px}.help-content-area{background:#f9fafb;background:var(--background-surface,#f9fafb);padding:24px}.help-header{gap:12px;margin-bottom:16px}.help-icon{font-size:2rem}.help-header h2{color:#111827;color:var(--text-primary,#111827);font-size:1.5rem}.help-description,.help-subtitle{color:#6b7280;color:var(--text-secondary,#6b7280);line-height:1.6;margin-bottom:24px}.feature-grid{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.feature-card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;padding:20px}.feature-icon{font-size:2rem;margin-bottom:12px}.feature-card h3{color:#111827;color:var(--text-primary,#111827);font-size:1rem;margin:0 0 8px}.feature-card p{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;margin:0}.help-section{margin-bottom:24px}.help-section h3{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);color:#111827;color:var(--text-primary,#111827);font-size:1.1rem;margin-bottom:12px;padding-bottom:8px}.help-section ul{margin:0;padding-left:20px}.help-section li{color:#4b5563;color:var(--text-secondary,#4b5563);line-height:1.5;margin-bottom:8px}.help-section li strong{color:#111827;color:var(--text-primary,#111827)}.quick-start-section{background:#eff6ff;background:var(--primary-light,#eff6ff);border-radius:8px;margin-top:24px;padding:20px}.quick-start-section h3{color:#2563eb;color:var(--primary-blue,#2563eb);margin:0 0 16px}.quick-start-list{margin:0;padding-left:20px}.quick-start-list li{color:#4b5563;color:var(--text-secondary,#4b5563);margin-bottom:12px}.quick-start-list li strong{color:#111827;color:var(--text-primary,#111827)}.dev-tool-option{background:#f3f4f6;background:var(--gray-100,#f3f4f6);border-radius:8px;margin-bottom:12px;padding:16px}.dev-tool-label{align-items:flex-start;cursor:pointer;display:flex;gap:12px;-webkit-user-select:none;user-select:none}.dev-tool-label input[type=checkbox]{cursor:pointer;height:18px;margin-top:2px;width:18px}.dev-tool-info strong{color:#111827;color:var(--text-primary,#111827);display:block;margin-bottom:4px}.dev-tool-info p{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;margin:0}.warning-text{color:#f59e0b;color:var(--warning,#f59e0b);font-weight:600}.dev-tool-section{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);margin-top:24px;padding-top:24px}.dev-tool-section h3{font-size:1rem;margin:0 0 8px}.coming-soon-note,.muted-note{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;font-style:italic}.section-header{gap:12px;margin-bottom:12px}.section-header h3{margin:0}.category-actions{display:flex;gap:8px}.category-action-btn{background:#f3f4f6;background:var(--gray-100,#f3f4f6);border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:4px;cursor:pointer;font-size:.75rem;padding:4px 10px;transition:all .2s}.category-action-btn:hover{background:#e5e7eb;background:var(--gray-200,#e5e7eb)}.category-grid{grid-gap:8px;gap:8px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.category-item{align-items:center;background:#f9fafb;background:var(--gray-50,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:8px 12px;transition:all .2s;-webkit-user-select:none;user-select:none}.category-item:hover{background:#fff;border-color:#2563eb;border-color:var(--primary-blue,#2563eb)}.category-item input[type=checkbox]{cursor:pointer;height:16px;width:16px}.category-emoji{font-size:1rem}.category-label{color:#374151;color:var(--text-primary,#374151);font-size:.8rem}.feedback-placeholder .coming-soon-banner{background:#eff6ff;background:var(--primary-light,#eff6ff);border-radius:8px;color:#2563eb;color:var(--primary-blue,#2563eb);font-weight:500;margin-bottom:24px;padding:12px 16px;text-align:center}.placeholder-form{background:#f3f4f6;background:var(--gray-100,#f3f4f6);border-radius:8px;opacity:.6;padding:20px}.placeholder-form .form-group{margin-bottom:16px}.placeholder-form label{color:#111827;color:var(--text-primary,#111827);display:block;font-weight:500;margin-bottom:6px}.placeholder-form input,.placeholder-form select,.placeholder-form textarea{background:#fff;border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:6px;font-size:.875rem;padding:10px 12px;width:100%}.placeholder-form .submit-btn{background:#2563eb;background:var(--primary-blue,#2563eb);border:none;border-radius:6px;color:#fff;cursor:not-allowed;font-size:1rem;padding:12px 24px;width:100%}.placeholder-note{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;font-style:italic;margin-top:16px}.index-search-section{margin-bottom:20px}.help-search-container{align-items:center;background:#fff;border:2px solid #e5e7eb;border:2px solid var(--border-color,#e5e7eb);border-radius:8px;display:flex;padding:8px 12px;transition:border-color .2s}.help-search-container:focus-within{border-color:#2563eb;border-color:var(--primary-blue,#2563eb)}.help-search-icon{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:1rem;margin-right:8px}.help-search-input{background:#0000;border:none;flex:1 1;font-size:1rem;outline:none}.help-search-clear{background:none;border:none;color:#6b7280;color:var(--text-secondary,#6b7280);cursor:pointer;font-size:1.25rem;padding:0 4px}.help-search-clear:hover{color:#111827;color:var(--text-primary,#111827)}.help-search-results{margin-bottom:24px}.help-search-results-header{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;margin-bottom:12px}.help-search-results-list{display:flex;flex-direction:column;gap:8px}.help-search-result-item{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px;transition:all .2s}.help-search-result-item:hover{border-color:#2563eb;border-color:var(--primary-blue,#2563eb);box-shadow:0 2px 8px #2563eb1a}.result-preview{align-items:center;display:flex;justify-content:center;width:60px}.result-content{flex:1 1}.result-title{color:#111827;color:var(--text-primary,#111827);font-weight:600;margin-bottom:4px}.result-description{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;margin-bottom:8px}.result-meta{display:flex;font-size:.75rem;gap:12px}.result-category,.result-page{color:#9ca3af;color:var(--text-tertiary,#9ca3af)}.help-search-hint,.help-search-loading,.help-search-no-results{color:#6b7280;color:var(--text-secondary,#6b7280);padding:24px;text-align:center}.no-results-icon{display:block;font-size:2rem;margin-bottom:8px}.no-results-hint{font-size:.875rem;margin-top:8px}.index-filters{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px}.filter-group{align-items:center;gap:8px}.filter-group label{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem}.filter-group select{background:#fff;border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:6px;font-size:.875rem;padding:6px 12px}.view-toggle{margin-left:auto}.view-btn{background:#fff;border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);cursor:pointer;font-size:1rem;padding:6px 10px}.view-btn:first-child{border-radius:6px 0 0 6px}.view-btn:last-child{border-left:none;border-radius:0 6px 6px 0}.view-btn.active{background:#2563eb;background:var(--primary-blue,#2563eb);border-color:#2563eb;border-color:var(--primary-blue,#2563eb);color:#fff}.index-stats{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;margin-bottom:16px}.index-grid{display:flex;flex-direction:column;gap:24px}.index-category-section{margin-bottom:8px}.category-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);color:#111827;color:var(--text-primary,#111827);font-size:1rem;margin-bottom:12px;padding-bottom:8px}.category-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.help-index-card{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;cursor:pointer;transition:all .2s}.help-index-card:hover{box-shadow:0 2px 8px #2563eb1a}.help-index-card.expanded,.help-index-card:hover{border-color:#2563eb;border-color:var(--primary-blue,#2563eb)}.card-main{display:flex;gap:12px;padding:12px}.card-preview{align-items:center;display:flex;flex-shrink:0;justify-content:center;width:50px}.card-content{flex:1 1;min-width:0}.card-header{align-items:flex-start;display:flex;gap:8px;justify-content:space-between;margin-bottom:4px}.card-title{color:#111827;color:var(--text-primary,#111827);font-size:.9rem;font-weight:600}.card-badges{display:flex;gap:4px}.card-badge{background:#f3f4f6;background:var(--gray-100,#f3f4f6);border-radius:4px;font-size:.75rem;padding:2px 6px}.card-description{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.8rem;line-height:1.4}.card-expand-icon{color:#9ca3af;color:var(--text-tertiary,#9ca3af);font-size:.75rem;padding:4px}.card-details{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);margin-top:8px;padding:12px}.card-full-description{color:#4b5563;color:var(--text-secondary,#4b5563);font-size:.85rem;line-height:1.5;margin-bottom:12px}.card-keywords{align-items:center;display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.keywords-label,.related-label{color:#9ca3af;color:var(--text-tertiary,#9ca3af);font-size:.75rem;margin-right:4px}.keyword-tag{background:#eff6ff;background:var(--primary-light,#eff6ff);border-radius:4px;color:#2563eb;color:var(--primary-blue,#2563eb);font-size:.7rem;padding:2px 6px}.card-related{align-items:center;display:flex;flex-wrap:wrap;gap:4px}.related-link{border-radius:4px;color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.7rem;padding:2px 6px}.card-location,.related-link{background:#f3f4f6;background:var(--gray-100,#f3f4f6)}.card-location{align-items:center;border-radius:6px;display:flex;gap:6px;margin-bottom:12px;padding:8px 12px}.location-icon{font-size:.9rem}.location-path{color:#374151;color:var(--text-primary,#374151);font-family:monospace;font-size:.8rem}.card-usage{background:#eff6ff;background:var(--primary-light,#eff6ff);border-left:3px solid #2563eb;border-left:3px solid var(--primary-blue,#2563eb);border-radius:0 6px 6px 0;display:flex;flex-direction:column;gap:4px;margin-bottom:12px;padding:10px 12px}.usage-label{color:#2563eb;color:var(--primary-blue,#2563eb);font-size:.75rem;font-weight:600}.usage-text{color:#4b5563;color:var(--text-secondary,#4b5563);font-size:.8rem;line-height:1.4}.card-large-preview{background:#f9fafb;background:var(--gray-50,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:8px;display:flex;justify-content:center;margin-bottom:12px;padding:16px}.large-preview-container{align-items:center;display:flex;justify-content:center;min-height:60px}.card-variants{margin-bottom:12px}.variants-label{color:#374151;color:var(--text-primary,#374151);display:block;font-size:.75rem;font-weight:600;margin-bottom:8px}.variants-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.variant-item{background:#f9fafb;background:var(--gray-50,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:6px;gap:10px;padding:8px 10px}.variant-item,.variant-preview{align-items:center;display:flex}.variant-preview{flex-shrink:0;justify-content:center;min-width:50px}.variant-info{display:flex;flex-direction:column;gap:2px;min-width:0}.variant-name{color:#374151;color:var(--text-primary,#374151);font-size:.75rem;font-weight:600}.variant-description{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.7rem;line-height:1.3}.help-index-card.compact{display:flex;gap:12px;padding:10px 12px}.help-index-card.compact .card-preview{width:40px}.help-index-card.compact .card-title{font-size:.85rem}.help-index-card.compact .card-description{font-size:.75rem}.index-list{display:flex;flex-direction:column;gap:8px}.index-empty{color:#6b7280;color:var(--text-secondary,#6b7280);padding:40px;text-align:center}.index-empty button{background:#2563eb;background:var(--primary-blue,#2563eb);border:none;border-radius:6px;color:#fff;cursor:pointer;margin-top:12px;padding:8px 16px}.preview-wrapper{pointer-events:none;-webkit-user-select:none;user-select:none}.preview-missing{align-items:center;background:#f3f4f6;background:var(--gray-100,#f3f4f6);border-radius:4px;color:#9ca3af;color:var(--text-tertiary,#9ca3af);display:flex;height:40px;justify-content:center;width:40px}.preview-btn{border:1px solid;border-radius:4px;font-size:.7rem;padding:4px 10px;white-space:nowrap}.preview-btn-add{background:#dcfce7;background:var(--success-light,#dcfce7);border-color:#16a34a;border-color:var(--success,#16a34a);color:#16a34a;color:var(--success,#16a34a)}.preview-btn-primary{background:#2563eb;background:var(--primary-blue,#2563eb);border-color:#2563eb;border-color:var(--primary-blue,#2563eb);color:#fff}.preview-btn-secondary{background:#fff;border-color:#d1d5db;border-color:var(--border-color,#d1d5db);color:#374151;color:var(--text-primary,#374151)}.preview-btn-danger{background:#fef2f2;background:var(--danger-light,#fef2f2);border-color:#dc2626;border-color:var(--danger,#dc2626);color:#dc2626;color:var(--danger,#dc2626)}.preview-btn-help{background:#eff6ff;background:var(--primary-light,#eff6ff);border-color:#2563eb;border-color:var(--primary-blue,#2563eb);color:#2563eb;color:var(--primary-blue,#2563eb)}.preview-toggle{align-items:center;display:flex}.preview-toggle input{height:14px;width:14px}.preview-toggle-slider{background:#d1d5db;background:var(--gray-300,#d1d5db);border-radius:8px;height:16px;margin-left:4px;width:28px}.preview-cell{align-items:center;background:#fff;border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:4px;display:flex;height:24px;justify-content:center;width:24px}.preview-cell input{height:14px;width:14px}.preview-dropdown{background:#fff;min-width:80px}.preview-dropdown,.preview-input{border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:4px;font-size:.7rem;padding:4px 8px}.preview-input{width:100px}.preview-input-search{border-radius:12px}.preview-tab{background:#f3f4f6;background:var(--gray-100,#f3f4f6);border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-bottom:none;border-radius:4px 4px 0 0;font-size:.7rem;padding:4px 10px}.preview-tab-active{background:#fff;border-bottom:1px solid #fff;margin-bottom:-1px}.preview-threshold{align-items:center;background:#f9fafb;background:var(--gray-50,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:4px;display:flex;font-size:.7rem;gap:8px;padding:4px 8px}.preview-threshold-label{color:#2563eb;color:var(--primary-blue,#2563eb);font-weight:600}.preview-threshold-value{color:#6b7280;color:var(--text-secondary,#6b7280)}.preview-progress-cell{align-items:center;background:#dcfce7;background:var(--success-light,#dcfce7);border-radius:4px;display:flex;justify-content:center;padding:4px 8px}.preview-grade{color:#16a34a;color:var(--success,#16a34a);font-size:.7rem;font-weight:600}.preview-nav-item{align-items:center;background:#1f2937;background:var(--gray-800,#1f2937);border-radius:4px;color:#fff;display:flex;font-size:.7rem;gap:6px;padding:4px 8px}.preview-nav-icon{font-size:.8rem}.preview-settings-panel{border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:4px;font-size:.6rem;overflow:hidden;width:80px}.preview-settings-header{background:#f3f4f6;background:var(--gray-100,#f3f4f6);font-weight:600;padding:3px 6px}.preview-settings-row{align-items:center;border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;padding:3px 6px}.preview-settings-row input{height:10px;width:10px}.preview-context-menu{background:#fff;border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:4px;box-shadow:0 2px 8px #0000001a;font-size:.65rem}.preview-menu-item{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-color,#f3f4f6);padding:3px 10px}.preview-menu-item:last-child{border-bottom:none}.preview-modal{border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:4px;box-shadow:0 2px 8px #0000001a;font-size:.6rem;overflow:hidden;width:70px}.preview-modal-header{background:#2563eb;background:var(--primary-blue,#2563eb);color:#fff;font-weight:500;padding:3px 6px}.preview-modal-body{background:#fff;padding:6px}.preview-user-menu{align-items:center;background:#f3f4f6;background:var(--gray-100,#f3f4f6);border-radius:4px;display:flex;font-size:.7rem;gap:4px;padding:4px 8px}.preview-avatar{font-size:.9rem}.preview-sort{display:flex;gap:2px}.preview-sort-btn{background:#fff;border:1px solid #d1d5db;border:1px solid var(--border-color,#d1d5db);border-radius:2px;font-size:.7rem;padding:2px 6px}.preview-drag-handle{color:#9ca3af;color:var(--text-tertiary,#9ca3af);font-size:.9rem;letter-spacing:-2px}@media (max-width:768px){.help-panel{border-radius:0;height:100vh;max-height:none;max-width:none;width:100vw}.help-panel-body{flex-direction:column}.help-sidebar{flex-direction:row;gap:4px;overflow-x:auto;padding:8px;width:100%}.help-nav-item{flex-direction:column;min-width:80px;padding:8px 12px;text-align:center}.help-nav-label{font-size:.75rem}.index-filters{flex-direction:column}.view-toggle{margin-left:0}.category-grid{grid-template-columns:1fr}}.spell-check-button-square{justify-content:center;min-width:38px;padding:8px!important;position:relative}.spell-check-button-square .spell-check-icon{flex-shrink:0}.spell-check-button-square .abc-icon{fill:#fff}.spell-check-icon.spinning{animation:spin 1s linear infinite}.spell-check-status-indicator{align-items:center;border-radius:8px;box-shadow:0 1px 3px #0000004d;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;line-height:1;min-width:16px;padding:2px 4px;position:absolute;right:-4px;top:-4px;z-index:1}.spell-check-status-indicator.error{background:#ef4444;color:#fff}.spell-check-status-indicator.success{background:#10b981;color:#fff}.spell-check-modal{display:flex;flex-direction:column;max-height:75vh;max-width:500px}.spell-check-modal-large{display:flex;flex-direction:column;margin:0;max-height:72vh;max-width:620px;min-width:480px;width:auto}.spell-check-modal .modal-body,.spell-check-modal-large .modal-body{max-height:calc(72vh - 100px);overflow-y:auto;padding:var(--spacing-sm) var(--spacing-md)}.spell-check-draggable{background:var(--dark-header)!important;border-bottom:none!important;color:var(--text-white)!important;cursor:grab!important;-webkit-user-select:none;user-select:none}.spell-check-draggable:active{background:var(--dark-navy)!important;cursor:grabbing!important}.spell-check-draggable .btn-close{color:var(--text-white)!important}.spell-check-draggable .btn-close:hover{background-color:#fff3!important}.header-with-handle{align-items:center;display:flex;gap:var(--spacing-sm)}.drag-handle-icon{color:var(--text-white);flex-shrink:0;opacity:.7}.spell-check-draggable h2{color:var(--text-white)!important;margin:0}.spell-check-success{padding:var(--spacing-lg) var(--spacing-md);text-align:center}.success-icon{color:var(--success-green);margin-bottom:var(--spacing-sm)}.spell-check-success h3{color:var(--text-primary);font-size:var(--font-size-h3);font-weight:600;margin:var(--spacing-sm) 0 var(--spacing-xs)}.spell-check-success p{color:var(--text-secondary);font-size:var(--font-size-small);margin:0}.spell-check-summary{background:var(--gray-100);border:1px solid var(--border-light);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.error-count{color:var(--text-primary);font-size:var(--font-size-small);margin:0}.error-count strong{color:var(--danger-red);font-weight:600}.spell-check-assessments{display:flex;flex-direction:column;gap:var(--spacing-md)}.assessment-card{background:var(--background-white);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);overflow:hidden}.assessment-card-header{align-items:center;background:var(--gray-700);border-bottom:2px solid var(--primary-blue);color:var(--text-white);display:flex;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md)}.assessment-card-header.clickable{cursor:pointer;transition:background-color .2s ease}.assessment-card-header.clickable:hover{background:var(--gray-600)}.header-left{align-items:center;display:flex;gap:var(--spacing-sm)}.collapse-icon{stroke:var(--text-white);stroke-width:2;fill:none;flex-shrink:0;height:16px;transition:transform .2s ease;width:16px}.collapse-icon.collapsed{transform:rotate(-90deg)}.assessment-card-header h3{color:var(--text-white);font-size:var(--font-size-body);font-weight:600;margin:0}.error-badge{background:var(--danger-red);border-radius:10px;color:var(--text-white);font-size:var(--font-size-caption);font-weight:600;padding:2px 8px}.spell-check-grid{display:flex;flex-direction:column}.grid-header{grid-gap:var(--spacing-sm);background:var(--gray-600);color:var(--text-white);display:grid;font-size:var(--font-size-caption);font-weight:600;gap:var(--spacing-sm);grid-template-columns:1fr 1fr;letter-spacing:.3px;padding:5px var(--spacing-sm);text-transform:uppercase}.grid-col-suggestions,.grid-col-word{align-items:center;display:flex}.spell-check-row{grid-gap:var(--spacing-sm);border-bottom:1px solid var(--border-light);display:grid;gap:var(--spacing-sm);grid-template-columns:1fr 1fr;padding:var(--spacing-sm);transition:background-color .15s ease}.spell-check-row:last-child{border-bottom:none}.spell-check-row:hover{background:var(--gray-50)}.spell-check-row.has-selection{background:#4f46e50d;border-left:2px solid var(--primary-blue)}.grid-col-word{align-items:flex-start;display:flex;flex-direction:column;gap:4px}.sentence-context{word-wrap:break-word;font-size:12px;line-height:1.4;max-width:100%}.context-after,.context-before,.sentence-context{color:var(--text-primary)}.misspelled-in-context{background:#dc26261a;border-bottom:2px wavy var(--danger-red);border-radius:2px;color:var(--danger-red);font-weight:600;padding:1px 2px}.field-context{color:var(--text-secondary);font-size:10px;font-weight:500;letter-spacing:.3px;text-transform:uppercase}.grid-col-suggestions{align-items:flex-start;display:flex}.suggestions-container{display:flex;flex-direction:column;gap:4px;width:100%}.suggestion-chips{display:flex;flex-wrap:wrap;gap:4px}.suggestion-chip{align-items:center;background:var(--background-white);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:var(--font-size-caption);font-weight:500;gap:4px;padding:4px 8px;transition:all .15s ease}.suggestion-chip:hover{background:var(--primary-light);border-color:var(--primary-light);color:var(--text-white)}.suggestion-chip.selected{background:var(--primary-blue);border-color:var(--primary-blue);color:var(--text-white);font-weight:600}.suggestion-chip svg{flex-shrink:0;height:11px;width:11px}.custom-correction-input{background:var(--background-white);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-caption);padding:5px 8px;transition:border-color .2s ease;width:100%}.custom-correction-input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #4f46e51a;outline:none}.custom-correction-input::placeholder{color:var(--text-secondary);font-style:italic;opacity:.7}.assessment-card-footer{align-items:center;background:var(--gray-50);border-top:1px solid var(--border-light);display:flex;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md)}.selection-info{color:var(--text-secondary);font-size:var(--font-size-caption);font-weight:500}.btn-apply{border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-small);font-weight:600;padding:6px var(--spacing-md);transition:all .15s ease}.btn-apply,.btn-primary{border:1px solid var(--primary-blue)}.btn-primary:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn-secondary{border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);padding:var(--spacing-sm) var(--spacing-lg);transition:all .2s ease}.spell-check-tabs{border-bottom:2px solid var(--border-color);gap:0}.spell-check-tab,.spell-check-tabs{background:var(--gray-100);display:flex}.spell-check-tab{align-items:center;border:none;border-bottom:2px solid #0000;color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:var(--font-size-small);font-weight:600;gap:var(--spacing-xs);justify-content:center;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.spell-check-tab:hover{background:var(--gray-200);color:var(--text-primary)}.spell-check-tab.active{background:var(--background-white);border-bottom-color:var(--primary-blue);color:var(--primary-blue)}.tab-badge{align-items:center;background:var(--danger-red);border-radius:9px;color:var(--text-white);display:inline-flex;font-size:10px;font-weight:700;height:18px;justify-content:center;line-height:1;min-width:18px;padding:0 5px}.spell-check-tab.active .tab-badge{background:var(--primary-blue)}.btn-ignore-word{background:var(--gray-100);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:var(--font-size-caption);font-weight:500;padding:5px 8px;transition:all .15s ease;width:100%}.btn-ignore-word:hover{background:var(--gray-200);border-color:var(--gray-400);color:var(--text-primary)}.ignored-words-view{padding:var(--spacing-md)}.no-ignored-words{color:var(--text-secondary);padding:var(--spacing-xl) var(--spacing-md);text-align:center}.no-ignored-words p{font-size:var(--font-size-body);margin:0 0 var(--spacing-sm)}.no-ignored-words .help-text{color:var(--text-tertiary);font-size:var(--font-size-small)}.ignored-words-header{background:var(--gray-100);border:1px solid var(--border-light);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md)}.ignored-count{color:var(--text-primary);font-size:var(--font-size-small);margin:0}.ignored-count strong{color:var(--primary-blue);font-weight:600}.ignored-words-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.ignored-word-item{align-items:center;background:var(--background-white);border:1px solid var(--border-color);border-radius:var(--radius-sm);display:flex;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);transition:all .15s ease}.ignored-word-item:hover{background:var(--gray-50);border-color:var(--gray-400)}.ignored-word-text{color:var(--text-primary);font-size:var(--font-size-body);font-weight:500}.btn-unignore{align-items:center;background:var(--danger-red);border:none;border-radius:50%;color:var(--text-white);cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:24px;justify-content:center;line-height:1;transition:all .15s ease;width:24px}.btn-unignore:hover{background:#dc2626;transform:scale(1.1)}@media (max-width:768px){.spell-check-modal-large{max-height:85vh;max-width:95vw;width:95vw}.spell-check-grid{font-size:var(--font-size-small)}.grid-header{gap:0;grid-template-columns:1fr}.grid-header .grid-col-suggestions{display:none}.spell-check-row{gap:var(--spacing-sm);grid-template-columns:1fr}.grid-col-word{border-bottom:1px solid var(--border-light);padding-bottom:var(--spacing-xs)}.suggestion-chips{flex-direction:column;width:100%}.suggestion-chip{justify-content:space-between;width:100%}.assessment-card-footer{align-items:stretch;flex-direction:column;gap:var(--spacing-sm)}.btn-apply{width:100%}}.assessment-creator-v2,.assessment-creator-v2 *,.assessment-creator-v2 input,.assessment-creator-v2 label,.assessment-creator-v2 select,.assessment-creator-v2 textarea{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.assessment-creator-v2{margin:0 auto;max-width:1100px;padding:var(--spacing-lg)}.creator-header{border-bottom:2px solid var(--border-light);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);text-align:center}.header-content{flex-direction:column;gap:var(--spacing-sm)}.header-title-row{align-items:center;display:flex;gap:var(--spacing-md);justify-content:center}.creator-header h1{color:var(--gray-900);font-size:28px;font-weight:700;margin:0}.creator-subtitle{color:var(--gray-600);font-size:var(--font-size-body);margin:0}.edit-details{align-items:center;color:var(--gray-600);display:flex;font-size:var(--font-size-small);gap:var(--spacing-sm);justify-content:center;margin-top:var(--spacing-sm)}.edit-detail-item strong{color:var(--gray-700);font-weight:600;margin-right:4px}.edit-detail-separator{color:var(--gray-400)}.error-banner{background:#fee2e2;border:1px solid #fecaca;border-radius:var(--radius-md);color:var(--danger-red);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.error-banner strong{display:block;margin-bottom:var(--spacing-xs)}.error-banner ul{margin:0;padding-left:20px}.step-section{background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);overflow:hidden;transition:all .3s ease}.step-section:not(.active){opacity:.7}.step-section.active{border-color:var(--gray-800);box-shadow:0 4px 12px #1f293726}.step-header{align-items:center;background:var(--gray-800);color:#fff;cursor:pointer;display:flex;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);transition:all .2s ease;-webkit-user-select:none;user-select:none}.step-section:not(.active) .step-header{background:var(--gray-200);color:var(--gray-700)}.step-header:hover{opacity:.95}.step-number{align-items:center;background:#fff;border-radius:50%;color:var(--gray-800);display:flex;flex-shrink:0;font-size:var(--font-size-body);font-weight:700;height:36px;justify-content:center;width:36px}.step-section:not(.active) .step-number{background:var(--gray-400);color:#fff}.step-info{flex:1 1}.step-info h2{font-size:var(--font-size-body);font-weight:600;margin:0}.step-description{font-size:var(--font-size-small);margin:4px 0 0;opacity:.9}.step-check{align-items:center;background:var(--success-green);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:24px;justify-content:center;width:24px}.step-content{padding:var(--spacing-xl)}.info-box{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-left:4px solid #0369a1;border-radius:var(--radius-sm);margin-bottom:var(--spacing-xl);padding:var(--spacing-md)}.info-box p{color:#0369a1;font-size:var(--font-size-small);line-height:1.6;margin:0}.form-grid-v2{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-row-v2{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:1fr 1fr}.form-group-v2{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group-v2 label{color:var(--gray-800);font-size:var(--font-size-small);font-weight:600}.form-group-v2 input,.form-group-v2 select,.form-group-v2 textarea{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:inherit;font-size:var(--font-size-small);padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.form-group-v2 input:focus,.form-group-v2 select:focus,.form-group-v2 textarea:focus{border-color:var(--gray-800);box-shadow:0 0 0 3px #1f29371a;outline:none}.form-group-v2 input:disabled{background:var(--gray-100);color:var(--gray-500);cursor:not-allowed}.form-group-v2 textarea{min-height:80px;resize:vertical}.required{color:var(--danger-red)}.char-counter{color:var(--gray-500);font-size:var(--font-size-caption);text-align:right}.preset-actions{gap:var(--spacing-sm);margin-top:var(--spacing-md)}.btn-preset{background:var(--success-green);border-color:var(--success-green)}.btn-preset:hover{background:var(--success-hover);border-color:var(--success-hover);box-shadow:0 4px 8px #0596694d}.step-actions{align-items:center;border-top:1px solid var(--border-light);display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-xl)}.final-actions,.step-actions{justify-content:space-between}.right-actions{display:flex;gap:var(--spacing-sm)}.btn-back{background:#fff;border:1px solid var(--gray-300);color:var(--gray-700)}.btn-back:hover{background:var(--gray-100);border-color:var(--gray-400);box-shadow:0 2px 4px #0000001a}.btn-reset{background:#0000!important;border:1px solid var(--danger-red)!important;color:var(--danger-red)!important}.btn-reset:hover{background:var(--danger-red)!important;box-shadow:0 4px 8px #dc26264d;color:#fff!important}.btn-submit{background:var(--primary-blue);border-color:var(--primary-blue)}.btn-submit:hover{background:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 4px 8px #2563eb4d}.btn-next:disabled,.btn-submit:disabled{cursor:not-allowed;opacity:.5}.btn-modal-load{background:var(--gray-800);border-color:var(--gray-800)}.btn-modal-load:hover{background:var(--gray-700);border-color:var(--gray-700);box-shadow:0 4px 8px #1f29374d}.btn-modal-edit{background:#f59e0b!important;border:1px solid #f59e0b!important}.btn-modal-edit:hover{background:#d97706!important;border-color:#d97706!important;box-shadow:0 4px 8px #f59e0b4d}.btn-modal-delete{background:var(--danger-red)!important;border:1px solid var(--danger-red)!important}.btn-modal-delete:hover{background:#b91c1c!important;border-color:#b91c1c!important;box-shadow:0 4px 8px #dc26264d}.btn-modal-create{background:var(--success-green)!important;border:1px solid var(--success-green)!important}.btn-modal-create:hover{background:var(--success-hover)!important;border-color:var(--success-hover)!important;box-shadow:0 4px 8px #0596694d}.btn-modal-save{background:var(--primary-blue);border-color:var(--primary-blue)}.btn-modal-save:hover{background:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 4px 8px #2563eb4d}.type-selector-section{border-bottom:1px solid var(--border-light);margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-xl)}.add-level-section{display:flex;justify-content:flex-end;margin-bottom:var(--spacing-lg)}.btn-add-level{background:var(--gray-800);border:1px solid var(--gray-800);border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:var(--font-size-small);font-weight:500;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.btn-add-level:hover{background:var(--gray-700);border-color:var(--gray-700)}.levels-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.level-card{background:#fff;border:2px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden;transition:all .3s ease}.level-card:hover{border-color:var(--gray-400);box-shadow:0 2px 8px #00000014}.level-card.expanded{border-color:var(--gray-800);box-shadow:0 4px 16px #1f293726;grid-column:1/-1}.level-card-header{align-items:center;background:linear-gradient(135deg,var(--gray-800) 0,var(--gray-700) 100%);display:flex;gap:12px;justify-content:space-between;min-height:48px;padding:10px 14px;position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none}.level-card-header:hover{background:linear-gradient(135deg,var(--gray-700) 0,var(--gray-600) 100%)}.level-info-row{align-items:center;display:flex;flex:1 1;gap:12px;min-width:0}.level-num-badge{align-items:center;background:#fff;border-radius:50%;color:var(--gray-800);display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:28px;justify-content:center;width:28px}.level-mark{color:#fff;flex:1 1;font-size:14px;line-height:1.4;min-width:0;overflow:hidden;text-overflow:ellipsis}.level-mark,.level-value{font-weight:600;white-space:nowrap}.level-value{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:20px;color:#0369a1;flex-shrink:0;font-size:var(--font-size-caption);padding:4px 12px}.level-actions{align-items:center;display:flex;flex-shrink:0;gap:var(--spacing-xs)}.btn-collapse-card,.btn-expand-card{align-items:center;background:#0000;border:1px solid #ffffff4d;border-radius:4px;color:#ffffffd9;cursor:pointer;display:flex;flex-shrink:0;height:24px;justify-content:center;padding:0;transition:all .2s ease;width:24px}.btn-collapse-card svg,.btn-expand-card svg{display:block;height:14px;width:14px}.btn-collapse-card:hover,.btn-expand-card:hover{background:#ffffff26;border-color:#ffffff80;color:#fff}.btn-remove-level{align-items:center;background:#dc2626e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:16px;height:24px;justify-content:center;line-height:1;transition:all .2s ease;width:24px}.btn-remove-level:hover{background:var(--danger-red);transform:scale(1.1)}.level-details{background:#fff;border-top:1px solid var(--border-light);padding:var(--spacing-md)}.detail-row{grid-gap:var(--spacing-md);align-items:start;display:grid;gap:var(--spacing-md);grid-template-columns:1fr 120px;margin-bottom:var(--spacing-md)}.detail-row .form-group-v2{display:flex;flex-direction:column}.detail-row .form-group-v2 label{align-items:center;display:flex;height:20px;margin-bottom:var(--spacing-xs)}.detail-row .form-group-v2 input{box-sizing:border-box;height:38px}.detail-row .form-group-v2:last-child input{text-align:center}.level-details .form-group-v2{margin-bottom:var(--spacing-md)}.level-details .form-group-v2:last-of-type{margin-bottom:0}.field-header-with-toggle{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--spacing-xs)}.toggle-label{align-items:center;color:var(--gray-600);cursor:pointer;display:flex;font-size:var(--font-size-caption);font-weight:500;gap:6px}.toggle-checkbox{accent-color:var(--gray-800);cursor:pointer;height:16px;width:16px}.toggle-text{-webkit-user-select:none;user-select:none}.form-group-v2 textarea:disabled{background:var(--gray-100);color:var(--gray-500);cursor:not-allowed;opacity:.6}.level-details label{color:var(--gray-700);font-size:var(--font-size-caption);font-weight:600}.level-details input,.level-details textarea{font-size:var(--font-size-small)}.level-details textarea{min-height:70px}.btn-collapse{margin-top:var(--spacing-md)}@media (max-width:768px){.assessment-creator-v2{padding:var(--spacing-md)}.creator-header h1{font-size:24px}.creator-subtitle{font-size:var(--font-size-small)}.form-row-v2,.levels-grid{grid-template-columns:1fr}.step-content{padding:var(--spacing-md)}.step-actions{align-items:stretch;flex-direction:column}.right-actions{flex-direction:column;width:100%}.btn-back,.btn-next,.btn-reset,.btn-submit{width:100%}.preset-actions{flex-direction:column}.btn-preset,.btn-preset-manage{width:100%}.detail-row{grid-template-columns:1fr}}@media (max-width:480px){.step-header{padding:var(--spacing-sm) var(--spacing-md)}.step-number{font-size:14px;height:32px;width:32px}.step-info h2{font-size:var(--font-size-small)}.step-description{font-size:var(--font-size-caption)}.level-card-header{align-items:stretch;flex-direction:column;gap:var(--spacing-xs)}.level-info-row{width:100%}.level-actions{justify-content:flex-end;width:100%}.level-name-value{font-size:var(--font-size-caption)}}.custom-presets-menu-overlay{z-index:999}.custom-presets-menu{border:2px solid var(--gray-800);border-radius:var(--radius-md)}.presets-menu-header{background:var(--gray-800);padding:10px 12px}.presets-menu-header h3{font-size:15px}.custom-presets-menu .btn-close{background:none;border:none;border-radius:4px;color:#fffc;cursor:pointer;font-size:24px;line-height:1;padding:4px 8px}.custom-presets-menu .btn-close:hover{background:#ffffff1a;color:#fff}.no-presets-message{color:var(--gray-500);padding:24px 16px;text-align:center}.no-presets-message p{margin:0}.presets-list{display:flex;flex-direction:column;gap:12px}.preset-item{align-items:center;background:#fff;border:1px solid var(--gray-300);border-radius:var(--radius-md);display:flex;justify-content:space-between;padding:12px;transition:all .2s ease}.preset-item:hover{border-color:var(--primary-blue);box-shadow:0 2px 4px #4f46e51a}.preset-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.preset-name{color:var(--gray-800);font-size:14px}.preset-meta{color:var(--gray-500);font-size:12px}.preset-actions{display:flex;flex-shrink:0;gap:8px}.presets-menu-footer{background:var(--gray-50);border-top:1px solid var(--gray-200);justify-content:space-between}.edit-preset-modal{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.edit-preset-modal .modal-content{background:#fff;border:2px solid var(--gray-800);border-radius:var(--radius-md);box-shadow:0 8px 24px #0003;display:flex;flex-direction:column;max-height:80vh;max-width:90vw;overflow:hidden;width:500px}.edit-preset-modal .modal-header{align-items:center;background:var(--gray-800);color:#fff;display:flex;justify-content:space-between;padding:10px 12px}.edit-preset-modal .modal-header h3{color:#fff;font-size:15px;font-weight:600;margin:0}.edit-preset-modal .btn-close{background:none;border:none;border-radius:4px;color:#fffc;cursor:pointer;font-size:24px;line-height:1;padding:4px 8px}.edit-preset-modal .btn-close:hover{background:#ffffff1a;color:#fff}.edit-preset-modal .modal-body{flex:1 1;overflow-y:auto;padding:16px}.edit-preset-modal .modal-footer{background:var(--gray-50);border-top:1px solid var(--gray-200);display:flex;gap:8px;justify-content:flex-end;padding:12px 16px}.edit-preset-modal .form-group{margin-bottom:16px}.edit-preset-modal .form-group label{color:var(--gray-700);display:block;font-size:var(--font-size-small);font-weight:600;margin-bottom:6px}.edit-preset-modal .form-group input[type=text]{border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-size:var(--font-size-body);padding:8px 12px;width:100%}.edit-preset-modal .form-group input[type=text]:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #4f46e51a;outline:none}.levels-list{display:flex;flex-direction:column;gap:12px}.level-edit-item{align-items:center;display:flex;gap:12px}.level-name-input{flex:2 1}.level-name-input,.level-value-input{border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-size:var(--font-size-body);padding:8px 12px}.level-value-input{flex:1 1;text-align:center}.level-name-input:focus,.level-value-input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px #4f46e51a;outline:none}.btn-sm{border-radius:var(--radius-sm);font-size:12px;padding:6px 12px}.btn-warning{background:var(--warning-amber);border:none}.btn-warning:hover{background:var(--warning-hover)}.btn-danger{background:var(--danger-red);border:none}.btn-danger:hover{background:var(--danger-hover)}.assessment-master-log{margin:0 auto;max-width:1800px;padding:var(--spacing-lg)}.assessment-master-log h1{color:var(--gray-900);font-size:var(--font-size-heading);font-weight:700;margin:0 0 var(--spacing-md) 0}.assessment-master-log h3{color:var(--gray-700);font-size:var(--font-size-body);font-weight:600;margin:0 0 var(--spacing-md) 0}.error-message{background-color:#fee2e2;border:1px solid #fecaca;border-radius:var(--radius-md);color:#dc2626;font-size:var(--font-size-small);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.lost-assessments-section{margin-top:var(--spacing-xl)}.lost-assessments-section h3{border-bottom:2px solid var(--gray-300);color:var(--gray-700);font-size:var(--font-size-body);font-weight:600;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm)}.assessments-data-table tr[style*="background-color: #fef3c7"]{background-color:#fef3c7!important}.assessments-data-table tr[style*="background-color: #fef3c7"]:hover{background-color:#fde68a!important}.assessment-description-section{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.assessment-description-text{word-wrap:break-word;color:var(--gray-700);font-size:var(--font-size-small);line-height:1.6;margin:0;white-space:pre-wrap}.levels-grid-container{min-width:0;overflow-x:visible;width:100%}.assessment-details-expanded .levels-grid{grid-gap:var(--spacing-md)!important;display:grid!important;gap:var(--spacing-md)!important;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))!important;width:100%}tr.detail-row{display:table-row!important}tr.detail-row td{display:table-cell!important;overflow:visible!important;padding:0!important}tr.detail-row .assessment-details-expanded{box-sizing:border-box;display:block!important;max-width:none;width:100%}.master-log-table{overflow-x:auto;width:100%}.assessments-data-table{table-layout:auto}.assessment-details-expanded .level-card.expanded{grid-column:1/-1!important}@media (min-width:769px){.assessment-details-expanded .levels-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))!important}}@media (min-width:1024px){.assessment-details-expanded .levels-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr))!important}}@media (min-width:1400px){.assessment-details-expanded .levels-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr))!important}}.help-panel-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.help-panel{background-color:var(--background-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;height:80vh;max-width:1200px;overflow:hidden;width:90vw}.help-panel-header{align-items:center;background-color:var(--primary-blue);color:var(--text-white);display:flex;justify-content:space-between;padding:var(--spacing-lg)}.help-panel-header h1{font-size:var(--font-size-h1);font-weight:600;margin:0}.help-close-btn{background:none;border:none;border-radius:var(--radius-sm);color:var(--text-white);cursor:pointer;font-size:24px;padding:var(--spacing-sm);transition:background-color .2s}.help-close-btn:hover{background-color:#ffffff1a}.help-panel-body{display:flex;flex:1 1;overflow:hidden}.help-sidebar{background-color:var(--dark-header);display:flex;flex-direction:column;padding:0;width:200px}.help-nav-item{align-items:center;background:none;border:none;border-bottom:1px solid #ffffff1a;color:var(--text-white);cursor:pointer;display:flex;padding:var(--spacing-md);text-align:left;transition:background-color .2s}.help-nav-item:hover{background-color:#ffffff1a}.help-nav-item.active{background-color:var(--primary-blue);border-left:4px solid var(--text-white)}.help-nav-icon{font-size:16px;margin-right:var(--spacing-sm)}.help-nav-label{font-size:var(--font-size-body);font-weight:500}.help-content-area{background-color:var(--background-surface);flex:1 1;overflow-y:auto;padding:var(--spacing-xl)}.help-content{max-width:800px}.help-header{margin-bottom:var(--spacing-lg)}.help-header,.help-icon{align-items:center;display:flex}.help-icon{background-color:var(--primary-blue);border-radius:50%;font-size:32px;height:48px;justify-content:center;margin-right:var(--spacing-md);width:48px}.help-header h2{color:var(--text-primary);font-size:var(--font-size-h1);font-weight:600;margin:0}.help-description{color:var(--text-secondary);font-size:var(--font-size-body);line-height:1.6;margin-bottom:var(--spacing-xl)}.feature-grid{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:1fr 1fr;margin-top:var(--spacing-xl)}.feature-card{background-color:var(--background-white);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--spacing-lg);text-align:center}.feature-icon{align-items:center;background-color:#dbeafe;border-radius:50%;color:var(--primary-blue);display:flex;font-size:40px;height:64px;justify-content:center;margin:0 auto var(--spacing-md);width:64px}.feature-card h3{color:var(--text-primary);font-size:var(--font-size-h3);font-weight:600;margin-bottom:var(--spacing-sm)}.feature-card p{color:var(--text-secondary);font-size:var(--font-size-small);line-height:1.5}.help-content ul{list-style-type:disc;margin-left:var(--spacing-lg);margin-top:var(--spacing-md)}.help-content li{color:var(--text-primary);font-size:var(--font-size-body);line-height:1.5;margin-bottom:var(--spacing-sm)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#00000080}.modal-content{border-radius:20px;box-shadow:0 25px 50px #0000004d;overflow-y:auto;position:relative}.tracker-settings-modal{max-width:90vw;width:600px}.modal-header{background-color:var(--gray-50);border-bottom:1px solid var(--border-light);border-radius:20px 20px 0 0;padding:var(--spacing-md) var(--spacing-lg)}.modal-header h2{color:#2c3e50;font-size:1.25rem;font-weight:600;margin:0}.btn-close{align-items:center;background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.btn-close:hover{background-color:#e9ecef;color:#495057;transform:scale(1.1);transition:all .3s ease-out}.modal-body,.modal-footer{padding:var(--spacing-md) var(--spacing-lg)}.modal-footer{background-color:var(--gray-50);border-radius:0 0 20px 20px;border-top:1px solid var(--border-light);display:flex;gap:var(--spacing-sm);justify-content:flex-end}.settings-section{margin-bottom:var(--spacing-lg)}.settings-section h3:not(.section-title){color:var(--gray-900);font-size:var(--font-size-h3);font-weight:600;margin:0 0 var(--spacing-sm) 0}.settings-section p.text-muted{color:var(--text-secondary);font-size:var(--font-size-small);margin:0 0 var(--spacing-md) 0}.settings-group{background-color:var(--gray-50);border:1px solid var(--border-light);border-radius:var(--radius-sm);margin:var(--spacing-lg) 0;padding:var(--spacing-md)}.settings-group h4{color:#495057;font-size:1rem;font-weight:500;margin:0 0 16px}.form-group{margin-bottom:16px}.form-group:last-child{margin-bottom:0}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:.95rem;margin:0}.checkbox-label input[type=checkbox]{height:16px;margin-right:8px;width:16px}.form-control{border:1px solid #ced4da;border-radius:4px;font-size:.95rem;padding:8px 12px;transition:border-color .15s ease-in-out;width:100%}.form-control:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40;outline:0}.form-text{display:block;font-size:.85rem;margin-top:4px}.text-muted{color:#6c757d!important}.large-modal{max-height:95vh;max-width:95vw;width:1000px}.requirements-header,.tracker-settings-header{align-items:center;background:var(--dark-header);border-bottom:none;color:var(--text-white);display:flex;gap:var(--spacing-md);justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.requirements-header .header-content,.tracker-settings-header .header-content{flex:1 1}.requirements-header h2,.tracker-settings-header h2{color:var(--text-white);font-size:var(--font-size-h2);font-weight:600;margin:0 0 var(--spacing-xs) 0}.requirements-header .header-subtitle,.tracker-settings-header .header-subtitle{color:#ffffffd9;font-size:var(--font-size-small);margin:0}.tracker-settings-header .header-actions{display:flex;flex-shrink:0;gap:var(--spacing-sm)}.tracker-settings-header .btn-close{color:var(--text-white);opacity:.9}.requirements-header .btn-close:hover,.tracker-settings-header .btn-close:hover{background-color:#fff3;opacity:1}.tracker-settings-modal .settings-tabs{align-items:flex-end;background:linear-gradient(180deg,#e5e7eb 0,#fff 50%);border:none;border-radius:8px 8px 0 0;display:flex;gap:4px;margin-bottom:0;overflow:visible;padding:4px 8px 0}.tracker-settings-modal .settings-tab{align-items:center;background:linear-gradient(180deg,#e5e7eb 0,#d1d5db);border:1px solid #cbd5e0;border-bottom:none;border-radius:8px 8px 0 0;box-shadow:inset 0 -2px 3px #0000000d;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;font-size:var(--font-size-small);font-weight:500;gap:var(--spacing-xs);justify-content:center;margin-bottom:-2px;min-width:80px;overflow:visible;padding:8px 16px 10px;position:relative;text-align:center;transition:all .15s ease;white-space:nowrap}.tracker-settings-modal .settings-tab svg{flex-shrink:0;height:16px;width:16px}.tracker-settings-modal .settings-tab:hover:not(.active){background:linear-gradient(180deg,#f3f4f6 0,#e5e7eb);border-color:#9ca3af;box-shadow:0 -1px 3px #0000001a,inset 0 -2px 3px #0000000d;color:var(--text-primary)}.tracker-settings-modal .settings-tab.active{background:#fff;border-color:var(--gray-300);border-bottom:none;box-shadow:none;color:var(--text-primary);font-weight:600;margin-bottom:-2px;padding:10px 16px 12px;z-index:2}.btn-primary,.btn-secondary{border:1px solid;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-body);font-weight:500;padding:var(--spacing-sm) var(--spacing-lg);transition:all .2s ease;white-space:nowrap}.btn-primary{background:var(--primary-blue);color:var(--text-white)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-secondary{background:var(--gray-100);border-color:var(--border-color);color:var(--gray-700)}.btn-secondary:hover:not(:disabled){background:var(--gray-200);border-color:var(--gray-400)}.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.5;transform:none}.section-title{align-items:center;color:var(--gray-900);display:flex;font-size:var(--font-size-h3);font-weight:600;gap:var(--spacing-sm);margin:0 0 var(--spacing-sm) 0}.section-title svg{color:var(--primary-blue);flex-shrink:0}.section-description{color:var(--text-secondary);font-size:var(--font-size-small);margin:0 0 var(--spacing-md) 0}.parent-tracker-section{background-color:var(--gray-50);border:2px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--spacing-xl);overflow:visible;padding:var(--spacing-md)}.tracker-settings-modal .settings-section.parent-tracker-section:last-child{border-bottom:2px solid var(--border-color)}.tracker-settings-modal .settings-section.parent-tracker-section.has-parent:last-child,.tracker-settings-modal .settings-section.parent-tracker-section.is-parent:last-child{border-bottom:2px solid #ff9800}.parent-tracker-section.has-parent,.parent-tracker-section.is-parent{background-color:#fff3e0;border-color:#ff9800}.assessment-table{border:1px solid #dee2e6;border-radius:6px;margin:16px 0;overflow:hidden}.table-header{background-color:var(--dark-header);color:var(--text-white);display:grid;font-weight:600;grid-template-columns:2fr 2fr 1fr}.table-header>div{border-right:1px solid #6c757d;padding:12px 16px}.table-header>div:last-child{border-right:none}.col-progress{flex-direction:column;text-align:center}.col-progress>div{padding:4px 0}.bulk-actions{display:flex;gap:4px;justify-content:center;margin:2px 0}.bulk-actions .btn{border-radius:4px;font-size:11px;margin:0;min-width:auto;padding:2px 8px}.bulk-actions .btn.btn-primary{background:#4f46e5;background:var(--primary-blue,#4f46e5);border-color:#4f46e5;border-color:var(--primary-blue,#4f46e5);color:#fff}.bulk-actions .btn.btn-primary:hover{background:#4338ca;background:var(--primary-hover,#4338ca);border-color:#4338ca;border-color:var(--primary-hover,#4338ca);box-shadow:none;transform:none}.bulk-actions .btn.btn-outline{background:#0000;border:1px solid #9ca3af;border:1px solid var(--gray-400,#9ca3af);color:#4b5563;color:var(--gray-600,#4b5563)}.bulk-actions .btn.btn-outline:hover{background:#f3f4f6;background:var(--gray-100,#f3f4f6);border-color:#6b7280;border-color:var(--gray-500,#6b7280)}.table-header .bulk-actions .btn.btn-outline{background:#ffffff26;border:1px solid #fff6;color:#fff;color:var(--text-white,#fff)}.table-header .bulk-actions .btn.btn-outline:hover{background:#ffffff40;border-color:#fff9}.bulk-actions .btn.btn-warning{background:#f59e0b;background:var(--warning-amber,#f59e0b);border-color:#f59e0b;border-color:var(--warning-amber,#f59e0b);color:#fff}.bulk-actions .btn.btn-warning:hover{background:#d97706;background:var(--warning-hover,#d97706);border-color:#d97706;border-color:var(--warning-hover,#d97706)}.btn-xs{font-size:.75rem;padding:2px 6px}.btn-outline{background:#0000;border:1px solid #6c757d;color:#6c757d}.btn-warning{background:#f59e0b;border:1px solid #d97706;color:#fff}.btn-warning:hover:not(:disabled){background:#d97706;border-color:#b45309}.assessment-row{align-items:center;border-bottom:1px solid #dee2e6;display:grid;grid-template-columns:2fr 2fr 1fr}.assessment-row:hover{background-color:#f8f9fa}.assessment-row>div{border-right:1px solid #dee2e6;padding:12px 16px}.assessment-row>div:last-child{border-right:none;text-align:center}.col-assessment{font-weight:500}.col-progress{align-items:center;display:flex;gap:12px;justify-content:space-between}.progress-checkbox{display:flex;justify-content:center}.weight-input{align-items:center;display:flex;flex:1 1;gap:8px}.weight-input input{border:1px solid #ced4da;border-radius:4px;padding:4px 8px;text-align:center;width:80px}.lock-btn{align-items:center;background:none;border:none;border-radius:3px;cursor:pointer;display:flex;font-size:16px;height:24px;justify-content:center;padding:2px;width:24px}.lock-btn:hover{background-color:#e9ecef}.lock-btn.locked{color:#dc3545}.lock-btn.unlocked{color:#28a745}.weight-summary{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;display:flex;justify-content:space-between;margin:16px 0;padding:16px}.total-weight{font-size:1.1rem;font-weight:600}.weight-valid{color:#28a745;margin-left:8px}.weight-invalid{color:#ffc107;margin-left:8px}.preset-section{margin:16px 0}.preset-select{max-width:200px}.thresholds-table{border:1px solid #dee2e6;border-radius:6px;margin:16px 0;overflow:hidden}.threshold-row,.thresholds-table .table-header{grid-template-columns:2fr 1fr 1fr 3fr}.threshold-row{align-items:center;border-bottom:1px solid #dee2e6;display:grid}.threshold-row:hover{background-color:#f8f9fa}.threshold-row>div{border-right:1px solid #dee2e6;padding:8px 12px}.threshold-row>div:last-child{border-right:none}.threshold-row input{border:1px solid #ced4da;border-radius:4px;padding:4px 8px;width:100%}.col-action{display:flex;gap:8px;justify-content:center}.btn-sm{font-size:.875rem;padding:4px 8px}.requirements-modal{max-width:90vw;width:700px}.requirements-list{margin:16px 0}.requirement-row{align-items:center;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:12px 0}.requirement-row:last-child{border-bottom:none}.assessment-name{flex:1 1;font-weight:500}.requirement-controls{align-items:center;display:flex;flex:1 1;gap:12px;justify-content:flex-end}.requirement-controls select{min-width:150px}.custom-presets-menu-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1100}.custom-presets-menu{background:#fff;border:2px solid #1f2937;border:2px solid var(--gray-800,#1f2937);border-radius:8px;box-shadow:0 8px 24px #0003;display:flex;flex-direction:column;max-height:80vh;max-width:95vw;overflow:hidden;width:600px}.presets-menu-header{align-items:center;background:#1f2937;background:var(--gray-800,#1f2937);color:#fff;display:flex;justify-content:space-between;padding:12px 16px}.presets-menu-header h3{color:#fff;font-size:16px;font-weight:600;margin:0}.presets-menu-body{flex:1 1;overflow-y:auto;padding:16px}.presets-menu-footer{background:#f9fafb;background:var(--gray-50,#f9fafb);border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200,#e5e7eb);display:flex;gap:8px;justify-content:flex-end;padding:12px 16px}.btn-sm{font-size:12px!important;padding:4px 8px!important}.btn-outline-action.btn-sm{font-size:11px;padding:3px 8px}.confirm-dialog-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.confirm-dialog-content{background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #0000004d;max-width:520px;padding:24px;width:90%}.confirm-dialog-title{color:#333;font-size:20px;font-weight:600;margin:0 0 16px}.confirm-dialog-message{color:#666;font-size:14px;line-height:1.6;margin:0 0 24px;white-space:pre-line}.confirm-dialog-options{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.confirm-dialog-option{border:1px solid #ddd;border:1px solid var(--border-light,#ddd);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;padding:14px 16px;text-align:left;transition:all .2s ease;width:100%}.confirm-dialog-option:hover{box-shadow:0 2px 8px #0000001f;transform:translateY(-1px)}.confirm-dialog-option.primary{background:#4caf50;border-color:#43a047;color:#fff}.confirm-dialog-option.primary:hover{background:#43a047;border-color:#388e3c}.confirm-dialog-option.secondary{background:#f5f5f5;border-color:#ddd;color:#333}.confirm-dialog-option.secondary:hover{background:#eee;border-color:#ccc}.confirm-dialog-option.danger{background:#f44336;border-color:#d32f2f;color:#fff}.confirm-dialog-option.danger:hover{background:#d32f2f;border-color:#c62828}.confirm-dialog-option-label{font-size:14px;font-weight:600;margin-bottom:6px}.confirm-dialog-option-description{font-size:12px;font-weight:400;line-height:1.5;opacity:.9}.confirm-dialog-cancel{background-color:initial;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s ease;width:100%}.confirm-dialog-cancel:hover{background-color:#f9f9f9;border-color:#999;color:#333}.parent-tab-badge{align-items:center;background:#ff9800;border-radius:50%;box-shadow:0 1px 3px #0003;color:#fff;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;left:-4px;position:absolute;top:-4px;width:16px;z-index:10}.export-import-modal{max-width:520px;width:95%}.export-import-modal .modal-subtitle{color:var(--text-primary);font-size:15px;font-weight:600;margin:0 0 4px}.export-import-modal .modal-info{color:var(--text-secondary);font-size:13px;margin:0 0 16px}.export-import-options{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.export-import-option{align-items:flex-start;background:var(--background-white);border:2px solid var(--gray-300);border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:14px;transition:all .15s ease}.export-import-option:hover{background:var(--gray-50);border-color:var(--primary-blue)}.export-import-option.selected{background:#2196f314;border-color:var(--primary-blue)}.export-import-option input[type=radio]{flex-shrink:0;margin-top:3px}.export-import-option .option-content{flex:1 1;min-width:0}.export-import-option .option-content strong{color:var(--text-primary);display:block;font-size:14px;font-weight:600;margin-bottom:4px}.export-import-option .option-content p{color:var(--text-secondary);font-size:13px;line-height:1.4;margin:0 0 8px}.export-import-option .option-preview{background:var(--gray-100);border-radius:4px;padding:8px 10px}.export-import-option .option-preview code{color:var(--text-tertiary);display:block;font-family:monospace;font-size:11px;margin:2px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-input-section{margin:16px 0}.file-input-section input[type=file]{display:none}.file-input-label{border:2px dashed var(--gray-400);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:block;font-size:14px;padding:16px 20px;text-align:center;transition:all .15s ease}.file-input-label:hover{background:var(--gray-50);border-color:var(--primary-blue);color:var(--primary-blue)}.import-preview{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;margin-top:16px;padding:14px}.import-preview h4{color:var(--text-primary);font-size:14px;font-weight:600;margin:0 0 10px}.import-preview ul{list-style-type:disc;margin:0;padding-left:20px}.import-preview li{color:var(--text-secondary);font-size:13px;margin:6px 0}.import-preview li strong{color:var(--text-primary)}.export-additional-options{border-top:1px solid var(--gray-200);display:flex;flex-direction:column;gap:12px;margin-top:16px;padding-top:16px}.export-checkbox-option{align-items:flex-start;border-radius:6px;cursor:pointer;display:flex;gap:12px;padding:10px;transition:background .15s ease}.export-checkbox-option:hover{background:var(--gray-50)}.export-checkbox-option input[type=checkbox]{accent-color:var(--primary-blue);flex-shrink:0;height:18px;margin-top:2px;width:18px}.export-checkbox-option .checkbox-label{flex:1 1}.export-checkbox-option .checkbox-label strong{color:var(--text-primary);display:block;font-size:14px;margin-bottom:2px}.export-checkbox-option .checkbox-label p{color:var(--text-secondary);font-size:12px;line-height:1.4;margin:0}.import-confirm-section{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;margin-top:16px;padding:16px}.import-confirm-section h4{color:var(--text-primary);font-size:15px;font-weight:600;margin:0 0 12px}.import-confirm-section .preview-section{margin-bottom:12px}.import-confirm-section .preview-section:last-child{margin-bottom:0}.import-confirm-section .preview-section strong{color:var(--text-primary);display:block;font-size:13px;font-weight:600;margin-bottom:6px}.import-confirm-section .preview-section ul{list-style-type:disc;margin:0;padding-left:20px}.import-confirm-section .preview-section li{color:var(--text-secondary);font-size:13px;margin:4px 0}.import-confirm-section .preview-section.preview-new li,.import-confirm-section .preview-section.preview-new strong{color:var(--primary-green)}.import-confirm-section .preview-badge{background:var(--primary-green);border-radius:4px;color:#fff;display:inline-block;font-size:12px;font-weight:500;padding:6px 12px}.import-conflict-section{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;margin-top:16px;padding:16px}.conflict-warning{color:#92400e;font-size:14px;font-weight:600;margin-bottom:12px}.conflict-input-label{color:var(--text-secondary);display:block;font-size:13px;margin-bottom:8px}.conflict-input{border:1px solid var(--gray-300);border-radius:6px;box-sizing:border-box;font-size:14px;margin-top:4px;padding:10px 12px;width:100%}.conflict-input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #4f46e51a;outline:none}.conflict-rename-row{align-items:center;display:flex;gap:12px;margin-bottom:10px}.conflict-rename-row:last-child{margin-bottom:0}.conflict-old-name{color:var(--text-primary);flex-shrink:0;font-weight:500;min-width:120px}.conflict-arrow{color:var(--gray-400);flex-shrink:0}.conflict-rename-row .conflict-input{flex:1 1;margin-top:0}.btn-modal-confirm{align-items:center;background:#1f2937;background:var(--gray-800,#1f2937);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.btn-modal-confirm:hover:not(:disabled){background:#374151;background:var(--gray-700,#374151);box-shadow:0 4px 8px #1f29374d;transform:translateY(-1px)}.btn-modal-confirm:active:not(:disabled){box-shadow:0 2px 4px #1f29374d;transform:translateY(0)}.btn-modal-confirm:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.btn-modal-cancel{align-items:center;border:1px solid #d1d5db;border:1px solid var(--gray-300,#d1d5db);border-radius:6px;color:#374151;color:var(--gray-700,#374151);display:inline-flex;font-weight:500;gap:8px;white-space:nowrap}.btn-modal-cancel:hover{background:#f9fafb;background:var(--gray-50,#f9fafb);border-color:#9ca3af;border-color:var(--gray-400,#9ca3af)}.btn-modal-cancel:active{background:#f3f4f6;background:var(--gray-100,#f3f4f6)}.export-modal-compact{max-width:95vw;width:480px}.modal-header-colored{align-items:center;background:#1f2937;background:var(--gray-800,#1f2937);border-radius:20px 20px 0 0;color:#fff;display:flex;justify-content:space-between;padding:12px 16px}.modal-header-colored h2{color:#fff;font-size:16px;font-weight:600;margin:0}.btn-close-light{align-items:center;background:none;border:none;border-radius:4px;color:#ffffffb3;cursor:pointer;display:flex;font-size:20px;height:28px;justify-content:center;padding:0;transition:all .2s ease;width:28px}.btn-close-light:hover{background:#ffffff1a;color:#fff}.modal-body-compact{padding:16px}.modal-footer-compact{background:#f9fafb;background:var(--gray-50,#f9fafb);border-radius:0 0 20px 20px;border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200,#e5e7eb);display:flex;gap:8px;justify-content:flex-end;padding:12px 16px}.export-format-options{display:flex;gap:8px;margin-bottom:12px}.export-format-option{align-items:center;background:#fff;border:2px solid #e5e7eb;border:2px solid var(--gray-200,#e5e7eb);border-radius:8px;cursor:pointer;display:flex;flex:1 1;gap:8px;padding:10px 12px;transition:all .15s ease}.export-format-option:hover{border-color:#d1d5db;border-color:var(--gray-300,#d1d5db)}.export-format-option.selected{background:#4f46e50a;border-color:#4f46e5;border-color:var(--primary-blue,#4f46e5)}.export-format-option input[type=radio]{accent-color:#4f46e5;accent-color:var(--primary-blue,#4f46e5);margin:0}.format-option-content{display:flex;flex-direction:column;gap:1px}.format-option-content strong{color:#111827;color:var(--text-primary,#111827);font-size:13px;font-weight:600}.format-desc{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:11px}.export-preview-table{background:#f9fafb;background:var(--gray-50,#f9fafb);border:1px solid #e5e7eb;border:1px solid var(--gray-200,#e5e7eb);border-radius:8px;margin-bottom:12px;overflow-x:auto;padding:8px}.export-preview-table table{border-collapse:collapse;font-size:10px;width:100%}.export-preview-table th{background:#374151;background:var(--gray-700,#374151);border:1px solid #4b5563;border:1px solid var(--gray-600,#4b5563);color:#fff;font-weight:500;padding:4px 6px;text-align:center}.export-preview-table th.assessment-group{background:#4f46e5;background:var(--primary-blue,#4f46e5);border-color:#4338ca}.export-preview-table th.threshold{background:#4b5563;background:var(--gray-600,#4b5563);font-size:9px;padding:3px 4px}.export-preview-table td{background:#fff;border:1px solid #e5e7eb;border:1px solid var(--gray-200,#e5e7eb);padding:4px 6px;text-align:center}.export-preview-table td:first-child{font-weight:500;text-align:left}.export-preview-table td.tick{color:#059669;color:var(--success-green,#059669);font-weight:600}.export-preview-table tbody tr:nth-child(2n) td{background:#f9fafb;background:var(--gray-50,#f9fafb)}.export-options-compact{display:flex;flex-direction:column;gap:6px}.export-option-inline{align-items:center;color:#6b7280;color:var(--text-secondary,#6b7280);cursor:pointer;display:flex;font-size:12px;gap:8px}.export-option-inline input[type=checkbox]{accent-color:#4f46e5;accent-color:var(--primary-blue,#4f46e5);margin:0}.export-option-inline:hover span{color:#111827;color:var(--text-primary,#111827)}.export-preview-empty{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:12px;font-style:italic;padding:20px;text-align:center}.save-status-indicator{align-items:center;border-radius:6px;display:flex;font-size:.875rem;font-weight:500;gap:8px;padding:6px 12px;transition:all .3s ease}.save-status-indicator .cloud-icon{height:20px;transition:transform .3s ease;width:20px}.save-status-indicator .status-text{font-size:.875rem;line-height:1}.save-status-indicator.saved{background-color:#10b9811a;color:#10b981}.save-status-indicator.saved:hover{background-color:#10b98126}.save-status-indicator.saving{background-color:#3b82f61a;color:#3b82f6}.save-status-indicator.saving:hover{background-color:#3b82f626}.save-status-indicator.saving .cloud-icon.spinning{animation:pulse 1.5s ease-in-out infinite}.save-status-indicator.unsaved{background-color:#f59e0b1a;color:#f59e0b}.save-status-indicator.unsaved:hover{background-color:#f59e0b26}.save-status-indicator.unsaved .cloud-icon{animation:bounce-subtle 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}@keyframes bounce-subtle{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@media (max-width:768px){.save-status-indicator .status-text{display:none}.save-status-indicator{padding:6px}}.student-sort-controls{align-items:center;background:#f9f9f9;border-bottom:1px solid var(--border-light);box-sizing:border-box;display:flex;flex-wrap:nowrap;gap:6px;height:42px;padding:4px 12px}.sort-label{color:#555;flex-shrink:0;font-size:13px;font-weight:500;white-space:nowrap}.universal-direction-toggle{align-items:center;background:#fff;border:1px solid #ddd;border-radius:4px;color:#666;cursor:pointer;display:flex;flex-direction:row;flex-shrink:0;gap:3px;height:28px;justify-content:center;line-height:1;padding:3px 6px;transition:all .2s ease}.universal-direction-toggle:hover:not(:disabled){background:#2196f3;border-color:#2196f3;color:#fff}.universal-direction-toggle:disabled{cursor:not-allowed;opacity:.3}.toggle-arrow{flex-shrink:0;font-size:14px;font-weight:700;line-height:1}.toggle-stack{align-items:center;display:flex;flex-direction:column;gap:0;justify-content:center;line-height:1}.toggle-bottom,.toggle-top{font-size:9px;font-weight:700;letter-spacing:-.5px;line-height:1}.sort-dropdown-container{align-items:center;display:flex;flex:1 1;gap:6px;min-width:0}.sort-select{-webkit-appearance:none;appearance:none;background:#fff;background-image:url('data:image/svg+xml;utf8,<svg fill="%23333" height="20" viewBox="0 0 24 24" width="20" xmlns="http://www.w3.org/2000/svg"><path d="M7 10l5 5 5-5z"/></svg>');background-position:right 6px center;background-repeat:no-repeat;background-size:16px;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:13px;min-width:0;overflow:hidden;padding:6px 28px 6px 10px;text-overflow:ellipsis;transition:all .2s ease;white-space:nowrap;width:100%}.sort-select:focus,.sort-select:hover{border-color:#2196f3}.sort-select:focus{box-shadow:0 0 0 2px #2196f31a;outline:none}.direction-button,.sort-direction-toggle{display:none}.manual-reorder-button{align-items:center;background:#fff;border:1px solid #2196f3;border-radius:4px;color:#2196f3;cursor:pointer;display:flex;flex-shrink:0;font-size:12px;font-weight:500;gap:4px;margin-left:auto;padding:6px 10px;transition:all .2s ease;white-space:nowrap}.manual-reorder-button:hover{background:#2196f3;color:#fff}.reorder-icon{font-size:16px;font-weight:700}@media (max-width:1024px){.sort-select{font-size:12px}.sort-label{font-size:11px}.universal-direction-toggle{gap:2px;height:26px;padding:3px 5px}.toggle-bottom,.toggle-top{font-size:8px}.toggle-arrow{font-size:13px}.manual-reorder-button{font-size:11px;gap:3px;padding:6px 8px}}@media (max-width:768px){.student-sort-controls{gap:4px;padding:4px 8px}.sort-select{font-size:11px;padding:4px 24px 4px 8px}.sort-label{display:none}.universal-direction-toggle{gap:2px;height:24px;padding:2px 4px}.toggle-bottom,.toggle-top{font-size:7px}.toggle-arrow{font-size:12px}.manual-reorder-button span:not(.reorder-icon){display:none}}.student-reorder-modal{display:flex;flex-direction:column;max-height:85vh;max-width:900px;width:90vw}.student-reorder-modal .modal-header{align-items:center;border-bottom:2px solid #eee;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;padding:20px}.header-left-section{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.header-left-section h2{color:#333;font-size:18px;margin:0}.header-hint{color:#999;font-size:13px}.header-preset-select{align-items:center;display:flex;gap:6px}.header-preset-select label{color:#666;font-size:13px;margin:0}.header-right-section{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.student-reorder-modal .modal-body{display:flex;flex:1 1;flex-direction:column;overflow:hidden;padding:20px}.reorder-container{display:flex;flex:1 1;gap:20px;min-height:0;overflow:hidden}.current-order-column{display:flex;flex:1 1;flex-direction:column;min-height:0}.two-column-layout{display:flex;flex:1 1;gap:12px;min-height:0}.reorder-container .student-list{background:#fafafa;border:2px dashed #ddd;border-radius:8px;display:flex;flex:1 1;flex-direction:column;gap:6px;min-height:0;overflow-y:auto;padding:8px;transition:all .2s ease}.reorder-container .student-list.dragging-over{background:#e3f2fd;border-color:#2196f3}.student-item{align-items:center;background:#fff;border:1.5px solid #ddd;border-radius:16px;cursor:grab!important;display:inline-flex;font-size:12px;gap:4px;height:26px;max-width:180px;min-width:0;padding:4px 10px;transition:all .15s ease;-webkit-user-select:none;user-select:none;white-space:nowrap}.left-list .student-item{background:#ff980014}.right-list .student-item{background:#3f51b514}.student-item *{cursor:grab!important}.student-item:hover{background:#f0f7ff;border-color:#2196f3;box-shadow:0 2px 4px #2196f333;transform:translateY(-1px)}.student-item.dragging{box-shadow:0 4px 12px #0000004d;opacity:.6;transform:rotate(2deg)}.student-item.dragging,.student-item.dragging *{cursor:grabbing!important}.student-item .drag-handle{color:#999;cursor:grab!important;flex-shrink:0;font-size:12px;line-height:1}.student-item .student-number{color:#666;cursor:grab!important;flex-shrink:0;font-size:11px;font-weight:600;min-width:auto}.student-item .student-name{color:#333;cursor:grab!important;font-size:12px;font-weight:500;overflow:hidden;pointer-events:none;text-overflow:ellipsis}.paste-column-toggle{align-items:center;background:#fafafa;border:2px dashed #ddd;border-radius:8px;display:flex;flex:1 1;flex-direction:column;justify-content:flex-start;min-height:0;overflow-y:auto;padding:80px 40px 40px}.show-paste-button{background:#2196f3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;padding:12px 24px;transition:background .2s ease}.show-paste-button:hover{background:#1976d2}.paste-hint{color:#666;font-size:14px;margin-top:15px;text-align:center}.paste-column{display:flex;flex:1 1;flex-direction:column;gap:15px;min-height:0;overflow-y:auto;padding-right:5px}.paste-header{align-items:center;display:flex;justify-content:space-between}.paste-header h3{color:#333;font-size:18px;margin:0}.close-paste-button{background:none;border:none;color:#999;cursor:pointer;font-size:28px;height:30px;line-height:1;padding:0;transition:color .2s ease;width:30px}.close-paste-button:hover{color:#333}.paste-textarea{border:2px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;min-height:300px;padding:12px;resize:vertical;width:100%}.paste-textarea:focus{border-color:#2196f3;outline:none}.analyze-button{background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:15px;padding:10px 20px;transition:background .2s ease}.analyze-button:hover:not(:disabled){background:#45a049}.analyze-button:disabled{background:#ccc;cursor:not-allowed}.match-results{background:#f9f9f9;border:1px solid #ddd;border-radius:6px;padding:15px}.match-results h4{color:#333;font-size:16px;margin:0 0 15px}.match-list{margin-bottom:15px;max-height:300px;overflow-y:auto}.match-item{align-items:center;background:#fff;border-left:3px solid #0000;border-radius:4px;display:flex;gap:10px;margin-bottom:6px;padding:8px 12px}.match-item.match-type-exact{border-left-color:#4caf50}.match-item.match-type-case-insensitive{border-left-color:#2196f3}.match-item.match-type-fuzzy{border-left-color:#ff9800}.match-item.match-type-none{border-left-color:#f44336}.pasted-name{color:#333;font-weight:500;min-width:120px}.matched-name{color:#666;font-size:14px}.no-match{color:#f44336;font-size:14px;font-style:italic}.match-indicator{align-items:center;border-radius:50%;display:inline-flex;font-size:12px;font-weight:700;height:24px;justify-content:center;width:24px}.match-indicator.exact{background:#4caf50;color:#fff}.match-indicator.case-insensitive{background:#2196f3;color:#fff;font-size:10px}.match-indicator.fuzzy{background:#ff9800;color:#fff}.match-indicator.none{background:#f44336;color:#fff}.apply-paste-button{background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:15px;font-weight:500;padding:12px;transition:background .2s ease;width:100%}.apply-paste-button:hover{background:#45a049}.match-status{border-radius:6px;font-size:14px;padding:12px;text-align:center}.match-status.warning{background:#fff3cd;border:1px solid #ffeaa7;color:#856404}.preset-select{background:#fff;border:1.5px solid #ddd;border-radius:4px;cursor:pointer;font-size:13px;min-width:150px;padding:6px 10px;transition:border-color .2s ease}.preset-select:focus{border-color:#2196f3;outline:none}.preset-select:hover{border-color:#999}.confirmations-section{background:#fff;border:1px solid #ddd;border-radius:6px;margin-top:20px;padding:15px}.confirmations-header{align-items:center;display:flex;gap:15px;justify-content:space-between;margin-bottom:15px}.confirmations-header h4{color:#333;font-size:16px;margin:0}.approve-all-button{background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:background .2s ease;white-space:nowrap}.approve-all-button:hover{background:#45a049}.confirmations-section h4{color:#333;font-size:16px;margin:0 0 15px}.confirmation-item{border-bottom:1px solid #eee;margin-bottom:20px;padding-bottom:20px}.confirmation-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.confirmation-question{color:#333;font-size:14px;margin-bottom:10px}.confirmation-options{display:flex;flex-wrap:wrap;gap:8px}.confirm-option{background:#f5f5f5;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.confirm-option:hover{background:#e0e0e0;border-color:#999}.confirm-option.suggested{background:#e3f2fd;border-color:#2196f3;color:#1976d2;font-weight:500}.confirm-option.suggested:hover{background:#bbdefb}.confirm-option.skip{background:#fff3cd;border-color:#ffc107;color:#856404}.confirm-option.skip:hover{background:#ffeaa7;border-color:#ff9800}.save-preset-button{background:#fff;border:2px solid #2196f3;border-radius:6px;color:#2196f3;cursor:pointer;font-size:14px;padding:10px 20px;transition:all .2s ease}.save-preset-button:hover{background:#2196f3;color:#fff}.preset-input-group{align-items:center;display:flex;gap:8px}.preset-name-input{border:2px solid #ddd;border-radius:6px;font-size:14px;padding:8px 12px;width:200px}.preset-name-input:focus{border-color:#2196f3;outline:none}.save-preset-confirm{background:#4caf50;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background .2s ease}.save-preset-confirm:hover{background:#45a049}.save-and-apply-preset{background:#2196f3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background .2s ease}.save-and-apply-preset:hover{background:#1976d2}.save-preset-cancel{background:#f5f5f5;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.save-preset-cancel:hover{background:#e0e0e0}.cancel-button{background:#f5f5f5;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:15px;padding:10px 24px;transition:all .2s ease}.cancel-button:hover{background:#e0e0e0}.apply-button{background:#2196f3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:15px;font-weight:500;padding:10px 24px;transition:background .2s ease}.apply-button:hover{background:#1976d2}.manage-presets-button{background:#fff;border:2px solid #ff9800;border-radius:6px;color:#ff9800;cursor:pointer;font-size:14px;padding:10px 20px;transition:all .2s ease}.manage-presets-button:hover{background:#ff9800;color:#fff}@media (max-width:768px){.reorder-container{flex-direction:column}.student-reorder-modal{max-height:90vh;width:95vw}.modal-footer{flex-direction:column;gap:15px}.footer-left,.footer-right{justify-content:center;width:100%}.preset-name-input{width:150px}.modal-content.delete-presets-modal{max-width:95vw;width:95vw}}.modal-content.delete-presets-modal{max-width:360px;width:90vw}.delete-presets-modal .modal-header{align-items:center;background-color:#1f2937;border-bottom:1px solid #1f2937;display:flex;justify-content:space-between;padding:14px 18px}.delete-presets-modal .modal-header h2{color:#fff;font-size:15px;font-weight:600;margin:0}.delete-presets-modal .close-button{background:none;border:none;color:#ffffffb3;cursor:pointer;font-size:24px;height:24px;line-height:1;padding:0;transition:color .2s ease;width:24px}.delete-presets-modal .close-button:hover{color:#fff}.delete-presets-modal .modal-body{padding:14px 18px}.delete-presets-modal .delete-hint{color:#666;font-size:12px;margin:0 0 10px}.delete-presets-modal .presets-list{background:#fafafa;border:1px solid #e0e0e0;border-radius:4px;max-height:240px;overflow-y:auto;padding:4px}.delete-presets-modal .preset-item{background:#fff;border:1px solid #e0e0e0;border-radius:3px;margin-bottom:3px;padding:6px 8px;transition:all .15s ease}.delete-presets-modal .preset-item:hover{background:#f5f5f5;border-color:#ccc}.delete-presets-modal .preset-item:last-child{margin-bottom:0}.delete-presets-modal .preset-checkbox-label{align-items:center;cursor:pointer;display:flex;gap:7px;-webkit-user-select:none;user-select:none}.delete-presets-modal .preset-checkbox-label input[type=checkbox]{cursor:pointer;flex-shrink:0;height:15px;width:15px}.delete-presets-modal .preset-name-text{color:#333;flex:1 1;font-size:12px;font-weight:500}.delete-presets-modal .preset-count{color:#999;font-size:11px}.delete-presets-modal .no-presets{color:#999;font-size:12px;font-style:italic;padding:24px 16px;text-align:center}.delete-presets-modal .modal-footer{align-items:center;background-color:#f8f9fa;border-top:1px solid #e9ecef;display:flex;gap:10px;justify-content:space-between;padding:10px 14px}.delete-presets-modal .footer-left,.delete-presets-modal .footer-right{align-items:center;display:flex;gap:7px}.delete-presets-modal .selection-count{color:#666;font-size:11px;font-weight:600}.delete-presets-modal .cancel-button{background:#fff;border:1px solid #ddd;border-radius:4px;color:#666;font-size:12px;font-weight:500;padding:6px 14px}.delete-presets-modal .delete-button{background:#f44336;border:none;border-radius:4px;color:#fff;font-size:12px;font-weight:500;padding:6px 14px}.assessment-menu-container,.student-menu-container{flex:none;min-width:0!important;position:relative;width:auto!important}.student-name-header .student-menu-container{min-width:0!important;width:auto!important}.assessment-menu-button{align-items:center;background:#fff;border:1px solid var(--gray-400);border-radius:4px;color:var(--gray-700);cursor:pointer;display:flex;font-size:18px;font-weight:700;height:28px;justify-content:center;line-height:1;min-width:32px;padding:4px 8px;transition:all .15s ease}.assessment-menu-button:hover{background:var(--gray-700);border-color:var(--gray-700);color:#fff}.assessment-dropdown-menu{background:#fff;border:1px solid var(--gray-300);border-radius:6px;box-shadow:0 4px 12px #00000026;margin-top:4px;min-width:200px;overflow:visible;position:absolute;right:0;top:100%;z-index:10000}.student-menu-container .assessment-dropdown-menu{left:0;right:auto}.menu-item{align-items:center;background:#fff;border:none;border-bottom:1px solid var(--gray-100);color:var(--gray-900);cursor:pointer;display:flex;font-size:14px;gap:0;justify-content:flex-start;padding:10px 16px;text-align:left;transition:all .15s ease;width:100%}.menu-item:last-child{border-bottom:none}.menu-item:hover{background:var(--gray-50);color:var(--primary-blue)}.menu-item-danger{color:var(--danger-red)}.menu-item-danger:hover{background:#fee2e2;color:var(--danger-hover)}.menu-item-icon{align-items:center;display:inline-flex;flex-shrink:0;font-size:14px;justify-content:flex-start;margin-right:8px;width:auto}.menu-item-icon svg{display:block;height:14px;width:14px}.submenu-trigger{cursor:pointer;padding-right:8px;position:relative}.submenu{background:#fff;border:1px solid var(--gray-300);border-radius:6px;box-shadow:0 4px 12px #00000026;left:100%;margin-left:2px;min-width:220px;overflow:visible;position:absolute;top:0;z-index:10001}.submenu-item{background:#fff;border:none;border-bottom:1px solid var(--gray-100);color:var(--gray-900);cursor:pointer;display:block;font-size:14px;padding:10px 16px;text-align:left;transition:all .15s ease;white-space:nowrap;width:100%}.submenu-item:last-child{border-bottom:none}.submenu-item:hover{background:var(--gray-50);color:var(--primary-blue)}.context-menu{background:#fff;border:1px solid var(--gray-300);border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:180px;overflow:hidden;padding:4px 0}.context-menu-item{align-items:center;background:#fff;border:none;border-bottom:1px solid var(--gray-100);color:var(--gray-900);cursor:pointer;display:flex;font-size:14px;padding:10px 16px;text-align:left;transition:all .15s ease;width:100%}.context-menu-item:last-child{border-bottom:none}.context-menu-item:hover{background:var(--gray-50);color:var(--primary-blue)}.assessment-card,.assessment-header{overflow:visible!important}.tracker-content{overflow-x:auto;overflow-y:visible}.assessment-grid{overflow:visible!important}.selection-panel{background-color:var(--background-white);border:1px solid var(--border-light);border-radius:16px;box-shadow:0 10px 20px #0f172a14;margin-bottom:var(--spacing-lg);overflow:hidden}.selection-header{background-color:var(--dark-header);border-bottom:1px solid var(--border-light);color:var(--text-white);padding:var(--spacing-md)}.selection-header h3{font-size:var(--font-size-body);font-weight:600;margin:0 0 var(--spacing-xs) 0}.selection-header p{font-size:var(--font-size-small);margin:0;opacity:.9}.selection-content{padding:var(--spacing-lg)}.selection-group{gap:var(--spacing-lg)}.selection-group,.selection-item{display:flex;flex-direction:column}.selection-item{gap:var(--spacing-sm)}.selection-item label{color:var(--text-primary);font-size:var(--font-size-small);font-weight:600;margin:0}.selection-controls{align-items:center;gap:var(--spacing-sm)}.selection-dropdown{background-color:var(--background-white);border:1px solid var(--border-light);border-radius:var(--radius-sm);box-sizing:border-box;color:var(--text-primary);flex:1 1;font-size:var(--font-size-small);min-height:36px;padding:var(--spacing-sm) var(--spacing-md)}.selection-dropdown:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #3b82f61a;outline:none}.selection-actions{align-items:center;display:flex;gap:var(--spacing-xs)}.btn-icon{background-color:var(--background-white);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-small);height:32px;width:32px}.btn-icon:hover:not(:disabled){background-color:var(--background-light);border-color:var(--border-medium)}.btn-icon:disabled{opacity:.5}.btn-icon.btn-add{border-color:var(--primary-blue);color:var(--primary-blue)}.btn-icon.btn-add:hover:not(:disabled){background-color:var(--primary-blue);color:var(--text-white)}.btn-icon.btn-success{border-color:var(--success-green);color:var(--success-green)}.btn-icon.btn-success:hover:not(:disabled){background-color:var(--success-green);color:var(--text-white)}.btn-icon.btn-cancel{border-color:var(--border-medium);color:var(--text-secondary)}.btn-icon.btn-cancel:hover:not(:disabled){background-color:var(--text-secondary);color:var(--text-white)}.btn-icon.btn-delete{border-color:var(--danger-red);color:var(--danger-red)}.btn-icon.btn-delete:hover:not(:disabled){background-color:var(--danger-red);color:var(--text-white)}.input-group{align-items:center;display:flex;gap:var(--spacing-xs)}.input-group input{background-color:var(--background-white);border:1px solid var(--border-light);border-radius:var(--radius-sm);box-sizing:border-box;color:var(--text-primary);font-size:var(--font-size-small);min-width:150px;padding:var(--spacing-sm) var(--spacing-md)}.input-group input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #3b82f61a;outline:none}.report-workspace{grid-gap:var(--spacing-lg);display:grid;gap:var(--spacing-lg);grid-template-columns:1fr 1fr 1fr}.settings-panel{background-color:#fff;box-shadow:none;overflow:hidden}.settings-header{background-color:var(--dark-header);color:var(--text-white);font-size:var(--font-size-body);font-weight:600;padding:var(--spacing-md)}.settings-content{padding:var(--spacing-lg)}.settings-section{margin-bottom:var(--spacing-xl)}.settings-section h4{color:var(--text-primary);font-size:var(--font-size-small);font-weight:600;margin-bottom:var(--spacing-md)}.sync-indicator{align-items:center;background-color:var(--primary-blue);border-radius:var(--radius-sm);color:var(--text-white);display:inline-flex;font-size:var(--font-size-caption);font-weight:500;padding:var(--spacing-xs) var(--spacing-sm)}.sync-indicator:before{content:"🔗";margin-right:var(--spacing-xs)}.report-preview{background-color:var(--background-white);border:1px solid var(--border-light);border-radius:var(--radius-md);grid-column:1/-1;margin-top:var(--spacing-lg);overflow:hidden}.report-preview-header{background-color:var(--dark-header);color:var(--text-white);font-size:var(--font-size-body);font-weight:600;padding:var(--spacing-md)}.btn-icon{flex-shrink:0}.btn-text{font-weight:500}.master-log-table{background-color:var(--background-white);border:1px solid var(--border-light);border-radius:16px;box-shadow:0 10px 20px #0f172a14;overflow:hidden}.assessments-data-table{border-collapse:collapse;font-size:var(--font-size-body);width:100%}.assessments-data-table th{background-color:var(--dark-header);border-bottom:none;color:var(--text-white);font-weight:600;padding:var(--spacing-md);text-align:left}.assessments-data-table td{border-bottom:1px solid #94a3b833;padding:var(--spacing-md);vertical-align:top}.assessments-data-table tr:hover{background-color:var(--background-surface);transition:all .3s ease-out}.actions-cell{padding:var(--spacing-sm)!important;text-align:center;white-space:nowrap}.action-btn{border:1px solid var(--gray-800);border-radius:50%;color:var(--gray-800);font-size:14px;height:32px;justify-content:center;margin:0 3px;position:relative;transition:all .2s ease;width:32px}.action-btn:hover{background-color:var(--gray-100);border-color:var(--gray-700);box-shadow:0 4px 8px #1f293733;color:var(--gray-700);transform:scale(1.1)}.action-btn:active{transform:scale(.95)}.action-btn-edit{border-color:var(--gray-800);color:var(--gray-800)}.action-btn-edit:hover{background-color:var(--gray-100);border-color:var(--gray-700);color:var(--gray-700)}.action-btn-delete{border-color:var(--danger-red);color:var(--danger-red)}.action-btn-delete:hover{background-color:#fee2e2;border-color:#b91c1c;color:#b91c1c}.action-btn-view{border-color:#4f46e5;color:#4f46e5}.action-btn-view:hover{background-color:#eef2ff;border-color:#4338ca;color:#4338ca}.action-btn-duplicate{border-color:#4f46e5;color:#4f46e5}.action-btn-duplicate:hover{background-color:#eef2ff;border-color:#4338ca;color:#4338ca}.search-filter-section{background-color:#fff;border:2px solid var(--gray-800);border-radius:16px;box-shadow:0 10px 20px #0f172a14;margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.filter-toolbar{display:flex;flex-direction:column;gap:var(--spacing-md)}.filter-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.filter-group{display:flex;flex:0 1 auto;flex-direction:column;min-width:140px}.filter-group.search-field{flex:1 1;min-width:250px}.filter-group label{color:var(--gray-700);font-size:var(--font-size-small);font-weight:600;margin-bottom:4px}.search-bar{align-items:center;display:flex;position:relative}.search-input{background-color:var(--background-white);border:1px solid var(--gray-300);border-radius:var(--radius-sm);font-size:var(--font-size-small);padding:8px 36px 8px 12px;transition:all .2s ease;width:100%}.search-input:focus{border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e51a;outline:none}.search-input::placeholder{color:var(--gray-400)}.clear-search-btn{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--gray-500);cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:8px;transition:all .2s ease}.clear-search-btn:hover{background-color:var(--gray-100);color:var(--gray-700)}.filter-group select{background-color:var(--background-white);border:1px solid var(--gray-300);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:var(--font-size-small);padding:7px 10px;transition:all .2s ease}.filter-group select:hover{background-color:var(--gray-50);border-color:var(--gray-400)}.filter-group select:focus{border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e51a;outline:none}.results-summary{border-top:2px solid var(--gray-200);color:var(--gray-600);font-size:var(--font-size-small);font-weight:500;margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.filtered-indicator{color:#4f46e5;font-weight:600}.active-filters{border-top:1px solid var(--gray-200);display:flex;flex-wrap:wrap;gap:6px;margin-top:var(--spacing-md);padding-top:var(--spacing-md)}.filter-pill{align-items:center;background-color:#eef2ff;border:1px solid #c7d2fe;border-radius:999px;color:#4f46e5;cursor:pointer;display:inline-flex;font-size:var(--font-size-small);font-weight:500;gap:6px;padding:4px 10px;transition:all .15s ease}.filter-pill:hover{background-color:#e0e7ff;border-color:#a5b4fc;color:#4338ca}.filter-pill.clear-all{background-color:#fee2e2;border-color:#fecaca;color:#dc2626}.filter-pill.clear-all:hover{background-color:#fef2f2;border-color:#fca5a5;color:#b91c1c}.report-generator{margin:0 auto;max-width:1900px;padding:20px}.report-header{border-bottom:2px solid #e1e5e9;margin-bottom:30px;padding-bottom:15px}.header-content h2{color:#2c3e50;margin-bottom:8px}.header-content p{color:#7f8c8d;font-size:16px}.data-source-header{background-color:var(--background-white);border:1px solid var(--border-light);border-radius:var(--radius-md);gap:20px;justify-content:space-between;margin-bottom:var(--spacing-lg);padding:12px 20px}.data-source-controls{align-items:center;display:flex;flex:1 1;gap:12px;min-width:400px}.data-source-controls label{color:var(--text-primary);font-size:var(--font-size-small);font-weight:600;white-space:nowrap}.data-source-controls .separator{color:var(--border-medium);font-size:18px;margin:0 4px}.compact-dropdown{background-color:var(--background-white);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:var(--font-size-small);min-height:32px;min-width:150px;padding:6px 12px;transition:all .2s ease}.compact-dropdown:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #3b82f61a;outline:none}.compact-dropdown:hover{border-color:var(--border-medium)}.inline-input-group{align-items:center;display:flex;gap:6px}.inline-input-group input{border:1px solid var(--border-light);border-radius:var(--radius-sm);font-size:var(--font-size-small);min-height:32px;padding:6px 12px;width:150px}.inline-input-group input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #3b82f61a;outline:none}.workflow-controls-inline{align-items:center;display:flex;gap:12px}.workflow-controls-inline label{color:var(--text-primary);font-size:var(--font-size-small);font-weight:600;white-space:nowrap}.workflow-controls{align-items:center;display:flex;gap:15px}.workflow-controls label{color:#495057;font-weight:500}.workflow-tabs{border:1px solid #dee2e6;border-radius:6px;display:flex;overflow:hidden}.workflow-tabs button{background:#f8f9fa;border:none;border-right:1px solid #dee2e6;color:#495057;cursor:pointer;font-size:var(--font-size-small);padding:8px 16px;transition:all .2s ease;white-space:nowrap}.workflow-tabs button:last-child{border-right:none}.workflow-tabs button:hover{background:#e9ecef}.workflow-tabs button.active{background:#007bff;color:#fff}.report-layout-side{gap:0;min-height:600px;position:relative}.settings-panel{background:#fff;border:none;border-radius:0;padding:20px}.resize-handle,.settings-panel{align-self:flex-start;flex-shrink:0;height:100vh;position:-webkit-sticky;position:sticky;top:0;z-index:10}.resize-handle{transition:background-color .2s ease}.resize-handle:before{background:#9ca3af;border-radius:1px;content:"";height:30px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:2px}.table-panel{min-width:0}.settings-panel-top{background:#fff;border:none;border-bottom:1px solid #e5e7eb;border-radius:0;max-height:70vh;padding:20px}.settings-content{width:100%}.settings-section{border-bottom:1px solid #dee2e6;margin-bottom:12px;padding-bottom:8px}.settings-section:last-child{border-bottom:none}.settings-section h3{color:#495057;font-size:13px;font-weight:600;margin-bottom:6px}.dual-settings-container{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:12px}.comments-section{border-right:1px solid #dee2e6;padding-right:10px}.targets-section{padding-left:10px}.sync-header{display:flex;flex-direction:column;gap:6px}.sync-controls label{align-items:center;display:flex;font-size:12px;gap:6px}.reset-btn{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;margin-top:4px;padding:4px 8px}.reset-btn:hover{background:#5a6268}.unsync-status{color:#dc3545;font-size:11px;font-weight:500;margin-top:3px}.setting-group{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:8px;min-height:24px}.setting-group.stack{align-items:stretch;flex-direction:column;gap:4px;min-height:auto}.setting-group.stack label{height:auto;margin-bottom:2px;overflow:visible;text-overflow:clip;white-space:normal}.setting-group label,.setting-label{align-items:center;color:#495057;display:flex;flex:1 1;font-size:12px;font-weight:500;margin:0;min-height:20px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.setting-label.unsynced,.unsynced,label.unsynced{color:#dc3545}.unsync-controls{align-items:center;display:inline-flex;gap:6px;margin-left:8px}.unsync-indicator{color:#dc3545;font-size:16px;font-weight:700}.resync-btn{background:#28a745;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:10px;font-weight:700;padding:1px 4px}.resync-btn:hover{background:#218838}.setting-group input[type=number],.setting-group input[type=text],.setting-group select,.setting-group-inline input[type=number],.setting-group-inline input[type=text]{background:#fff;border:1px solid #ced4da;border-radius:3px;box-sizing:border-box;flex:0 0 auto;font-size:11px;height:24px;margin-top:2px;max-width:200px;min-width:120px;padding:4px 6px}.setting-group label.unsynced~select{max-width:160px}.setting-group-inline{align-items:flex-end;display:flex;flex-direction:column;gap:4px;padding-bottom:12px}.setting-group-inline>div{align-items:center;display:flex;gap:8px;justify-content:flex-end;width:100%}.setting-group-inline label{color:#495057;font-size:11px;margin:0}.limit-inputs{display:flex;gap:6px;margin-top:3px}.limit-inputs input{flex:1 1;margin-top:0}.report-generator .toggle-switch{background-color:#d1d5db;border-radius:9px;cursor:pointer;flex-shrink:0;height:18px;position:relative;transition:background-color .2s;width:32px}.report-generator .toggle-switch.active{background-color:var(--primary-blue)}.report-generator .toggle-switch.disabled{cursor:not-allowed;opacity:.6}.report-generator .toggle-switch:after{background-color:var(--text-white);border-radius:50%;box-shadow:0 1px 2px #0000001a;content:"";height:14px;left:2px;position:absolute;top:2px;transition:transform .2s;width:14px}.report-generator .toggle-switch.active:after{transform:translateX(14px)}.column-list{background:#fff;border:1px solid #dee2e6;border-radius:4px;margin-top:4px;padding:6px}.column-item{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:3px;display:flex;margin-bottom:4px;padding:4px 6px;transition:all .2s ease}.column-item:hover{border-color:#007bff;box-shadow:0 2px 4px #007bff1a}.column-title{color:#495057;font-size:11px}.column-controls{align-items:center;gap:6px;margin-left:auto}.column-controls label{font-size:10px;margin:0}.required{color:#dc3545;font-weight:700;margin-left:5px}.reorder-buttons{display:flex;gap:2px}.reorder-btn{align-items:center;background:#f8f9fa;border:1px solid #dee2e6;border-radius:3px;color:#495057;cursor:pointer;display:flex;font-size:10px;font-weight:700;height:18px;justify-content:center;transition:all .2s ease;width:18px}.reorder-btn:hover:not(:disabled){background:#007bff;border-color:#007bff;color:#fff}.reorder-btn:disabled{background:#e9ecef;color:#6c757d;cursor:not-allowed;opacity:.5}.report-table-panel{background:#fff;border:none;border-radius:0;display:flex;flex-direction:column;height:100%;overflow:hidden}.report-table-panel h3{color:#495057;font-size:14px;margin:0}.report-table-panel .report-header,.report-table-panel h3{background:#fff;border-bottom:1px solid #e9ecef;padding:10px 15px}.report-table-panel .report-header{justify-content:space-between}.report-header-left,.report-table-panel .report-header{align-items:center;display:flex;gap:12px}.report-table-panel .report-header h3{border:none;margin:0;padding:0}.toggle-settings-btn{align-items:center;background-color:#fff;border:1px solid #3b82f6;border-radius:4px;color:#3b82f6;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:6px 12px;transition:all .15s ease;white-space:nowrap}.toggle-settings-btn svg{flex-shrink:0}.toggle-settings-btn:hover{background-color:#eff6ff;border-color:#2563eb;color:#2563eb}.table-wrapper{flex:1 1;overflow-x:auto;overflow-y:visible}.report-table{border-collapse:collapse;min-width:-webkit-max-content;min-width:max-content;width:100%}.report-table.small td,.report-table.small th{padding:6px 8px}.report-table.medium td,.report-table.medium th{padding:12px 16px}.report-table.large td,.report-table.large th{padding:20px 24px}.report-table.compact tr{line-height:1.2}.report-table.normal tr{line-height:1.5}.report-table.spacious tr{line-height:2}.report-table.none td,.report-table.none th{border:none}.report-table.light td,.report-table.light th{border:1px solid #94a3b833}.report-table.heavy td,.report-table.heavy th{border:2px solid #6c757d}.report-table.bold{font-weight:700}.report-table.italic{font-style:italic}.report-table th{background:#f8f9fa;color:#495057;font-weight:600;position:-webkit-sticky;position:sticky;top:0;z-index:10}.report-table td.frozen,.report-table th.frozen{background:#fff;box-shadow:2px 0 5px #0000001a;left:0;position:-webkit-sticky;position:sticky;z-index:11}.report-table th.frozen{background:#f8f9fa;z-index:12}.report-table td{background:#fff;color:#212529;position:relative;vertical-align:top}.report-table td.validation-warning{background-color:#fff3cd;border-color:#ffeaa7}.validation-indicator{background:#ffffffe6;border-radius:2px;color:#dc3545;font-size:10px;padding:2px 4px;position:absolute;right:2px;top:2px}.report-table tr:hover td{background:#f8f9fa}.report-table tr:hover td.frozen{background:#e9ecef}.report-table tr:hover td.validation-warning{background:#ffeaa7}.column-studentName{font-weight:500;min-width:150px}.column-progress{min-width:200px}.column-comments,.column-targets{max-width:500px;min-width:300px}.column-gpa{font-weight:600;min-width:80px;text-align:center}.column-attitude{min-width:120px}.cell-content{word-wrap:break-word;line-height:1.4}.no-data{color:#6c757d;font-style:italic;padding:40px;text-align:center}.export-actions{display:flex;flex-wrap:wrap;gap:12px;padding:16px 0}.export-btn{align-items:center;background:var(--primary-blue);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 18px;transition:all .2s}.export-btn:hover{background:var(--primary-hover);box-shadow:0 4px 8px #4f46e54d;transform:translateY(-1px)}.export-btn svg{flex-shrink:0}.export-btn:active{transform:translateY(0)}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:90vw;overflow:auto}.export-modal{width:1200px}.copy-custom-modal{width:700px}.modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:20px 24px}.modal-header h3{color:var(--text-primary);font-size:18px;margin:0}.modal-close{background:none;border:none;color:var(--gray-400);cursor:pointer;font-size:28px;height:32px;line-height:1;padding:0;width:32px}.modal-close:hover{color:var(--gray-600)}.modal-body{padding:24px}.pdf-export-container{grid-gap:24px;display:grid;gap:24px;grid-template-columns:350px 1fr;min-height:500px}.pdf-settings-section{display:flex;flex-direction:column;gap:16px}.pdf-preview-section{border-left:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px;padding-left:24px}.pdf-preview-section h4{color:var(--gray-700);font-size:14px;font-weight:600;margin:0}.pdf-preview-iframe{background:#fff;height:100%;min-height:450px;width:100%}.pdf-preview-iframe,.pdf-preview-loading{border:1px solid var(--border-color);border-radius:6px}.pdf-preview-loading{align-items:center;background:var(--gray-50);color:var(--text-secondary);display:flex;font-size:14px;height:450px;justify-content:center}.control-group{flex-direction:column;gap:8px}.control-group label{color:var(--gray-700);font-size:14px;font-weight:500}.control-group input[type=number],.control-group select{border:1px solid var(--border-color);border-radius:6px;font-size:14px;padding:8px 12px}.selection-container{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-bottom:20px}.selection-section h4{color:var(--gray-700);font-size:14px;font-weight:600;margin:0 0 12px}.checkbox-list{background:var(--gray-50);border-radius:6px;display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto;padding:12px}.checkbox-item{align-items:center;border-radius:4px;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:6px 8px;transition:background .15s}.checkbox-item:hover{background:var(--gray-100)}.checkbox-item input[type=checkbox]{cursor:pointer;height:18px;width:18px}.header-toggle{align-items:center;background:var(--gray-50);border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;margin-bottom:16px;padding:12px;-webkit-user-select:none;user-select:none}.header-toggle input[type=checkbox]{cursor:pointer;height:18px;width:18px}.header-toggle:hover{background:var(--gray-100)}.modal-actions{gap:12px}.primary-btn,.secondary-btn{border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.primary-btn{background:var(--primary-blue);border:none;color:#fff}.primary-btn:hover{background:var(--primary-hover)}.secondary-btn{background:#fff;border:1px solid var(--border-color);color:var(--gray-700)}.secondary-btn:hover{background:var(--gray-50)}@media (max-width:1024px){.pdf-export-container{gap:16px;grid-template-columns:1fr}.pdf-preview-section{border-left:none;border-top:1px solid var(--border-color);padding-left:0;padding-top:16px}.selection-container{grid-template-columns:1fr}.copy-custom-modal,.export-modal{width:95vw}}.export-actions-header{align-items:center;display:flex;gap:12px;margin-left:24px}.export-btn-navy{align-items:center;background-color:var(--dark-navy);border:1px solid var(--dark-navy);border-radius:6px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s ease}.export-btn-navy:hover{background-color:var(--gray-700);border-color:var(--gray-700);box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.export-btn-navy:active{box-shadow:0 1px 2px #0000001a;transform:translateY(0)}.export-btn-navy svg{flex-shrink:0}.header-content{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.header-content h2{margin:0}@media (max-width:768px){.export-actions-header{flex-wrap:wrap;margin-left:0;margin-top:12px}.export-btn-navy{font-size:13px;padding:6px 12px}.export-btn-navy span{display:none}}.report-table th .header-content{align-items:center;display:flex;gap:8px;justify-content:space-between;min-width:-webkit-max-content;min-width:max-content}.report-table th .header-title{align-items:center;display:flex;flex:1 1;gap:4px;white-space:nowrap}.report-table th .header-controls{align-items:center;display:flex;gap:4px;opacity:1}.header-control-btn{align-items:center;background:#fff;border:1px solid #dee2e6;border-radius:4px;color:#495057;cursor:pointer;display:inline-flex;font-size:14px;height:24px;justify-content:center;padding:0;transition:all .2s ease;width:24px}.header-control-btn:hover:not(:disabled){background:var(--primary-blue);border-color:var(--primary-blue);box-shadow:0 2px 4px #007bff33;color:#fff;transform:translateY(-1px)}.header-control-btn:disabled{background:#e9ecef;cursor:not-allowed;opacity:.3}.header-control-btn:active:not(:disabled){box-shadow:none;transform:translateY(0)}.copy-custom-overlay{background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.copy-custom-modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;left:50%;max-height:80vh;max-width:900px;overflow:auto;padding:24px;position:fixed;top:50%;transform:translate(-50%,-50%);z-index:1000}.copy-custom-modal h3{color:var(--text-primary);font-size:24px;font-weight:600;margin:0 0 20px}.selection-controls{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.selection-controls button{background:#fff;border:1px solid var(--border-light);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:13px;padding:6px 12px;transition:all .2s ease}.selection-controls button:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.preview-table-wrapper{border:1px solid var(--border-light);border-radius:6px;margin:16px 0;max-height:400px;overflow:auto}.preview-table td,.preview-table th{border:1px solid var(--border-light);font-size:13px;padding:8px}.preview-table th{background:#f8f9fa;font-weight:600;position:-webkit-sticky;position:sticky;top:0;z-index:1}.preview-table .checkbox-cell{text-align:center;width:40px}.preview-table tr.selected{background:#3498db1a}.preview-table th.selected{background:#3498db4d}.modal-options{display:flex;gap:16px;margin:16px 0}.modal-options label{align-items:center;cursor:pointer;display:flex;gap:6px}.ai-prompt-section{background:#f8f9fa;border:1px solid var(--border-light);border-radius:6px;margin:16px 0;padding:16px}.ai-prompt-section h4{font-size:16px;margin:0 0 12px}.ai-prompt-section label{align-items:center;cursor:pointer;display:flex;gap:6px;margin-bottom:12px}.prompt-editor{margin:12px 0}.prompt-editor label{display:block;font-weight:500;margin-bottom:6px}.ai-prompt-textarea{border:1px solid var(--border-light);border-radius:6px;font-family:Courier New,monospace;font-size:13px;min-height:120px;padding:12px;resize:vertical;width:100%}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:24px}.pdf-export-overlay{background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.pdf-export-modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;left:50%;max-height:90vh;max-width:1000px;overflow:auto;padding:24px;position:fixed;top:50%;transform:translate(-50%,-50%);z-index:1000}.pdf-export-modal h3{font-size:20px;font-weight:600;margin:0 0 20px}.pdf-settings{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;margin-bottom:20px;padding:16px}.pdf-setting-group{margin-bottom:12px}.pdf-setting-group:last-child{margin-bottom:0}.pdf-setting-group>label{display:block;font-weight:500;margin-bottom:8px}.pdf-radio-group{display:flex;gap:16px}.pdf-radio-option{align-items:center;display:flex;gap:6px}.pdf-preview-container{background:#f5f5f5;border:1px solid var(--border-color);border-radius:6px;margin-bottom:16px;padding:16px}.pdf-preview-container>label{display:block;font-weight:500;margin-bottom:12px}.pdf-preview{background:#fff;box-shadow:0 2px 8px #0000001a;margin:0 auto;max-width:100%;overflow:auto;padding:20px}.pdf-preview.portrait{max-width:650px;width:100%}.pdf-preview.landscape{max-width:850px;width:100%}.preview-header{align-items:center;border-bottom:2px solid #333;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:10px}.preview-logo{height:40px;width:auto}.preview-title{flex:1 1;text-align:center}.preview-title h3{font-size:16px;font-weight:700;margin:0}.preview-title h4{color:#666;font-size:13px;margin:4px 0 0}.preview-date{color:#666;font-size:10px}.preview-table{border-collapse:collapse;font-size:inherit;width:100%}.preview-table td,.preview-table th{border:1px solid #ddd;font-size:inherit;padding:4px 6px;text-align:left}.preview-table th{background:#f0f0f0;font-weight:700}.preview-pagination{align-items:center;display:flex;font-size:14px;justify-content:space-between;margin-top:12px}.preview-nav{display:flex;gap:8px}.preview-nav button{background:#fff;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;padding:4px 12px}.preview-nav button:disabled{cursor:not-allowed;opacity:.5}.pdf-options{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.pdf-options label{align-items:center;display:flex;gap:8px}@media print{body *{visibility:hidden}#pdf-print-container,#pdf-print-container *{visibility:visible}#pdf-print-container{left:0;position:absolute;top:0;width:100%}@page{size:auto;margin:.5in}.pdf-header{align-items:center;border-bottom:2px solid #333;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:10px}.pdf-logo{height:50px;width:auto}.pdf-title{flex:1 1;text-align:center}.pdf-title h1{font-size:18pt;font-weight:700;margin:0}.pdf-title h2{color:#666;font-size:14pt;margin:5px 0 0}.pdf-date{color:#666;font-size:10pt}.pdf-table{border-collapse:collapse;page-break-inside:auto;width:100%}.pdf-table.text-small{font-size:8pt}.pdf-table.text-medium{font-size:10pt}.pdf-table.text-large{font-size:12pt}.pdf-table thead{display:table-header-group}.pdf-table tr{page-break-after:auto;page-break-inside:avoid}.pdf-table td,.pdf-table th{border:1px solid #333;padding:4px 8px;text-align:left}.pdf-table th{background-color:#f0f0f0!important;font-weight:700;-webkit-print-color-adjust:exact;print-color-adjust:exact}.validation-indicator{display:none}.pdf-table.show-warnings .validation-indicator{color:red;display:inline;font-size:7pt}}.gpa-conversions{background:var(--bg-secondary);border-radius:6px;margin-top:12px;padding:12px}.gpa-conversions h5{color:var(--text-primary);font-size:13px;font-weight:600;margin:0 0 12px}.gpa-conversion-item{gap:12px;margin-bottom:8px}.gpa-conversion-item:last-child{margin-bottom:0}.gpa-mark{color:var(--text-primary);font-weight:600;min-width:30px}.gpa-conversion-item input[type=number],.gpa-value{font-family:Courier New,monospace;font-size:14px}.gpa-conversion-item input[type=number]{border:1px solid var(--border-light);border-radius:4px;padding:4px 8px}.column-order-section{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:6px;margin-bottom:20px;padding:12px}.column-order-section h5{color:var(--text-primary);font-size:13px;font-weight:600;margin:0 0 12px}.column-order-list{display:flex;flex-direction:column;gap:8px}.column-order-item{background:#fff;border:1px solid var(--border-light);border-radius:4px;overflow:hidden}.column-header{align-items:center;display:flex;justify-content:space-between;padding:10px 12px}.column-title{color:var(--text-primary);flex:1 1;font-weight:500}.column-title .required{color:red;margin-left:4px}.column-controls{display:flex;gap:4px}.btn-icon{align-items:center;background:#fff;border:1px solid var(--border-light);border-radius:4px;display:flex;justify-content:center;min-height:28px;min-width:28px;padding:6px;transition:all .2s ease}.btn-icon svg{display:block}.btn-icon:hover:not(:disabled){background:#f5f5f5;background:var(--bg-hover,#f5f5f5);border-color:#999;border-color:var(--border-dark,#999)}.btn-icon:disabled{cursor:not-allowed;opacity:.3}.report-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:16px}.report-header h3{margin:0}.hidden-columns-pills{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.column-pill{align-items:center;background:#e3f2fd;border:1px solid #90caf9;border-radius:16px;color:#1976d2;cursor:pointer;display:inline-flex;font-size:13px;gap:6px;padding:4px 10px;transition:all .2s ease}.column-pill:hover{background:#bbdefb;border-color:#64b5f6}.pill-close{color:#1976d2;font-size:18px;font-weight:700;line-height:1}.th-content{align-items:center;display:flex;gap:8px;justify-content:space-between;width:100%}.th-title{flex:1 1;min-width:0}.th-controls{display:flex;flex-shrink:0;gap:2px}.btn-icon-small{align-items:center;background:#fffc;border:1px solid #00000026;border-radius:3px;cursor:pointer;display:flex;justify-content:center;min-height:24px;min-width:24px;opacity:1;padding:4px;transition:all .2s ease}.btn-icon-small svg{color:#666;display:block}.btn-icon-small:hover:not(:disabled){background:#00000014;border-color:#0000004d}.btn-icon-small:hover:not(:disabled) svg{color:#000}.btn-icon-small:disabled{background:#00000005;cursor:not-allowed;opacity:.3}.report-table th{position:relative}.report-table th .th-controls{opacity:1}.data-source-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:24px;padding:16px 20px}.export-buttons{align-items:center;display:flex;gap:8px}.btn-export{align-items:center;background:#1f2937;background:var(--gray-800,#1f2937);border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.btn-export svg{flex-shrink:0}.btn-export:hover{background:#374151;background:var(--gray-700,#374151);box-shadow:0 4px 8px #1f29374d;transform:translateY(-1px)}.btn-export:active{box-shadow:0 2px 4px #1f29374d;transform:translateY(0)}.settings-header{align-items:center;background:#0000;border-bottom:2px solid #e0e0e0;border-bottom:2px solid var(--border-light,#e0e0e0);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.settings-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.settings-header-actions{align-items:center;display:flex;gap:12px}.zoom-controls{align-items:center;display:inline-flex;gap:8px}.zoom-btn{font-size:14px;font-weight:600;min-width:32px;padding:4px 10px}.zoom-indicator{color:var(--gray-600);font-size:12px;font-weight:500;min-width:40px;text-align:center}.settings-zoom-wrapper{width:100%}.btn-modal-cancel{background:#fff;border:1px solid var(--gray-300);border-radius:4px;color:var(--gray-700);cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.btn-modal-cancel:hover{background:var(--gray-100);border-color:var(--gray-400);box-shadow:0 2px 4px #0000001a}.view-controls-mini{align-items:center;display:flex;gap:8px}.view-controls-mini label{color:#666;font-size:13px;font-weight:500;margin:0}.view-tabs-mini{background:#d1d5db;border-radius:6px;display:flex;gap:4px;padding:3px}.view-tabs-mini button{background:#9ca3af;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.view-tabs-mini button.active{background:#374151;box-shadow:0 2px 4px #0003;color:#fff}.view-tabs-mini button:hover:not(.active){background:#6b7280}.settings-tabs{-webkit-overflow-scrolling:touch;background:#f5f5f5;background:var(--bg-secondary,#f5f5f5);border-radius:8px;display:flex;gap:4px;margin-bottom:16px;overflow-x:auto;padding:8px}.settings-tabs button{background:#0000;border:none;border-radius:6px;color:#666;color:var(--text-secondary,#666);cursor:pointer;flex-shrink:0;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.settings-tabs button.active{background:#fff;box-shadow:0 2px 4px #0000001a;color:#3b82f6;color:var(--primary-blue,#3b82f6)}.settings-tabs button:hover:not(.active){background:#fff9}.settings-panel{height:calc(100vh - 200px);overflow-x:hidden;overflow-y:auto}.settings-panel-top{max-height:400px;overflow-x:hidden;overflow-y:auto}.settings-panel-content{padding:20px}.resize-handle{background:#e5e7eb;cursor:col-resize;transition:background .2s ease;-webkit-user-select:none;user-select:none;width:4px}.resize-handle:hover{background:#3b82f6}.report-layout-side{background:#fff;display:flex;min-height:calc(100vh - 150px);overflow:visible}.table-panel{background:#fff;flex:1 1;overflow-x:auto;overflow-y:visible;padding:20px}.report-layout-top{background:#fff;display:flex;flex-direction:column;gap:0}.dual-settings-wrapper{align-items:flex-start;display:flex!important;flex-wrap:wrap;gap:20px;width:100%}.dual-settings-wrapper>.settings-section{box-sizing:border-box;flex:1 1 250px;max-width:calc(50% - 10px);min-width:250px;padding:0}@media (min-width:1200px){.dual-settings-wrapper>.settings-section{max-width:calc(25% - 15px)}}@media (min-width:900px) and (max-width:1199px){.dual-settings-wrapper>.settings-section{max-width:calc(33.333% - 14px)}}.dual-settings-wrapper .setting-group{flex-wrap:nowrap;gap:12px;justify-content:space-between}.dual-settings-wrapper .setting-group label{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dual-settings-wrapper .setting-group input[type=number],.dual-settings-wrapper .setting-group input[type=text],.dual-settings-wrapper .setting-group select{flex-shrink:0;margin-left:auto}.settings-sync-section .setting-group{gap:12px;justify-content:flex-start!important}.settings-sync-section .setting-group label{flex:0 0 auto}.assessment-details-expanded{background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-top:2px solid var(--gray-200);padding:var(--spacing-lg)}.detail-section{margin-bottom:var(--spacing-lg)}.detail-section-title{border-bottom:2px solid var(--gray-300);color:var(--gray-800);font-size:var(--font-size-body);font-weight:600;margin:0 0 var(--spacing-md) 0;padding-bottom:var(--spacing-sm)}.detail-empty{background:var(--gray-50);border:1px dashed var(--gray-300);border-radius:var(--radius-md);color:var(--gray-500);font-style:italic;padding:var(--spacing-xl);text-align:center}.master-log-row{cursor:pointer;transition:all .15s ease}.master-log-row:hover{background-color:var(--gray-50)!important}.master-log-row.expanded{background-color:#eef2ff!important}.row-summary{align-items:center;display:flex;gap:var(--spacing-sm)}.row-chevron{align-items:center;color:var(--gray-600);display:inline-flex;font-size:14px;height:20px;justify-content:center;transition:transform .2s ease;width:20px}.master-log-row.expanded .row-chevron{transform:rotate(0deg)}.row-title{color:var(--gray-800);font-weight:500}.row-actions{align-items:center;display:flex;gap:6px;justify-content:center}.detail-row td{background:linear-gradient(180deg,#f8fafc,#f1f5f9)!important;padding:0!important}:root{--primary-blue:#4f46e5;--primary-hover:#4338ca;--primary-light:#6366f1;--success-green:#059669;--success-hover:#047857;--warning-amber:#d97706;--warning-hover:#b45309;--danger-red:#dc2626;--danger-hover:#b91c1c;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--background-surface:var(--gray-50);--background-white:#fff;--border-color:var(--gray-300);--border-light:var(--gray-200);--text-secondary:var(--gray-500);--text-primary:var(--gray-900);--text-white:#fff;--secondary-blue:var(--primary-light);--accent-green:var(--success-green);--warning-orange:var(--warning-amber);--error-red:var(--danger-red);--dark-header:var(--gray-700);--dark-navy:var(--gray-800);--section-header:var(--gray-600);--font-size-h1:24px;--font-size-h2:18px;--font-size-h3:16px;--font-size-body:14px;--font-size-small:13px;--font-size-caption:12px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:12px;--spacing-lg:16px;--spacing-xl:20px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #00000012;--shadow-lg:0 10px 15px #0000001a;--nav-height:64px}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 20% 20%,#ff8c4208,#0000 50%),radial-gradient(circle at 80% 10%,#ffa06405,#0000 45%),linear-gradient(180deg,#fafaf8f2,#f5f5f3e6);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:var(--font-size-body);line-height:1.5}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{background:#0000;flex:1 1;margin-top:var(--nav-height);max-width:100vw;overflow-x:auto;overflow-y:visible;padding:var(--spacing-lg)}.page-header{border-bottom:1px solid var(--border-light);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md)}.page-header h1{color:var(--text-primary);font-size:var(--font-size-h1);font-weight:600;margin-bottom:var(--spacing-xs)}.page-header p{color:var(--text-secondary);font-size:var(--font-size-small)}.main-navigation{background-color:var(--dark-navy);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-md);height:var(--nav-height);left:0;padding:0 var(--spacing-xl);position:fixed;right:0;top:0;z-index:100}.main-navigation,.nav-brand{align-items:center;display:flex}.nav-brand{gap:var(--spacing-sm);margin-right:var(--spacing-xl);text-decoration:none}.nav-logo{display:block;height:44px;width:auto}.app-title{color:var(--text-white);font-size:var(--font-size-h2);font-weight:600}.nav-menu{flex:1 1;list-style:none}.nav-link,.nav-menu{display:flex;gap:var(--spacing-sm)}.nav-link{align-items:center;border-bottom:3px solid #0000;border-radius:0;color:var(--text-white);opacity:.8;padding:var(--spacing-sm) var(--spacing-md);position:relative;text-decoration:none;transition:all .2s ease;white-space:nowrap}.nav-link:hover{border-bottom-color:#ff8c4280;opacity:1}.nav-link.active{border-bottom-color:#ff8c42;font-weight:600;opacity:1}.nav-icon{align-items:center;color:currentColor;display:inline-flex;height:18px;justify-content:center;width:18px}.nav-label{font-size:var(--font-size-body);font-weight:500}.nav-actions{align-items:center;display:flex;gap:.75rem;margin-left:auto}.help-button{background:none;border:1px solid #ffffff4d;border-radius:var(--radius-md);color:var(--text-white);cursor:pointer;font-size:var(--font-size-body);font-weight:500;opacity:.9;padding:var(--spacing-sm) var(--spacing-md);transition:all .2s ease}.help-button:hover{background-color:#ffffff1a;border-color:#ffffff80;opacity:1}.login-inline{position:relative}.login-button{background:#ffffff24;border:1px solid #fff6;border-radius:var(--radius-md);color:var(--text-white);font-size:.95rem;font-weight:600;padding:8px 18px}.login-button:hover{background:#ffffff38;box-shadow:0 12px 18px #0f172a40}.login-popover{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#fffffff5;border:1px solid #94a3b840;border-radius:18px;box-shadow:0 25px 45px #0f172a40;padding:20px 22px;position:absolute;right:0;top:calc(100% + 12px);width:320px;z-index:120}.login-popover:before{background:inherit;border-left:1px solid #94a3b840;border-radius:3px;border-top:1px solid #94a3b840;content:"";height:18px;position:absolute;right:18px;top:-10px;transform:rotate(45deg);width:18px}.login-popover-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.login-popover-header h3{color:var(--dark-navy);font-size:1.1rem;margin:0}.popover-close{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1rem}.login-popover-subtext{color:var(--text-secondary);font-size:.85rem;line-height:1.5;margin:0 0 12px}.login-popover-form{grid-gap:10px;display:grid;gap:10px}.login-popover-form label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.login-popover-form input{background:#f8fafcd9;border:1px solid #94a3b866;border-radius:10px;font-size:.9rem;padding:10px 12px}.login-popover-form input:focus{background:#fff;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e52e;outline:none}.login-popover-divider{align-items:center;color:var(--text-secondary);display:flex;font-size:.75rem;gap:10px;letter-spacing:.12em;margin:14px 0;text-transform:uppercase}.login-popover-divider:after,.login-popover-divider:before{background:#94a3b84d;content:"";flex:1 1;height:1px}.link-button{background:none;border:none;color:#4f46e5;cursor:pointer;font-weight:600;margin-top:8px}.link-button:hover{text-decoration:underline}.login-popover-links{grid-gap:6px;display:grid;gap:6px;margin-top:10px}.error-message.compact{font-size:.8rem;margin-bottom:10px;padding:8px 10px}.login-popover .btn-block{justify-content:center;width:100%}@media (max-width:768px){.login-popover{right:-40px}}.mobile-nav-toggle{background:none;border:none;color:var(--text-white);cursor:pointer;display:none;font-size:24px;margin-left:auto;padding:8px}@media (max-width:768px){.main-navigation{flex-wrap:wrap;padding:0 var(--spacing-md);position:relative}.nav-brand{flex:1 1;min-width:0}.app-title{font-size:var(--font-size-h3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-logo{height:40px}.mobile-nav-toggle{display:block;order:3}.nav-actions{display:flex;gap:var(--spacing-sm);margin-left:auto;margin-right:var(--spacing-sm);order:2}.dropdown-arrow,.user-name{display:none}.help-button{font-size:14px;padding:var(--spacing-xs) var(--spacing-sm)}.nav-menu{background-color:var(--dark-navy);border-top:1px solid #ffffff1a;box-shadow:0 4px 6px #0003;display:none;flex-direction:column;left:0;margin-top:var(--spacing-md);order:4;padding:var(--spacing-md) 0;position:absolute;right:0;top:100%;width:100%;z-index:1000}.nav-menu.mobile-open{display:flex}.nav-item,.nav-link{width:100%}.nav-link{justify-content:flex-start;padding:var(--spacing-md)}}@media (max-width:480px){.main-navigation{height:auto;min-height:var(--nav-height);padding:0 var(--spacing-sm)}.app-title{font-size:16px}.nav-link{font-size:14px;padding:var(--spacing-sm) var(--spacing-md)}.help-button{font-size:12px;padding:6px 10px}.nav-logo{height:32px}.user-menu-trigger{padding:4px}.user-avatar{font-size:14px;height:32px;width:32px}.mobile-nav-toggle{font-size:20px;padding:6px}.user-menu-dropdown{min-width:220px;right:-8px}}.tracker-header{background-color:#fff;border-bottom:2px solid #ddd;padding:15px 20px}.tracker-title-row{align-items:center;display:flex;font-size:16px;gap:16px}.title-section{align-items:center;display:inline-flex;gap:8px}.title-separator{color:#666;font-size:18px;font-weight:300}.icon-btn.edit-icon-btn{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--gray-500);cursor:pointer;display:inline-flex;font-size:14px;justify-content:center;padding:var(--spacing-xs);transition:color .15s ease}.icon-btn.edit-icon-btn svg{height:14px;width:14px}.icon-btn.edit-icon-btn:hover{background-color:#4f46e50d;color:var(--primary-blue)}.save-status-right{align-items:center;display:flex;gap:12px;margin-left:auto}.book-selector-label{color:var(--gray-700);font-size:14px;font-weight:500}.book-selector-dropdown{background-color:#fff;border:1px solid #ddd;border-radius:var(--radius-sm);color:var(--gray-900);cursor:pointer;font-size:14px;padding:6px 12px;transition:border-color .2s ease}.book-selector-dropdown:focus,.book-selector-dropdown:hover{border-color:var(--primary-blue)}.book-selector-dropdown:focus{box-shadow:0 0 0 3px #4f46e51a;outline:none}.new-book-btn{align-items:center;background-color:#fff;border:1px solid #ddd;border-radius:var(--radius-sm);color:var(--gray-700);cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:6px 12px;transition:all .2s ease}.new-book-btn:hover{background-color:#f8f9fa;border-color:var(--gray-400)}.new-book-btn svg{height:16px;width:16px}.tracker-controls-row{align-items:center;background:linear-gradient(180deg,#e5e7eb 0,#fff 50%);border-bottom:1px solid #ddd;display:flex;gap:20px;justify-content:space-between;padding:15px 20px}.tracker-tabs-section{align-items:center;border:1px solid var(--gray-800);border-bottom:none;border-radius:8px 8px 0 0;display:flex;flex:1 1;gap:8px;min-width:0;overflow:visible;padding:4px 8px}.tracker-tabs{-ms-overflow-style:none;align-items:flex-end;background:#0000;border:none;border-radius:0;display:flex;flex:1 1;gap:4px;height:44px;overflow-x:auto;overflow-y:visible;padding:8px 0 0 8px;scroll-behavior:smooth;scrollbar-width:none}.tracker-tabs::-webkit-scrollbar{display:none}.add-tracker-btn{align-items:center;background-color:#e3f2fd;border:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0;color:#2196f3;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;justify-content:center;min-height:36px;padding:10px var(--spacing-md);transition:background-color .15s ease;white-space:nowrap}.add-tracker-btn:hover{background-color:#bbdefb}.scroll-arrow{background-color:#0000001a;border:none;border-radius:var(--radius-sm);color:#666;display:inline-flex;height:32px;min-width:32px;padding:var(--spacing-sm);transition:background-color .2s}.scroll-arrow svg{height:16px;width:16px}.scroll-arrow:hover{background-color:#0003}.tracker-controls-actions{align-items:center;display:flex;flex-shrink:0;gap:10px}.control-label-inline{color:#333;font-size:14px;font-weight:500}.control-dropdown{background-color:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-body);height:32px;max-width:250px;min-width:150px;padding:var(--spacing-sm) var(--spacing-md);transition:all .15s ease}.control-dropdown:focus,.control-dropdown:hover{border-color:var(--primary-blue)}.control-dropdown:focus{box-shadow:0 0 0 3px #4f46e51a;outline:none}.btn-settings{align-items:center;background-color:#fff;border:1px solid #673ab7;border-radius:var(--radius-sm);color:#673ab7;cursor:pointer;display:inline-flex;font-size:var(--font-size-body);font-weight:500;gap:6px;padding:var(--spacing-sm) var(--spacing-md);transition:all .15s ease;white-space:nowrap}.btn-settings svg{flex-shrink:0;height:16px;width:16px}.btn-settings:hover:not(:disabled){background-color:#f3e5f5;border-color:#5e35b1}.btn-settings:disabled{background-color:var(--gray-100);border-color:var(--gray-300);color:var(--gray-400);cursor:not-allowed;opacity:.6}.btn-delete{align-items:center;background-color:#fff;border:1px solid var(--danger-red);border-radius:var(--radius-sm);color:var(--danger-red);cursor:pointer;display:inline-flex;font-size:var(--font-size-body);font-weight:500;gap:6px;padding:var(--spacing-sm) var(--spacing-md);transition:all .15s ease;white-space:nowrap}.btn-delete svg{flex-shrink:0;height:16px;width:16px}.btn-delete:hover:not(:disabled){background-color:#fee2e2;border-color:var(--danger-hover);color:var(--danger-hover)}.btn-delete:disabled{background-color:var(--gray-100);border-color:var(--gray-300);color:var(--gray-400);cursor:not-allowed;opacity:.6}.new-tracker-input-inline{align-items:center;background:#fff;border:2px solid #2196f3;border-radius:8px 8px 0 0;box-sizing:border-box;display:inline-flex;gap:4px;height:34px;padding:4px 8px}.new-tracker-input-inline input{border:none;border-radius:4px;box-sizing:border-box;font-size:14px;height:24px;max-width:150px;min-width:100px;outline:none;padding:4px 8px}.btn-cancel-small,.btn-confirm-small{align-items:center;border:none;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;flex-shrink:0;height:24px;justify-content:center;padding:0;transition:all .15s ease;width:24px}.btn-cancel-small svg,.btn-confirm-small svg{height:12px;width:12px}.btn-confirm-small{background-color:var(--success-green);color:#fff}.btn-confirm-small:hover{background-color:var(--success-hover)}.btn-cancel-small{background-color:var(--gray-500);color:#fff}.btn-cancel-small:hover{background-color:var(--gray-600)}.assessment-actions-row{align-items:center;background-color:#fff;border-bottom:2px solid #ddd;display:flex;gap:10px;padding:15px 20px}.assessment-scrollbar-wrapper{grid-gap:var(--spacing-lg);align-items:center;background-color:#f9f9f9;border-bottom:1px solid #ddd;display:grid;gap:var(--spacing-lg);grid-template-columns:400px 1fr;height:24px;padding:0 20px}.scrollbar-spacer{grid-column:1}.scrollbar-controls{align-items:center;display:flex;gap:8px;grid-column:2;min-width:0;width:100%}.scroll-arrow{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;display:flex;font-size:20px;font-weight:700;height:20px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:28px}.scroll-arrow:hover:not(:disabled){background:#374151;border-color:#374151;color:#fff}.scroll-arrow:disabled{cursor:not-allowed;opacity:.3}.assessment-scrollbar-proxy{background-color:initial;flex:1 1;height:20px;min-width:0;overflow-x:auto;overflow-y:hidden;position:relative}.assessment-scrollbar-proxy .scrollbar-content{pointer-events:none}.assessment-scrollbar-proxy::-webkit-scrollbar{height:14px}.assessment-scrollbar-proxy::-webkit-scrollbar-track{background:#f1f1f1;border-radius:6px;margin:0 10px}.assessment-scrollbar-proxy::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#ff8c42,#ff6b35);border:2px solid #f1f1f1;border-radius:6px;-webkit-transition:background .2s ease;transition:background .2s ease}.assessment-scrollbar-proxy::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#ff6b35,#ff4500)}.actions-label{color:#333;font-size:14px;font-weight:400}.assessment-select{background-color:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-body);height:32px;max-width:300px;min-width:200px;padding:var(--spacing-sm) var(--spacing-md);transition:all .15s ease}.assessment-select:focus,.assessment-select:hover{border-color:var(--primary-blue)}.assessment-select:focus{box-shadow:0 0 0 3px #4f46e51a;outline:none}.action-btn{align-items:center;background-color:#fff;border:1px solid var(--primary-blue);border-radius:var(--radius-sm);color:var(--primary-blue);cursor:pointer;display:inline-flex;font-size:var(--font-size-body);font-weight:500;gap:6px;padding:var(--spacing-sm) var(--spacing-md);transition:all .15s ease;white-space:nowrap}.action-btn svg{flex-shrink:0;height:16px;width:16px}.action-btn:hover:not(:disabled){background-color:#eef2ff;border-color:var(--primary-hover);color:var(--primary-hover)}.action-btn:disabled{background-color:var(--gray-100);border-color:var(--gray-300);color:var(--gray-400);cursor:not-allowed;opacity:.6}.action-btn.action-icon-only{gap:0;height:32px;justify-content:center;min-width:32px;padding:var(--spacing-sm)}.action-btn.action-export,.action-btn.action-save{min-width:90px;padding:var(--spacing-sm) var(--spacing-lg)}.book-management{align-items:flex-start;background-color:var(--background-white);border:1px solid var(--border-light);border-radius:var(--radius-md);display:flex;gap:var(--spacing-lg);justify-content:space-between;margin-bottom:var(--spacing-lg);padding:var(--spacing-lg)}.book-info{flex:1 1}.book-info h2{color:var(--text-primary);font-size:var(--font-size-h2);font-weight:600;margin-bottom:var(--spacing-sm)}.book-info h3{color:var(--primary-blue);font-size:var(--font-size-body);font-weight:400;margin-top:var(--spacing-xs)}.book-actions{display:flex;flex-direction:column;gap:var(--spacing-md);min-width:400px}.book-selector,.tracker-selector{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.selector-label{white-space:nowrap}.book-dropdown,.selector-label{color:var(--text-primary);font-size:var(--font-size-body)}.book-dropdown{background-color:var(--background-white);border:1px solid var(--border-color);border-radius:var(--radius-sm);max-width:200px;min-width:150px;padding:var(--spacing-sm) var(--spacing-md)}.book-dropdown:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #4f46e51a;outline:none}.inline-edit{align-items:center;display:inline-flex;gap:var(--spacing-xs)}.inline-edit-input{background-color:var(--background-white);border:1px solid var(--primary-blue);border-radius:var(--radius-sm);box-shadow:0 0 0 2px #4f46e51a;font-size:inherit;font-weight:inherit;padding:var(--spacing-xs) var(--spacing-sm)}.edit-btn{background:#0000!important;border:1px solid var(--border-color)!important;color:var(--text-secondary)!important;margin-left:4px!important;min-width:auto!important;padding:2px 4px!important}.edit-btn:hover{background-color:var(--gray-100)!important;border-color:var(--primary-blue)!important;color:var(--primary-blue)!important}.edit-btn svg{height:12px!important;width:12px!important}.new-book-input{align-items:center;display:inline-flex;gap:var(--spacing-xs)}.new-book-input input{border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-body);min-width:150px;padding:var(--spacing-xs) var(--spacing-sm)}.new-book-input input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #4f46e51a;outline:none}.new-tracker-input{align-items:center;background:linear-gradient(180deg,#fff 0,#f9fafb);border:1px solid var(--gray-300);border-bottom:2px solid #fff;border-radius:8px 8px 0 0;box-shadow:0 -2px 4px #00000014,inset 0 1px 0 #fffc;display:inline-flex;flex-shrink:0;gap:4px;margin-bottom:-2px;padding:8px 12px 10px;position:relative;z-index:2}.new-tracker-input input{background-color:#fff;border:1px solid #4f46e5;border-radius:4px;font-size:var(--font-size-small);font-weight:500;max-width:120px;min-width:100px;padding:4px 8px}.new-tracker-input input:focus{border-color:#4338ca;box-shadow:0 0 0 2px #4f46e526;outline:none}.new-tracker-input .btn{border-radius:4px;font-size:11px;min-width:auto;padding:3px 6px}.new-tracker-input .btn svg{height:10px;width:10px}.tracker-controls{background:#fff;border:2px solid var(--gray-800);border-radius:var(--radius-md);box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.tracker-top-row{flex-wrap:nowrap}.tracker-bottom-row,.tracker-top-row{align-items:center;display:flex;gap:var(--spacing-md)}.tracker-bottom-row{border-top:2px solid var(--gray-200);flex-wrap:wrap;padding-top:var(--spacing-md)}.tracker-tabs-container{align-items:flex-end;background:#f3f4f6;border-bottom:2px solid var(--gray-300);display:flex;flex:1 1;margin-bottom:-2px;max-width:600px;min-width:0;padding:0 80px 0 40px;position:relative}.tracker-selectors{align-items:center;display:flex;flex-shrink:0;gap:var(--spacing-sm)}.tracker-selector-label{color:var(--gray-700);font-size:var(--font-size-small);font-weight:600;white-space:nowrap}.tracker-selector-dropdown{background-color:var(--background-white);border:1px solid var(--gray-300);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:var(--font-size-small);max-width:180px;min-width:120px;padding:6px var(--spacing-sm);transition:all .2s ease}.tracker-selector-dropdown:hover{background-color:var(--gray-50);border-color:var(--gray-400)}.tracker-selector-dropdown:focus{border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e51a;outline:none}.tracker-scroll-btn{align-items:center;background:linear-gradient(180deg,#fff 0,#f3f4f6);border:1px solid var(--gray-300);border-radius:6px;bottom:4px;box-shadow:0 2px 6px #00000026;color:#4f46e5;cursor:pointer;display:flex;font-size:20px;font-weight:700;height:32px;justify-content:center;position:absolute;transition:all .2s ease;width:32px;z-index:3}.tracker-scroll-btn:hover{background:linear-gradient(180deg,#eef2ff 0,#e0e7ff);border-color:#4f46e5;box-shadow:0 3px 8px #4f46e540;color:#4338ca}.tracker-scroll-btn.left{left:0}.tracker-scroll-btn.right{right:0}.tracker-tab{background:linear-gradient(180deg,#e5e7eb 0,#d1d5db);border:1px solid #cbd5e0;border-bottom:none;border-radius:8px 8px 0 0;box-shadow:inset 0 -2px 3px #0000000d;color:#6b7280;cursor:pointer;flex-shrink:0;font-size:var(--font-size-small);font-weight:500;margin-bottom:-2px;min-width:80px;padding:8px 16px 10px;position:relative;text-align:center;transition:all .15s ease;white-space:nowrap}.tracker-tab.active{background:#fff;border-color:var(--gray-300);border-bottom:none;box-shadow:none;color:var(--text-primary);font-weight:600;margin-bottom:-2px;padding:10px 16px 12px;z-index:2}.tracker-tab:hover:not(.active){background:linear-gradient(180deg,#f3f4f6 0,#e5e7eb);border-color:#9ca3af;box-shadow:0 -1px 3px #0000001a,inset 0 -2px 3px #0000000d;color:var(--text-primary)}.parent-badge{align-items:center;background:#ff9800;border-radius:50%;box-shadow:0 1px 3px #0003;color:#fff;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;left:-4px;position:absolute;top:-4px;width:16px;z-index:10}.tracker-tab.dragging{cursor:grabbing!important;opacity:.4;transform:scale(.95)}.tracker-tab{cursor:grab}.tracker-tab:active{cursor:grabbing}.tab-drop-indicator{animation:pulse-indicator .8s ease-in-out infinite;background:#4f46e5;border-radius:2px;box-shadow:0 0 8px #4f46e580;flex-shrink:0;height:32px;margin:0 -1px;width:3px}@keyframes pulse-indicator{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.7;transform:scaleY(.9)}}.tracker-tab.add-tracker{background:linear-gradient(180deg,#e0e7ff 0,#c7d2fe);border-color:#a5b4fc;color:#4f46e5;font-size:16px;font-weight:600;min-width:36px;padding:8px 12px 10px}.tracker-tab.add-tracker:hover{background:linear-gradient(180deg,#c7d2fe 0,#a5b4fc);border-color:#818cf8;color:#4338ca}.new-tracker-input.frozen,.tracker-tab.add-tracker.frozen{background:linear-gradient(180deg,#e0e7ff 0,#c7d2fe);box-shadow:-2px 0 6px #0000001a;position:absolute;right:40px;z-index:5}.new-tracker-input.frozen{background:linear-gradient(180deg,#fff 0,#f9fafb);min-width:180px}.assessment-controls{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.control-group{align-items:center;display:flex;gap:6px;white-space:nowrap}.control-label{color:var(--gray-700);font-size:var(--font-size-small);font-weight:600;margin-right:var(--spacing-xs);white-space:nowrap}.assessment-dropdown{background-color:var(--background-white);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;font-size:var(--font-size-small);max-width:200px;min-width:150px;padding:6px var(--spacing-sm);transition:border-color .2s ease}.assessment-dropdown:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #4f46e51a;outline:none}.book-actions .btn,.tracker-controls .btn{align-items:center;border:1px solid #0000;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:5px;padding:7px 12px;transition:all .15s ease;white-space:nowrap}.book-actions .btn svg,.tracker-controls .btn svg{flex-shrink:0;height:14px;width:14px}.book-actions .btn-primary,.tracker-controls .btn-primary{background-color:#4f46e5;border-color:#4f46e5;box-shadow:0 1px 2px #4f46e51a;color:#fff}.book-actions .btn-primary:hover:not(:disabled),.tracker-controls .btn-primary:hover:not(:disabled){background-color:#4338ca;border-color:#4338ca;box-shadow:0 2px 4px #4f46e533}.book-actions .btn-outline,.tracker-controls .btn-outline{background-color:#fff;border-color:#4f46e5;color:#4f46e5}.book-actions .btn-outline:hover:not(:disabled),.tracker-controls .btn-outline:hover:not(:disabled){background-color:#eef2ff;border-color:#4338ca;color:#4338ca}.book-actions .btn-secondary,.tracker-controls .btn-secondary{background-color:#6b7280;border-color:#6b7280;color:#fff}.book-actions .btn-secondary:hover:not(:disabled),.tracker-controls .btn-secondary:hover:not(:disabled){background-color:#4b5563;border-color:#4b5563}.book-actions .btn-success,.tracker-controls .btn-success{background-color:#059669;border-color:#059669;color:#fff}.book-actions .btn-success:hover:not(:disabled),.tracker-controls .btn-success:hover:not(:disabled){background-color:#047857;border-color:#047857}.book-actions .btn-danger,.tracker-controls .btn-danger{background-color:#dc2626;border-color:#dc2626;color:#fff}.book-actions .btn-danger:hover:not(:disabled),.tracker-controls .btn-danger:hover:not(:disabled){background-color:#b91c1c;border-color:#b91c1c}.book-actions .btn-sm,.tracker-controls .btn-sm{font-size:12px;gap:3px;padding:4px 8px}.book-actions .btn-sm svg,.tracker-controls .btn-sm svg{height:12px;width:12px}.book-actions .btn:disabled,.tracker-controls .btn:disabled{cursor:not-allowed;opacity:.5}.tracker-content{grid-gap:var(--spacing-lg);align-items:start;display:grid;gap:var(--spacing-lg);grid-template-columns:400px 1fr;min-height:500px;overflow:visible}.student-section{background-color:var(--background-white);border:1px solid var(--border-light);border-radius:var(--radius-md);left:0;min-width:300px;overflow:hidden;position:-webkit-sticky;position:sticky;top:0;z-index:10}.student-section-header{grid-gap:var(--spacing-sm);align-items:center;background-color:var(--dark-header);box-sizing:border-box;color:var(--text-white);display:grid;font-size:var(--font-size-body);font-weight:600;gap:var(--spacing-sm);grid-template-columns:auto 1fr auto;height:48px;padding:var(--spacing-md)}.student-section-header .student-menu-container{align-items:center;display:flex;justify-content:center}.student-section-header .header-with-add{align-items:center;display:flex;gap:6px}.student-name-header{align-items:center;display:flex;gap:8px}.btn-remove-all{margin-left:auto}.add-student-icon-btn,.student-name-header .add-student-btn{align-items:center;background:#ffffff1a;border:1px solid #ffffff4d;border-radius:var(--radius-sm);color:var(--text-white);cursor:pointer;display:inline-flex;flex-shrink:0;font-size:13px;font-weight:500;gap:4px;justify-content:center;padding:4px 6px;transition:all .2s ease}.add-student-icon-btn:hover,.student-name-header .add-student-btn:hover{background:#fff3;border-color:#ffffff80;transform:scale(1.05)}.add-student-icon-btn svg,.student-name-header .add-student-btn svg{flex-shrink:0;height:14px;width:14px}.student-name-label{text-align:center}.student-progress-label{min-width:120px;text-align:center;white-space:nowrap}.student-threshold-spacer{background-color:var(--background-white);height:28px}.student-list{padding:0}.student-row{grid-gap:var(--spacing-sm);align-items:center;border-bottom:1px solid var(--border-light);box-sizing:border-box;display:grid;gap:var(--spacing-sm);grid-template-columns:auto 1fr auto;height:48px;line-height:1;padding:var(--spacing-md);transition:background-color .2s ease}.student-row:nth-child(2n){background-color:#f8f9fa}.student-row:nth-child(odd){background-color:#fff}.student-assessment-row:hover,.student-row:hover{background-color:#e3f2fd!important}.student-row:last-child{border-bottom:none}.student-remove{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--error-red);cursor:pointer;display:flex;font-size:var(--font-size-small);height:24px;justify-content:center;line-height:1;padding:var(--spacing-xs);width:24px}.student-name{background-color:var(--background-white);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:text;font-size:var(--font-size-body);padding:var(--spacing-xs) var(--spacing-sm);width:100%}.student-name:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #2563eb1a;outline:none}.student-progress{border-radius:var(--radius-sm);font-size:var(--font-size-small);font-weight:600;min-width:120px;padding:var(--spacing-xs) var(--spacing-sm);text-align:center;white-space:nowrap}.progress-A,.progress-Above,.progress-Exceeds{background-color:#dcfce7;color:#166534}.progress-Average,.progress-B,.progress-Meets{background-color:#dbeafe;color:#1d4ed8}.progress-Below,.progress-Below\ Average,.progress-C{background-color:#fef3c7;color:#d97706}.progress-D,.progress-F,.progress-Fail,.progress-Very\ Below{background-color:#fecaca;color:#dc2626}.progress-Pass{background-color:#dcfce7;color:#166534}.progress-Fail{background-color:#fecaca;color:#dc2626}.progress-100,.progress-80,.progress-85,.progress-90,.progress-95{background-color:#dcfce7;color:#166534}.progress-60,.progress-65,.progress-70,.progress-75,.progress-79{background-color:#dbeafe;color:#1d4ed8}.progress-40,.progress-45,.progress-50,.progress-55,.progress-59{background-color:#fef3c7;color:#d97706}.progress-0,.progress-10,.progress-15,.progress-20,.progress-25,.progress-30,.progress-35,.progress-39,.progress-5{background-color:#fecaca;color:#dc2626}.progress-Custom{background-color:#e0e7ff;color:#3730a3}.assessment-grid-container{flex:1 1;min-width:0;overflow-x:auto;overflow-y:visible;position:relative;scroll-behavior:smooth;transition:box-shadow .3s ease}.assessment-grid-container::-webkit-scrollbar{display:none}.assessment-grid-container{-ms-overflow-style:none;scrollbar-width:none}.assessment-grid{display:flex;flex-wrap:nowrap!important;gap:var(--spacing-md);margin:0;overflow-x:auto;overflow-y:visible;padding:0;position:-webkit-sticky;position:sticky;scroll-behavior:smooth;top:0;z-index:5}.assessment-grid::-webkit-scrollbar{height:10px}.assessment-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:5px}.assessment-grid::-webkit-scrollbar-thumb{background:#888;border-radius:5px}.assessment-grid::-webkit-scrollbar-thumb:hover{background:#555}.assessment-card{background-color:var(--background-white);border:1px solid var(--border-light);border-radius:var(--radius-md);min-width:300px;overflow:visible}.assessment-header{align-items:center;background-color:var(--dark-header);border-radius:var(--radius-md) var(--radius-md) 0 0;box-sizing:border-box;color:var(--text-white);display:flex;height:48px;justify-content:space-between;padding:var(--spacing-md)}.assessment-title{font-size:var(--font-size-body);font-weight:600}.assessment-remove{background:none;border:none;border-radius:var(--radius-sm);color:var(--error-red);cursor:pointer;font-size:var(--font-size-small);padding:var(--spacing-xs)}.assessment-thresholds{background-color:var(--section-header);border-bottom:1px solid var(--border-light);color:var(--text-white);display:grid;grid-template-columns:repeat(4,1fr);min-height:42px}.threshold-header{border-right:1px solid #fff3;font-size:var(--font-size-caption);font-weight:600;justify-content:center;padding:var(--spacing-md);text-align:center}.threshold-header:last-child{border-right:none}.assessment-students{padding:0}.student-assessment-row{border-bottom:1px solid var(--border-light);box-sizing:border-box;display:grid;grid-template-columns:repeat(4,1fr);height:48px;transition:background-color .2s ease}.student-assessment-row:nth-child(2n){background-color:#f8f9fa}.student-assessment-row:nth-child(odd){background-color:#fff}.student-assessment-row:hover{background-color:#e3f2fd!important}.student-assessment-row:last-child{border-bottom:none}.threshold-checkbox{align-items:center;border-right:1px solid var(--border-light);box-sizing:border-box;display:flex;height:48px;justify-content:center;line-height:1;padding:var(--spacing-md)}.threshold-checkbox:last-child{border-right:none}.threshold-checkbox input[type=checkbox]{accent-color:var(--primary-blue);height:16px;width:16px}.threshold-checkbox.temporary-mark{background-color:#fff3e0;position:relative}.threshold-checkbox.temporary-mark input[type=checkbox]{accent-color:#ff9800}.temporary-flag{align-items:center;display:flex;height:14px;justify-content:center;pointer-events:none;position:absolute;right:1px;top:1px;width:14px}.temporary-flag svg{height:12px;width:12px}.context-menu-divider{background-color:#e0e0e0;height:1px;margin:4px 0}.context-menu-item.temporary-active,.context-menu-item.temporary-active .menu-item-icon{color:#ff9800}.delete-modal{max-width:500px;width:90%}.delete-modal-body{max-height:60vh;overflow-y:auto}.delete-section{margin-bottom:20px}.delete-section:last-child{margin-bottom:0}.delete-section-header{color:#666;font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.delete-book-item,.delete-tracker-item{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:4px;display:flex;justify-content:space-between;padding:15px;transition:background-color .2s}.delete-tracker-item{border-bottom:1px solid #e0e0e0;border-radius:0}.delete-tracker-item:first-child{border-radius:4px 4px 0 0}.delete-tracker-item:last-child{border-bottom:none;border-radius:0 0 4px 4px}.delete-tracker-item:only-child{border-radius:4px}.delete-tracker-item:hover{background-color:#f9f9f9}.delete-tracker-list{border:1px solid #e0e0e0;border-radius:4px;overflow:hidden}.delete-item-info{flex:1 1}.delete-item-name{align-items:center;color:#333;display:flex;font-size:15px;font-weight:600;gap:10px;margin-bottom:4px}.delete-item-count{color:#666;font-size:13px}.active-badge{background-color:#2196f3;display:inline-block;font-size:11px;font-weight:700;letter-spacing:.5px;padding:2px 8px}.btn-delete-item{align-items:center;background-color:#fff;border:2px solid #f44336;border-radius:4px;color:#f44336;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:6px 12px;transition:all .2s;white-space:nowrap}.btn-delete-item:hover:not(:disabled){background-color:#f44336;color:#fff}.btn-delete-item:disabled{cursor:not-allowed;opacity:.4}.btn-delete-item svg{flex-shrink:0}.btn-outline-action{align-items:center;background-color:#fff;border:1px solid #3b82f6;border-radius:4px;color:#3b82f6;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:6px 12px;transition:all .15s ease;white-space:nowrap}.btn-outline-action svg{flex-shrink:0}.btn-outline-action:hover{background-color:#eff6ff;border-color:#2563eb;color:#2563eb}.btn-outline-action:disabled{cursor:not-allowed;opacity:.4}.btn-outline-action.add-student-btn{padding:6px 8px 6px 12px}.btn-outline-action.add-student-btn svg{flex-shrink:0;height:16px;width:16px}.add-student-count{background-color:#fff;border:1px solid #d1d5db;border-radius:2px;color:#1f2937;font-size:11px;font-weight:500;height:16px;line-height:16px;padding:0 2px;text-align:center;transition:all .15s ease;width:30px}.add-student-count:hover{border-color:#9ca3af}.add-student-count:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.add-student-count::-webkit-inner-spin-button,.add-student-count::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.add-student-count[type=number]{-moz-appearance:textfield}.btn-outline-settings{border-color:var(--warning-amber);color:var(--warning-amber)}.btn-outline-settings:hover{background-color:#fef3c7;border-color:var(--warning-hover);color:var(--warning-hover)}.btn-outline-delete{border-color:var(--danger-red);color:var(--danger-red)}.btn-outline-delete:hover{background-color:#fee2e2;border-color:var(--danger-hover);color:var(--danger-hover)}.btn-outline-clear{border-color:#f97316;color:#f97316}.btn-outline-clear:hover{background-color:#fff7ed;border-color:#ea580c;color:#ea580c}.books-list{gap:8px}.book-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.book-header{background:#f9fafb;cursor:pointer;gap:12px;padding:12px 16px;transition:background .2s}.book-header:hover{background:#f3f4f6}.expand-icon{color:#6b7280;font-size:12px;transition:transform .2s;-webkit-user-select:none;user-select:none}.expand-icon.expanded{transform:rotate(90deg)}.book-title{align-items:center;color:#1f2937;display:flex;flex:1 1;font-weight:600;gap:8px}.current-badge{background:#3b82f6;border-radius:3px;color:#fff;font-size:10px;font-weight:600;letter-spacing:.5px;padding:2px 6px;text-transform:uppercase}.student-count,.tracker-count{color:#6b7280;font-size:13px;white-space:nowrap}.trackers-list{background:#fff;border-top:1px solid #e5e7eb}.tracker-item{border-bottom:1px solid #f3f4f6;gap:12px;padding:10px 16px 10px 40px}.tracker-item:last-child{border-bottom:none}.tracker-item:hover{background:#fafafa}.tracker-name{align-items:center;color:#374151;display:flex;flex:1 1;gap:8px}.active-badge{background:#10b981;border-radius:3px;color:#fff;font-size:10px;font-weight:600;padding:2px 6px;text-transform:uppercase}.btn-delete-sm{background:#fff;border:1px solid #ef4444;border-radius:4px;color:#ef4444;cursor:pointer;font-size:12px;padding:4px 10px;transition:all .2s;white-space:nowrap}.btn-delete-sm:hover:not(:disabled){background:#ef4444;color:#fff}.btn-delete-sm:disabled{cursor:not-allowed;opacity:.4}.delete-confirmation-banner{background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;padding:16px}.confirmation-buttons{display:flex;gap:8px;justify-content:flex-end}.btn-danger{background:#ef4444;border:1px solid #dc2626;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .2s}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-danger:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .2s}.btn-secondary:hover{background:#e5e7eb}.missing-assessment-badge{align-items:center;background:#1f2937;border-radius:50%;box-shadow:0 1px 3px #0000004d;color:#fff;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;left:-4px;pointer-events:none;position:absolute;top:-4px;width:16px;z-index:10}.threshold-checkbox.highlight-missing{background-color:var(--dark-navy)!important}.missing-status-indicator{align-items:center;border-radius:8px;box-shadow:0 1px 3px #0000004d;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;min-width:16px;position:absolute;right:-4px;top:-4px;z-index:1}.missing-status-indicator.success{background:#10b981;color:#fff}.btn-outline-action.btn-disabled-success{border-color:#10b981;color:#10b981;cursor:not-allowed;opacity:.6}.btn-outline-action.btn-disabled-success:hover{background-color:initial}.btn-outline-action.btn-active-highlight{background-color:#fef3c7;border-color:#f59e0b;color:#d97706}.btn-outline-action.btn-active-highlight:hover{background-color:#fde68a;border-color:#d97706}.student-assessment-row.row-hover-sync,.student-row.row-hover-sync{background-color:#e3f2fd!important}.btn{align-items:center;border:1px solid var(--primary-blue);border-radius:8px;cursor:pointer;display:inline-flex;font-size:var(--font-size-body);font-weight:500;margin-right:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;transition:all .3s ease-out}.btn,.btn-primary{background-color:var(--background-white);color:var(--primary-blue)}.btn-primary{border-color:var(--primary-blue)}.btn-primary:hover:not(:disabled){background-color:#eef2ff;border-color:var(--primary-hover);box-shadow:0 8px 16px #4f46e533;color:var(--primary-hover);transform:translateY(-2px)}.btn-success{background-color:var(--background-white);border-color:var(--success-green);color:var(--success-green)}.btn-success:hover:not(:disabled){background-color:#ecfdf5;border-color:var(--success-hover);box-shadow:0 8px 16px #05966933;color:var(--success-hover);transform:translateY(-2px)}.btn-warning{background-color:var(--background-white);border-color:var(--warning-amber);color:var(--warning-amber)}.btn-warning:hover:not(:disabled){background-color:#fef3c7;border-color:var(--warning-hover);box-shadow:0 8px 16px #d9770633;color:var(--warning-hover);transform:translateY(-2px)}.btn-danger{background-color:var(--background-white);border-color:var(--danger-red);color:var(--danger-red)}.btn-danger:hover:not(:disabled){background-color:#fee2e2;border-color:var(--danger-hover);box-shadow:0 8px 16px #dc262633;color:var(--danger-hover);transform:translateY(-2px)}.btn-secondary{background-color:var(--background-white);border-color:var(--gray-500);color:var(--gray-500)}.btn-secondary:hover:not(:disabled){background-color:var(--gray-100);border-color:var(--gray-600);box-shadow:0 8px 16px #6b728026;color:var(--gray-600);transform:translateY(-2px)}.btn:hover:not(:disabled){background-color:#eef2ff;border-color:var(--primary-hover);color:var(--primary-hover)}.btn:disabled{background-color:var(--gray-100);border-color:var(--gray-300);color:var(--gray-400);cursor:not-allowed;opacity:.6}.toggle-row{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:var(--spacing-sm) 0}.toggle-row:last-child{border-bottom:none}.toggle-label{color:var(--text-primary);font-size:var(--font-size-body)}.toggle-switch{background-color:#d1d5db;border-radius:12px;cursor:pointer;height:24px;position:relative;transition:background-color .2s;width:44px}.toggle-switch.active{background-color:var(--primary-blue)}.toggle-switch:after{background-color:var(--text-white);border-radius:50%;content:"";height:20px;left:2px;position:absolute;top:2px;transition:transform .2s;width:20px}.toggle-switch.active:after{transform:translateX(20px)}.custom-dropdown{background-color:var(--background-white);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--font-size-body);padding:var(--spacing-sm) var(--spacing-md);width:100%}.custom-dropdown:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #4f46e51a;outline:none}.assessment-creator,.assessment-form{max-width:100%;width:100%}.form-section{background-color:var(--background-white);border:2px solid var(--gray-800);border-radius:16px;box-shadow:0 10px 20px #0f172a14;margin-bottom:var(--spacing-md);overflow:hidden;padding:0}.section-header{align-items:center;background-color:var(--dark-header);border-bottom:none;color:var(--text-white);display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:space-between;margin-bottom:0;padding:var(--spacing-sm) var(--spacing-md)}.section-header h2{color:var(--text-white)!important;font-size:15px;font-weight:600;margin:0}.section-header p{color:#ffffffd9!important;font-size:var(--font-size-caption);font-weight:400;margin:0}.section-header .btn{background-color:initial;border-color:#ffffff4d;color:var(--text-white);font-size:12px;padding:4px 10px}.section-header .btn:hover:not(:disabled){background-color:#ffffff1a;border-color:#ffffff80;color:var(--text-white)}.form-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:1fr 1fr;padding:var(--spacing-md)}.form-section>.form-group{padding:0 var(--spacing-md) var(--spacing-md) var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{color:var(--gray-700);font-size:13px;font-weight:600;margin-bottom:2px}.form-group input,.form-group select,.form-group textarea{background-color:var(--background-white);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:var(--font-size-small);min-height:34px;padding:7px 10px;resize:vertical;transition:border-color .2s ease}.form-group textarea{min-height:70px}.form-group input,.form-group select{height:34px;min-height:0;min-height:auto}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #4f46e51a;outline:none}.form-group input:disabled{background-color:var(--background-surface);color:var(--text-secondary);cursor:not-allowed}.char-count{color:var(--text-secondary);font-size:var(--font-size-caption);text-align:right}.thresholds-container{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.threshold-card{background-color:var(--background-white);border:1px solid var(--gray-300);border-radius:var(--radius-sm);overflow:hidden}.threshold-header{align-items:center;background-color:var(--gray-700);color:var(--text-white);display:flex;justify-content:space-between;padding:6px var(--spacing-sm)}.threshold-header h4{font-size:13px;font-weight:600;margin:0}.remove-threshold{background:none;border:none;border-radius:var(--radius-sm);color:#fca5a5;cursor:pointer;font-size:12px;padding:4px 6px;transition:all .15s ease}.remove-threshold:hover{background-color:#ef444433;color:#fee2e2}.threshold-fields{grid-gap:var(--spacing-sm);align-items:start;background-color:var(--background-white);display:grid;gap:var(--spacing-sm);grid-template-columns:180px 150px 1fr 1fr;padding:var(--spacing-sm)}.threshold-row-1,.threshold-row-2{display:contents}.mark-group{min-width:160px}.mark-group label{color:var(--gray-600);font-size:12px;white-space:nowrap}.mark-group input{font-size:13px;height:32px;padding:6px 8px}.point-value-group{display:flex;flex-direction:column;gap:4px;min-width:130px}.point-value-group label{color:var(--gray-600);font-size:12px;white-space:nowrap}.point-value-input{align-items:center;background-color:var(--gray-50);border:1px solid var(--border-color);border-radius:var(--radius-sm);display:flex;font-size:12px;gap:4px;height:32px;padding:4px 8px;white-space:nowrap}.point-value-input input{background:#0000;border:none;color:var(--primary-blue);font-size:13px;font-weight:600;padding:2px;width:45px}.point-value-input input:focus{outline:none}.point-value-input small{color:var(--gray-500);font-size:11px;font-weight:500;white-space:nowrap}.comment-group{min-width:200px}.comment-group label{color:var(--gray-600);font-size:12px}.comment-group textarea{font-size:12px;height:32px;min-height:32px!important;padding:6px 8px;resize:vertical}.target-group{min-width:180px}.target-group label{color:var(--gray-600);font-size:12px;white-space:nowrap}.target-group select{font-size:12px;height:32px;padding:6px 8px}.form-actions{background-color:var(--gray-50);border-top:1px solid var(--border-light);gap:var(--spacing-sm);justify-content:flex-end;margin:0;padding:var(--spacing-md)}.gpa-conversions{background-color:var(--background-white);border:1px solid var(--border-light);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:4px;margin-top:4px;padding:8px}.gpa-conversions.auto{background-color:#f8f9fa}.gpa-conversion-item{align-items:center;display:flex;gap:8px;padding:4px 0}.mark-label{color:var(--text-primary);font-size:12px;font-weight:500;min-width:60px}.gpa-input{border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:12px;padding:4px 6px;text-align:center;width:60px}.gpa-input:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #2563eb1a;outline:none}.gpa-value{background-color:#f1f5f9;border-radius:var(--radius-sm);color:var(--text-secondary);font-weight:500;min-width:80px;padding:6px 8px;text-align:center}.btn-google{align-items:center;background:#fff;border:1px solid #ddd;border-radius:8px;color:#444;cursor:pointer;display:flex;font-size:1rem;font-weight:500;justify-content:center;margin-top:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.btn-google:hover:not(:disabled){background:#f8f9fa;border-color:#ccc;box-shadow:0 2px 4px #0000001a}.btn-google:disabled{cursor:not-allowed;opacity:.6}.auth-layout{grid-gap:clamp(32px,6vw,64px);align-items:stretch;background:radial-gradient(circle at 20% 20%,#4f46e51f,#0000 50%),radial-gradient(circle at 80% 10%,#2563eb1a,#0000 45%),linear-gradient(180deg,#f1f5f9e6,#e2e8f0b3);display:grid;gap:clamp(32px,6vw,64px);grid-template-columns:minmax(320px,1.2fr) minmax(320px,1fr);min-height:calc(100vh - var(--nav-height));padding:clamp(40px,6vw,80px)}.auth-intro{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd1;border:1px solid #94a3b82e;border-radius:28px;box-shadow:0 25px 60px #0f172a26;display:flex;flex-direction:column;gap:clamp(20px,3vw,32px);padding:clamp(32px,5vw,48px)}.intro-badge{align-items:center;background:#4f46e51f;border-radius:999px;color:#4f46e5;display:inline-flex;font-size:.85rem;font-weight:600;gap:8px;letter-spacing:.08em;padding:8px 14px;text-transform:uppercase}.auth-intro h1{color:var(--dark-navy);font-size:clamp(2rem,3.5vw,2.8rem);margin:0}.auth-intro p{color:var(--text-secondary);font-size:1.05rem;line-height:1.7;margin:0;max-width:520px}.intro-highlights{grid-gap:16px;display:grid;gap:16px}.highlight-card{background:#f8fafcb3;border:1px solid #94a3b833;border-radius:16px;box-shadow:0 12px 24px #94a3b833;padding:16px 18px}.highlight-card h3{color:var(--dark-navy);font-size:1.1rem;margin:0 0 6px}.highlight-card p{line-height:1.5;margin:0}.highlight-card p,.intro-cta{color:var(--text-secondary);font-size:.95rem}.intro-cta{align-items:center;display:flex;gap:10px}.intro-cta a{color:#4f46e5;font-weight:600}.auth-panel{align-items:center;display:flex;justify-content:center}.auth-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;border:1px solid #94a3b833;border-radius:24px;box-shadow:0 25px 50px #0f172a40;max-width:440px;padding:clamp(32px,5vw,48px);width:100%}.auth-header h2{color:var(--dark-navy);font-size:1.8rem;margin:0}.auth-header p{color:var(--text-secondary);font-size:.95rem;margin:6px 0 0}.auth-form{grid-gap:18px;display:grid;gap:18px;margin-top:28px}.auth-form .form-group input{background:#f8fafcd9;border:1px solid #94a3b873;border-radius:12px;font-size:.95rem;padding:12px 14px}.auth-form .form-group input:focus{background:#fff;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e52e}.auth-divider{color:var(--text-secondary);font-size:.85rem;font-weight:600;letter-spacing:.12em;margin:24px 0;position:relative;text-transform:uppercase}.auth-divider:after,.auth-divider:before{background:var(--border-light);height:1px;position:absolute;top:50%;width:40%}.auth-divider:before{left:0}.auth-divider:after{right:0}.auth-divider span{background:#0000;display:inline-block;padding:0 12px;position:relative}.alt-actions{grid-gap:12px;display:grid;gap:12px}.btn-demo{background:#111f35e6;border:1px solid #111f35e6;transition:transform .2s,box-shadow .2s}.btn-demo:hover:not(:disabled){box-shadow:0 10px 25px #111f3540;transform:translateY(-1px)}.btn-demo:disabled{cursor:default;opacity:.8}.demo-hint{font-size:.85rem;margin:12px 0 0}.auth-footer,.demo-hint{color:var(--text-secondary);text-align:center}.auth-footer{font-size:.95rem;margin-top:28px}.auth-footer a{color:#4f46e5;font-weight:600}@media (max-width:980px){.auth-layout{grid-template-columns:1fr;padding:48px clamp(24px,6vw,40px)}.auth-panel{order:-1}}@media (max-width:640px){.auth-layout{padding:32px 20px}.auth-card,.auth-intro{padding:28px}.intro-highlights{grid-template-columns:1fr}.auth-form{gap:14px}}.btn-demo{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 6px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;justify-content:center;padding:.75rem 1.5rem;transition:all .3s ease}.btn-demo:hover:not(:disabled){box-shadow:0 6px 12px #667eea66;transform:translateY(-2px)}.btn-demo:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.auth-divider{align-items:center;color:#666;display:flex;font-size:.9rem;margin:1.5rem 0;text-align:center}.auth-divider:after,.auth-divider:before{border-bottom:1px solid #ddd;content:"";flex:1 1}.auth-divider span{font-weight:500;padding:0 1rem}.auth-callback-status{padding:3rem 2rem;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#4caf50;border-top:4px solid var(--primary-blue,#4caf50);height:48px;margin:0 auto 1.5rem;width:48px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.success-icon{background:#4caf50}.error-icon,.success-icon{align-items:center;animation:scaleIn .3s ease;border-radius:50%;color:#fff;display:flex;font-size:2.5rem;height:64px;justify-content:center;margin:0 auto 1.5rem;width:64px}.error-icon{background:#f44336}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.auth-callback-status h2{color:#333;color:var(--text-primary,#333);font-size:1.5rem;margin-bottom:.75rem}.auth-callback-status p{color:#666;color:var(--text-secondary,#666);font-size:1rem}.user-menu{position:relative}.user-menu-trigger{align-items:center;background:#f5f5f5;background:var(--color-grey-light,#f5f5f5);border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:8px;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.user-menu-trigger:hover{background:#e3f2fd;border-color:#4caf50;border-color:var(--color-primary,#4caf50)}.user-avatar{align-items:center;background:linear-gradient(135deg,#4caf50,#2196f3);background:linear-gradient(135deg,var(--color-primary,#4caf50),var(--color-secondary,#2196f3));border-radius:50%;color:#fff;display:flex;font-size:.85rem;font-weight:600;height:32px;justify-content:center;width:32px}.user-name{color:#333;color:var(--color-text,#333);font-weight:500}.dropdown-arrow{color:#666;color:var(--color-text-light,#666);font-size:.7rem;transition:transform .2s ease}.user-menu-dropdown{animation:slideDown .2s ease;background:#fff;border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:12px;box-shadow:0 8px 24px #0000001f;min-width:280px;overflow:hidden;position:absolute;right:0;top:calc(100% + .5rem);z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{background:linear-gradient(135deg,#4caf50,#2196f3);background:linear-gradient(135deg,var(--color-primary,#4caf50),var(--color-secondary,#2196f3));padding:1.25rem}.user-info{gap:1rem}.user-avatar-large,.user-info{align-items:center;display:flex}.user-avatar-large{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff4d;border:2px solid #ffffff80;border-radius:50%;color:#fff;font-size:1.1rem;font-weight:600;height:48px;justify-content:center;width:48px}.user-details{color:#fff;flex:1 1}.user-full-name{font-size:1rem;font-weight:600;margin-bottom:.25rem}.user-email{font-size:.85rem;opacity:.9}.dropdown-divider{background:#e0e0e0;background:var(--border-color,#e0e0e0);height:1px;margin:.5rem 0}.dropdown-item{align-items:center;background:none;border:none;color:#333;color:var(--color-text,#333);cursor:pointer;display:flex;font-size:.95rem;gap:.75rem;padding:.875rem 1.25rem;text-align:left;transition:background .15s ease;width:100%}.dropdown-item:hover{background:#f5f5f5;background:var(--color-grey-light,#f5f5f5)}.dropdown-item.logout{color:#f44336;color:var(--color-danger,#f44336)}.dropdown-item.logout:hover{background:#ffebee}.dropdown-item.login-real{color:#4caf50;color:var(--color-primary,#4caf50)}.dropdown-item.login-real:hover{background:#4caf501a}.dropdown-item.login-google{color:#4285f4}.dropdown-item.login-google:hover{background:#4285f41a}.dropdown-item.login-google .dropdown-icon{align-items:center;display:flex}.dropdown-icon{font-size:1.1rem}.login-button{background:#4caf50;background:var(--color-primary,#4caf50);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1.25rem;transition:all .2s ease}.login-button:hover{background:#45a049;background:var(--color-primary-dark,#45a049);transform:translateY(-1px)}.profile-page{background:#0000;min-height:100vh;padding:2rem}.profile-container{margin:0 auto;max-width:1200px}.profile-header{margin-bottom:2rem}.profile-header h1{color:#333;color:var(--color-text,#333);font-size:2rem;margin-bottom:.5rem}.profile-header p{color:#666;color:var(--color-text-light,#666);font-size:1rem}.profile-tabs{border-bottom:2px solid #e0e0e0;border-bottom:2px solid var(--border-color,#e0e0e0);display:flex;gap:.5rem;margin-bottom:2rem;overflow-x:auto}.tab-button{background:none;border:none;border-bottom:3px solid #0000;color:#666;color:var(--color-text-light,#666);cursor:pointer;font-size:1rem;padding:1rem 1.5rem;transition:all .2s ease;white-space:nowrap}.tab-button:hover{background:#4caf500d}.tab-button.active,.tab-button:hover{color:#4caf50;color:var(--color-primary,#4caf50)}.tab-button.active{border-bottom-color:#4caf50;border-bottom-color:var(--color-primary,#4caf50);font-weight:600}.profile-content{background:#fff;border-radius:16px;box-shadow:0 10px 20px #0f172a14;padding:2rem}.profile-section h2{color:#333;color:var(--color-text,#333);font-size:1.5rem;margin-bottom:1.5rem}.profile-card{align-items:center;background:linear-gradient(135deg,#4caf50,#2196f3);background:linear-gradient(135deg,var(--color-primary,#4caf50),var(--color-secondary,#2196f3));border-radius:12px;color:#fff;display:flex;gap:1.5rem;margin-bottom:2rem;padding:2rem}.profile-avatar-large{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff4d;border:3px solid #ffffff80;border-radius:50%;display:flex;font-size:2rem;font-weight:600;height:80px;justify-content:center;width:80px}.profile-info h3{font-size:1.5rem;margin-bottom:.5rem}.profile-email{margin-bottom:.25rem;opacity:.9}.profile-member-since{font-size:.9rem;opacity:.8}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:2rem}.stat-card{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:16px;padding:1.5rem;text-align:center;transition:all .3s ease-out}.stat-card:hover{box-shadow:0 10px 20px #0f172a1f;transform:translateY(-4px);transition:all .3s ease-out}.stat-icon{font-size:2rem;margin-bottom:.75rem}.stat-value{color:#4caf50;color:var(--color-primary,#4caf50);font-size:2rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:#666;color:var(--color-text-light,#666);font-size:.9rem}.books-list{display:flex;flex-direction:column;gap:1.5rem}.book-card{border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:12px;padding:1.5rem;transition:all .2s ease}.book-card:hover{box-shadow:0 4px 12px #00000014}.book-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.book-header h3{color:#333;color:var(--color-text,#333);font-size:1.25rem}.book-meta{color:#666;color:var(--color-text-light,#666);font-size:.9rem}.trackers-list{border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color,#e0e0e0);display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;padding-top:1rem}.tracker-item{align-items:center;background:#f5f5f5;background:var(--color-grey-light,#f5f5f5);border-radius:8px;display:flex;justify-content:space-between;padding:.75rem}.tracker-name{color:#333;color:var(--color-text,#333);font-weight:500}.tracker-badge{background:#4caf50;background:var(--color-primary,#4caf50);border-radius:12px;color:#fff;font-size:.85rem;padding:.25rem .75rem}.presets-container{display:flex;flex-direction:column;gap:2rem}.preset-group h3{color:#333;color:var(--color-text,#333);font-size:1.25rem;margin-bottom:.5rem}.preset-description{color:#666;color:var(--color-text-light,#666);margin-bottom:1.5rem}.preset-list{display:flex;flex-direction:column;gap:1rem}.preset-item{border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:8px;padding:1rem}.preset-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.preset-name{color:#333;color:var(--color-text,#333);font-weight:600}.preset-type{background:#2196f3;background:var(--color-secondary,#2196f3);border-radius:12px;color:#fff;font-size:.85rem;padding:.25rem .75rem}.preset-details{color:#666;color:var(--color-text-light,#666);display:flex;font-size:.9rem;gap:1rem}.preset-info-box{background:#f5f5f5;background:var(--color-grey-light,#f5f5f5);border-radius:8px;text-align:center}.preset-info-box p{color:#666;color:var(--color-text-light,#666);margin-bottom:1rem}.security-card{border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.security-card h3{color:#333;color:var(--color-text,#333);font-size:1.25rem;margin-bottom:.5rem}.security-card p{color:#666;color:var(--color-text-light,#666);margin-bottom:1.5rem}.security-card.danger-zone{background:#ffebee;border-color:#f44336;border-color:var(--color-danger,#f44336)}.password-form{max-width:400px}.password-form .form-group{margin-bottom:1.25rem}.password-form label{color:#333;color:var(--color-text,#333);display:block;font-weight:500;margin-bottom:.5rem}.password-form input{border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:8px;font-size:1rem;padding:.75rem;width:100%}.password-form input:focus{border-color:#4caf50;border-color:var(--color-primary,#4caf50);outline:none}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.empty-state{color:#666;color:var(--color-text-light,#666);padding:3rem 1rem}.empty-state p{margin-bottom:1.5rem}.empty-message{color:#666;color:var(--color-text-light,#666);font-style:italic}.sync-message{border-radius:8px;font-weight:500;margin-bottom:1.5rem;padding:1rem 1.5rem}.sync-message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.sync-message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.sync-overview{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.sync-actions-card,.sync-info-card{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:12px;padding:1.5rem}.sync-info-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.sync-info-header h3{color:#333;color:var(--color-text,#333);font-size:1.25rem;margin:0}.sync-badge{border-radius:16px;font-size:.85rem;font-weight:600;padding:.375rem .875rem}.sync-badge.synced{background:#d4edda;color:#155724}.sync-badge.not-synced{background:#fff3cd;color:#856404}.sync-details{display:flex;flex-direction:column;gap:.75rem}.sync-detail-item{background:#f5f5f5;background:var(--color-grey-light,#f5f5f5);border-radius:8px;display:flex;justify-content:space-between;padding:.75rem}.sync-actions-card h3{color:#333;color:var(--color-text,#333);font-size:1.25rem;margin-bottom:.75rem}.sync-description{color:#666;color:var(--color-text-light,#666);font-size:.95rem;margin-bottom:1.5rem}.sync-buttons{display:flex;gap:1rem;margin-bottom:1.5rem}.sync-btn{align-items:center;display:flex;flex:1 1;font-size:1rem;gap:.5rem;justify-content:center;padding:.875rem 1.5rem}.sync-btn:disabled{cursor:not-allowed;opacity:.6}.sync-help{background:#f5f5f5;background:var(--color-grey-light,#f5f5f5);border-radius:8px;font-size:.9rem;padding:1rem}.sync-help p{color:#666;color:var(--color-text-light,#666);margin:.5rem 0}.sync-help strong{color:#333;color:var(--color-text,#333)}.cloud-data-summary{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:12px;padding:1.5rem}.cloud-data-summary h3{color:#333;color:var(--color-text,#333);font-size:1.25rem;margin-bottom:1.5rem}.cloud-stats{grid-gap:1rem;display:grid;gap:1rem}.cloud-stat-item{align-items:center;background:#f5f5f5;background:var(--color-grey-light,#f5f5f5);border-radius:8px;display:flex;gap:1rem;padding:1rem;transition:all .2s ease}.cloud-stat-item:hover{background:#e8f5e9;transform:translateX(4px)}.cloud-stat-icon{align-items:center;background:#fff;border-radius:8px;display:flex;font-size:2rem;height:48px;justify-content:center;width:48px}.cloud-stat-info{flex:1 1}.cloud-stat-label{color:#666;color:var(--color-text-light,#666);font-size:.9rem;margin-bottom:.25rem}.cloud-stat-value{color:#333;color:var(--color-text,#333);font-size:1.1rem;font-weight:600}.cloud-count{color:#4caf50;color:var(--color-primary,#4caf50);font-weight:500}.preset-section{border-bottom:2px solid #e0e0e0;border-bottom:2px solid var(--border-color,#e0e0e0);margin-bottom:3rem;padding-bottom:2rem}.preset-section:last-of-type{border-bottom:none}.preset-section-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.preset-section-header h3{color:#333;color:var(--color-text,#333);font-size:1.3rem;margin-bottom:.5rem}.btn-sm{font-size:.9rem;padding:.5rem 1rem}.preset-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.preset-card{background:#fff;border:1px solid #e0e0e0;border:1px solid var(--border-color,#e0e0e0);border-radius:12px;padding:1.5rem;transition:all .2s ease}.preset-card:hover{border-color:#4caf50;border-color:var(--color-primary,#4caf50);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.preset-card-header{align-items:flex-start;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color,#e0e0e0);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.preset-card-header h4{color:#333;color:var(--color-text,#333);flex:1 1;font-size:1.1rem;margin:0}.btn-icon{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem;transition:transform .2s ease}.btn-icon:hover{transform:scale(1.2)}.btn-danger-icon:hover{filter:brightness(.8)}.preset-card-body{display:flex;flex-direction:column;gap:.75rem}.preset-detail-row{align-items:center;background:#f5f5f5;background:var(--color-grey-light,#f5f5f5);border-radius:6px;display:flex;justify-content:space-between;padding:.5rem}.detail-label{color:#333;color:var(--color-text,#333);font-size:.9rem;font-weight:600}.detail-value{color:#666;color:var(--color-text-light,#666);font-size:.9rem;text-align:right}.progress-thresholds-list{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.threshold-item{align-items:center;background:#f5f5f5;background:var(--color-grey-light,#f5f5f5);border-radius:6px;display:flex;gap:.75rem;padding:.5rem}.threshold-color-dot{border:2px solid #fff;border-radius:50%;box-shadow:0 1px 3px #0003;flex-shrink:0;height:16px;width:16px}.threshold-name{color:#333;color:var(--color-text,#333);font-weight:600;min-width:30px}.threshold-range{color:#666;color:var(--color-text-light,#666);font-size:.85rem;margin-left:auto}.empty-state{background:#f5f5f5;background:var(--color-grey-light,#f5f5f5);border:2px dashed #e0e0e0;border:2px dashed var(--border-color,#e0e0e0);border-radius:12px;padding:3rem 1.5rem;text-align:center}.empty-state p{color:#666;color:var(--color-text-light,#666);font-size:1.1rem;margin-bottom:.5rem}.empty-hint{color:#999!important;color:var(--color-text-light,#999)!important;font-size:.9rem!important;font-style:italic}.preset-info-box{background:#e3f2fd;border-left:4px solid #2196f3;border-left:4px solid var(--color-secondary,#2196f3);border-radius:12px;padding:1.5rem}.preset-info-box h4{color:#333;color:var(--color-text,#333);font-size:1rem;margin-bottom:1rem}.preset-info-box ul{list-style:none;margin:0;padding:0}.preset-info-box li{color:#666;color:var(--color-text-light,#666);font-size:.95rem;padding:.5rem 0}.preset-info-box strong{color:#333;color:var(--color-text,#333)}@media (max-width:768px){.profile-page{padding:1rem}.profile-card{flex-direction:column;text-align:center}.stats-grid{gap:1rem;grid-template-columns:repeat(2,1fr)}.tab-button{font-size:.9rem;padding:.875rem 1rem}.user-name{display:none}.sync-overview{grid-template-columns:1fr}.sync-buttons{flex-direction:column}.sync-btn{width:100%}.preset-grid{grid-template-columns:1fr}.preset-section-header{align-items:stretch;flex-direction:column}.preset-section-header button{width:100%}.user-menu-dropdown{border-radius:0 0 0 12px;left:auto;max-width:320px;min-width:260px;position:fixed;right:0;top:60px;top:var(--nav-height,60px)}.user-menu-trigger{gap:.4rem;padding:.4rem .75rem}.dropdown-header{padding:1rem}.user-avatar-large{height:40px;width:40px}.user-full-name{font-size:.95rem}.user-email{font-size:.8rem}.dropdown-item{font-size:.9rem;padding:.75rem 1rem}}@media (max-width:480px){.user-menu-dropdown{max-width:280px;min-width:240px}.dropdown-header{padding:.875rem}.user-info{gap:.75rem}.user-avatar-large{font-size:.85rem;height:36px;width:36px}.user-full-name{font-size:.9rem}.user-email{font-size:.75rem}.dropdown-item{font-size:.85rem;gap:.6rem;padding:.625rem .875rem}.dropdown-icon{font-size:1rem}}.student-details{border-top:1px solid #94a3b833;margin-top:1rem;padding-top:1rem}.student-details h4{color:var(--slate-900);font-size:.95rem;font-weight:600;margin-bottom:.75rem}.student-chip-grid{display:flex;flex-wrap:wrap;gap:.75rem}.student-chip{align-items:center;background:#94a3b81f;border-radius:12px;display:flex;flex:1 1 220px;gap:.75rem;max-width:260px;min-width:180px;padding:.6rem .75rem;transition:transform .18s ease,box-shadow .18s ease}.student-chip:hover{box-shadow:0 4px 12px #0f172a1f;transform:translateY(-2px)}.student-chip-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;font-weight:600;height:40px;justify-content:center;letter-spacing:.5px;width:40px}.student-chip-content{display:flex;flex-direction:column;gap:.15rem}.student-chip-content .student-name{color:var(--slate-900);font-weight:600}.student-chip-content .student-meta{color:var(--slate-600);font-size:.8rem}@media (max-width:768px){.student-chip-grid{gap:.65rem}.student-chip{flex:1 1 180px;max-width:none;min-width:150px;padding:.55rem .65rem}.student-chip-avatar{font-size:.85rem;height:36px;width:36px}}.student-row td{background:#f1f5f9d9;border-radius:16px;padding:1.25rem 1.5rem}.student-row td>.student-details{margin-top:0}@media (max-width:1400px){.report-workspace{grid-template-columns:1fr 1fr}.help-panel{height:85vh;width:95vw}}@media (max-width:1024px){.tracker-content{gap:var(--spacing-md);grid-template-columns:1fr}.assessment-grid{overflow-x:auto}.assessment-card{min-width:300px}.feature-grid,.report-workspace{grid-template-columns:1fr}.help-sidebar{width:160px}}@media (max-width:768px){.main-content{padding:var(--spacing-md)}.book-management{align-items:stretch;flex-direction:column;gap:var(--spacing-sm)}.tracker-controls{flex-direction:column;gap:var(--spacing-md)}.master-log-controls{align-items:stretch;flex-direction:column;gap:var(--spacing-xs)}.btn-icon{margin-right:var(--spacing-xs)}.help-panel{border-radius:0;height:100vh;width:100vw}.help-panel-body{flex-direction:column}.help-sidebar{flex-direction:row;height:120px;overflow-x:auto;width:100%}.help-nav-item{flex-direction:column;min-width:120px;padding:var(--spacing-sm)}.help-nav-icon{margin-bottom:var(--spacing-xs);margin-right:0}.assessments-data-table{font-size:var(--font-size-small)}.assessments-data-table td,.assessments-data-table th{padding:var(--spacing-sm)}.form-grid{gap:var(--spacing-md);grid-template-columns:1fr}.threshold-fields{gap:var(--spacing-xs);grid-template-columns:1fr}.threshold-row-1,.threshold-row-2{display:block}.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%}.assessment-form{padding:0 var(--spacing-md)}.form-section{padding:var(--spacing-md)}.filter-row{align-items:stretch;flex-direction:column}.filter-group{min-width:0;min-width:auto}.clear-filters-btn{margin-top:var(--spacing-md)}.report-header{align-items:flex-start;flex-direction:column;gap:15px}.workflow-controls{align-self:stretch}.dual-settings-container{grid-template-columns:1fr}.table-wrapper{font-size:14px}.report-table td,.report-table th{padding:6px 8px}}@media (max-width:1500px){.dual-settings-container,.report-layout-side{grid-template-columns:1fr}.comments-section{border-bottom:1px solid #dee2e6;border-right:none;margin-bottom:15px;padding-bottom:15px;padding-right:0}.targets-section{padding-left:0}.settings-panel{max-height:none;overflow-y:visible}}@media (max-width:480px){h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.1rem}.btn{font-size:14px;padding:10px 16px}.btn-sm{font-size:12px;padding:6px 12px}input,select,textarea{font-size:16px!important}.modal,.overlay-content,.popup{border-radius:0;height:100vh;margin:0;max-width:100vw!important;width:100vw!important}table{font-size:12px}td,th{padding:6px!important}.card{padding:12px}.main-content{padding:8px!important}.flex-container{flex-direction:column}}@media (max-height:500px) and (orientation:landscape){.modal,.popup{max-height:95vh;overflow-y:auto}.header,.main-navigation{padding:8px 12px}}@media (hover:none) and (pointer:coarse){.btn,a,button{min-height:44px;min-width:44px}:hover{opacity:1}.scroll-container{-webkit-overflow-scrolling:touch}}.landing-page{background:var(--gray-50);margin-top:calc(var(--nav-height)*-1);min-height:100vh;padding-top:var(--nav-height)}.landing-hero-split{grid-gap:60px;align-items:center;background:linear-gradient(135deg,var(--gray-800) 0,var(--gray-700) 100%);display:grid;gap:60px;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1400px;padding:60px 40px}.hero-left{color:#fff}.logo-section{margin-bottom:24px}.hero-logo{filter:brightness(0) invert(1);height:70px;opacity:.95;width:auto}.hero-left h1{color:#fff;font-size:42px;font-weight:700;line-height:1.2;margin-bottom:20px}.hero-tagline{color:#fff;font-size:18px;line-height:1.6;margin-bottom:32px;opacity:.95}.hero-buttons{display:flex;flex-wrap:wrap;gap:16px}.btn-hero-primary,.btn-hero-secondary{border:none;border-radius:var(--radius-md);cursor:pointer;font-family:inherit;font-size:16px;font-weight:600;padding:14px 32px;transition:all .2s ease}.btn-hero-primary{background:#ff8c42;border:none;color:#fff}.btn-hero-primary:hover{background:#ff7a2e;box-shadow:0 8px 16px #ff8c4266;transform:translateY(-2px)}.btn-hero-secondary{background:#ffffff26;border:1px solid #ffffff4d;color:#fff}.btn-hero-secondary:hover{background:#ffffff40;transform:translateY(-2px)}.hero-right{display:flex;justify-content:center}.hero-report-showcase{background:#fff;border-radius:var(--radius-lg);box-shadow:0 20px 40px #0003;max-width:500px;overflow:hidden;width:100%}.hero-report-header{align-items:center;background:#f8f9fa;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:16px 20px}.hero-report-title{color:var(--text-primary);font-size:16px;font-weight:600}.hero-export-btns{display:flex;gap:8px}.hero-export-btn{background:var(--primary-blue);border:none;border-radius:var(--radius-sm);color:#fff;cursor:default;font-size:12px;font-weight:600;padding:6px 14px}.hero-report-body{display:grid;grid-template-columns:140px 1fr;min-height:280px}.hero-settings-panel{background:var(--gray-50);border-right:1px solid var(--gray-200);display:flex;flex-direction:column;gap:20px;padding:20px 12px}.hero-setting-item{display:flex;flex-direction:column;gap:8px}.hero-setting-label{color:var(--gray-600);font-size:12px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.hero-toggle{background:var(--gray-300);border-radius:12px;height:24px;position:relative;transition:background .2s;width:44px}.hero-toggle:after{background:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;content:"";height:18px;left:3px;position:absolute;top:3px;transition:left .2s;width:18px}.hero-toggle.on{background:var(--primary-blue)}.hero-toggle.on:after{left:23px}.hero-report-preview{background:#fff;padding:20px}.hero-student-name{border-bottom:2px solid var(--gray-200);color:var(--text-primary);font-size:17px;font-weight:700;margin-bottom:16px;padding-bottom:12px}.hero-assessment-item{align-items:center;border-bottom:1px solid var(--gray-100);color:var(--text-primary);display:flex;font-size:14px;justify-content:space-between;padding:10px 0}.hero-grade-a,.hero-grade-b{align-items:center;border-radius:var(--radius-sm);color:#fff;display:inline-flex;font-size:11px;font-weight:700;height:24px;justify-content:center;min-width:32px;padding:0 10px}.hero-grade-a{background:linear-gradient(135deg,#10b981,#059669)}.hero-grade-b{background:linear-gradient(135deg,#3b82f6,#2563eb)}.hero-progress-bar{background:var(--gray-100);border-radius:var(--radius-sm);height:32px;margin-top:16px;overflow:hidden;position:relative}.hero-progress-fill{align-items:center;background:linear-gradient(90deg,#ff8c42,#ff6b35);color:#fff;display:flex;font-size:13px;font-weight:700;height:100%;justify-content:center;transition:width .3s ease}.feature-showcase{background:#fff;padding:80px 20px}.feature-showcase.alternate{background:var(--gray-50)}.feature-content{grid-gap:60px;align-items:center;display:grid;gap:60px;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1200px}.feature-showcase.alternate .feature-content{grid-template-columns:1fr 1fr}.feature-text h2{color:var(--text-primary);font-size:32px;font-weight:700;margin-bottom:16px}.feature-text p{color:var(--text-secondary);font-size:18px;line-height:1.6;margin-bottom:24px}.feature-points{list-style:none;margin:0;padding:0}.feature-points li{color:var(--text-primary);font-size:16px;padding:10px 0 10px 28px;position:relative}.feature-points li:before{color:#ff8c42;content:"✓";font-size:18px;font-weight:700;left:0;position:absolute}.feature-visual{display:flex;justify-content:center}.mock-creator,.mock-masterlog,.mock-report,.mock-tracker{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000001a;max-width:550px;overflow:hidden;width:100%}.mock-section-header{background:linear-gradient(135deg,#4a5568,#2d3748);border-bottom:1px solid var(--gray-200);padding:12px 16px}.mock-section-title h3{color:#fff;font-size:15px;font-weight:600;margin:0 0 4px}.mock-section-title p{color:#ffffffd9;font-size:12px;margin:0}.mock-form-grid{grid-gap:16px;background:#fff;display:grid;gap:16px;grid-template-columns:1fr 1fr;padding:16px}.mock-form-group{display:flex;flex-direction:column;gap:4px}.mock-form-group label{color:var(--gray-700);font-size:13px;font-weight:600}.mock-input,.mock-select{align-items:center;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);display:flex;font-size:14px;min-height:34px;padding:7px 10px}.mock-section-header-sm{background:linear-gradient(135deg,#4a5568,#2d3748);border-top:1px solid var(--gray-200);padding:10px 16px}.mock-section-header-sm h3{color:#fff;font-size:15px;font-weight:600;margin:0}.mock-thresholds{background:#fff;display:flex;flex-direction:column;gap:8px;padding:12px}.mock-threshold-card{border:1px solid var(--gray-300);border-radius:var(--radius-sm);overflow:hidden}.mock-threshold-header{background:var(--gray-700);color:#fff;font-size:13px;font-weight:600;padding:6px 12px}.mock-threshold-body{background:#fff;padding:10px 12px}.mock-thresh-row{align-items:center;display:flex;justify-content:space-between}.mock-thresh-label{color:var(--gray-600);font-size:13px}.mock-thresh-value{color:var(--text-primary);font-size:13px;font-weight:500}.mock-tracker-header{background:#fff;border-bottom:2px solid #ddd;padding:15px 20px}.mock-book-title{color:var(--text-primary);font-size:16px}.mock-book-title strong{font-weight:600}.mock-tracker-tabs{align-items:center;background:#f5f5f5;border-bottom:1px solid #ddd;display:flex;gap:4px;padding:15px 20px}.mock-tracker-tab{background:#e0e0e0;border-radius:8px 8px 0 0;color:#333;font-size:14px;font-weight:500;padding:10px 20px;white-space:nowrap}.mock-tracker-tab.active{background:#fff;color:#000;font-weight:600}.mock-add-tracker-btn{background:#e3f2fd;border-radius:8px 8px 0 0;color:#2196f3;cursor:default;font-size:18px;font-weight:700;padding:10px 16px}.mock-tracker-grid{background:#fff;display:flex}.mock-tracker-left{border-right:2px solid #ddd;min-width:220px}.mock-student-header{background:#f8f9fa;border-bottom:2px solid #ddd;color:var(--gray-600);font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-transform:uppercase}.mock-student-header,.mock-student-row{display:flex;justify-content:space-between}.mock-student-row{align-items:center;border-bottom:1px solid var(--gray-200);padding:14px 16px}.mock-student-row:last-child{border-bottom:none}.mock-student-name{color:var(--text-primary);font-size:14px;font-weight:500}.mock-progress-pill{background:linear-gradient(90deg,#ff8c42,#ff6b35);border-radius:var(--radius-sm);color:#fff;font-size:12px;font-weight:700;padding:4px 12px}.mock-tracker-right{display:flex;padding:0}.mock-assessment-column{border-right:1px solid var(--gray-200);min-width:140px}.mock-assessment-column:last-child{border-right:none}.mock-assessment-title{background:#f8f9fa;border-bottom:2px solid #ddd;color:var(--text-primary);font-size:13px;font-weight:600;overflow:hidden;padding:12px 16px;text-align:center;text-overflow:ellipsis;white-space:nowrap}.mock-cell{align-items:center;border-bottom:1px solid var(--gray-200);display:flex;justify-content:center;padding:14px 16px;text-align:center}.mock-grade-a,.mock-grade-b,.mock-grade-c{align-items:center;border-radius:var(--radius-sm);color:#fff;display:inline-flex;font-size:12px;font-weight:700;height:28px;justify-content:center;min-width:36px;padding:0 10px}.mock-grade-a{background:linear-gradient(135deg,#10b981,#059669)}.mock-grade-b{background:linear-gradient(135deg,#3b82f6,#2563eb)}.mock-grade-c{background:linear-gradient(135deg,#f59e0b,#d97706)}.mock-report-header{align-items:center;background:#f8f9fa;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:16px 20px}.mock-report-title{color:var(--text-primary);font-size:16px;font-weight:600}.mock-export-btns{display:flex;gap:8px}.mock-export-btn{background:var(--primary-blue);border:none;border-radius:var(--radius-sm);color:#fff;cursor:default;font-size:12px;font-weight:600;padding:6px 14px}.mock-report-preview{padding:24px}.mock-report-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:20px}.mock-report-student{align-items:center;border-bottom:2px solid var(--gray-200);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.mock-report-student strong{color:var(--text-primary);font-size:18px}.mock-report-meta{color:var(--text-secondary);font-size:13px}.mock-report-table{margin-bottom:20px}.mock-report-row{align-items:center;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;padding:12px 0}.mock-report-row:last-child{border-bottom:none}.mock-report-assessment{color:var(--text-primary);font-size:14px}.mock-report-grade-a,.mock-report-grade-b{align-items:center;border-radius:var(--radius-sm);color:#fff;display:inline-flex;font-size:12px;font-weight:700;height:28px;justify-content:center;min-width:36px;padding:0 10px}.mock-report-grade-a{background:linear-gradient(135deg,#10b981,#059669)}.mock-report-grade-b{background:linear-gradient(135deg,#3b82f6,#2563eb)}.mock-report-progress{background:var(--gray-50);border-radius:var(--radius-md);padding:16px}.mock-report-progress-label{color:var(--text-secondary);font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.mock-report-progress-bar{background:var(--gray-200);border-radius:var(--radius-sm);height:36px;overflow:hidden;position:relative;width:100%}.mock-report-progress-fill{align-items:center;background:linear-gradient(90deg,#ff8c42,#ff6b35);display:flex;height:100%;justify-content:center;left:0;position:absolute;top:0}.mock-report-progress-fill span{color:#fff;font-size:14px;font-weight:700}.mock-log-header{align-items:center;background:#f8f9fa;border-bottom:1px solid var(--gray-200);display:flex;gap:16px;justify-content:space-between;padding:16px 20px}.mock-log-title{color:var(--text-primary);font-size:16px;font-weight:600;white-space:nowrap}.mock-search-input{background:#fff;border:1px solid var(--gray-300);border-radius:var(--radius-md);flex:1 1;font-size:13px;max-width:300px;outline:none;padding:8px 14px}.mock-log-list{padding:20px}.mock-log-item{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-md);display:flex;justify-content:space-between;margin-bottom:12px;padding:16px;transition:all .2s ease}.mock-log-item:hover{border-color:var(--primary-blue);box-shadow:0 2px 8px #00000014}.mock-log-item:last-child{margin-bottom:0}.mock-log-info{flex:1 1}.mock-log-name{color:var(--text-primary);font-size:15px;font-weight:600;margin-bottom:4px}.mock-log-details{color:var(--text-secondary);font-size:13px}.mock-log-actions{display:flex;gap:8px}.mock-action-btn{background:#fff;border:1px solid var(--gray-300);border-radius:var(--radius-sm);color:var(--primary-blue);cursor:default;font-size:12px;font-weight:500;padding:6px 12px;transition:all .15s ease}.mock-action-btn:hover{background:var(--gray-50);border-color:var(--primary-blue)}.landing-cta{background:linear-gradient(135deg,var(--gray-800) 0,var(--gray-700) 100%);color:#fff;padding:80px 20px;text-align:center}.cta-container{margin:0 auto;max-width:700px}.landing-cta h2{font-size:36px;font-weight:700;margin-bottom:12px}.landing-cta p{font-size:18px;margin-bottom:32px;opacity:.9}.cta-buttons{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.btn-cta-primary,.btn-cta-secondary{border:none;border-radius:var(--radius-md);cursor:pointer;font-family:inherit;font-size:16px;font-weight:600;padding:14px 32px;transition:all .2s ease}.btn-cta-primary{background:#ff8c42;color:#fff}.btn-cta-primary:hover{background:#ff7a2e;box-shadow:0 8px 16px #ff8c424d;transform:translateY(-2px)}.btn-cta-secondary{background:#ffffff26;border:1px solid #ffffff4d;color:#fff}.btn-cta-secondary:hover{background:#ffffff40;transform:translateY(-2px)}@media (max-width:968px){.landing-hero-split{gap:40px;grid-template-columns:1fr;padding:50px 30px}.hero-left h1{font-size:32px}.hero-tagline{font-size:16px}.hero-report-showcase{max-width:100%}.feature-content{gap:40px}.feature-content,.feature-showcase.alternate .feature-content{grid-template-columns:1fr}.feature-showcase.alternate .feature-visual{order:-1}.feature-text h2{font-size:28px}.feature-text p{font-size:16px}.mock-tracker-grid{flex-direction:column}.mock-tracker-left{border-bottom:2px solid #ddd;border-right:none}.mock-tracker-right{overflow-x:auto}}@media (max-width:640px){.landing-hero-split{gap:30px;padding:40px 20px}.hero-left h1{font-size:28px}.hero-logo{height:60px}.hero-report-body{grid-template-columns:1fr}.hero-settings-panel{border-bottom:1px solid var(--gray-200);border-right:none;flex-direction:row;justify-content:space-around;padding:16px}.feature-showcase{padding:60px 16px}.feature-text h2{font-size:24px}.cta-buttons,.hero-buttons{flex-direction:column}.btn-cta-primary,.btn-cta-secondary,.btn-hero-primary,.btn-hero-secondary{width:100%}.mock-form-grid{grid-template-columns:1fr}.mock-log-item{align-items:flex-start;flex-direction:column;gap:12px}.mock-log-actions{width:100%}.mock-action-btn{flex:1 1}.mock-log-header{align-items:flex-start;flex-direction:column}.mock-search-input{max-width:none;width:100%}}