.analytics-export{padding:20px;max-width:800px;margin:0 auto}.export-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:2px solid #3498db;padding-bottom:10px}.export-header h3{margin:0;color:#2c3e50}.close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#7f8c8d;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.close-button:hover{color:#e74c3c}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:4px;margin-bottom:20px;border-left:4px solid #e74c3c}.success-message{background-color:#efe;color:#3c3;padding:12px;border-radius:4px;margin-bottom:20px;border-left:4px solid #27ae60}.export-section{margin-bottom:30px}.export-section h4{color:#34495e;margin-bottom:15px;font-size:16px}.radio-group{display:flex;flex-direction:column;gap:10px}.radio-group label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s}.radio-group label:hover{background-color:#f8f9fa}.radio-group input[type=radio]{cursor:pointer}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.filter-field{display:flex;flex-direction:column;gap:5px}.filter-field label{font-size:14px;color:#555;font-weight:500}.filter-field input,.filter-field select{padding:8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.filter-field input:focus,.filter-field select:focus{outline:none;border-color:#3498db}.preset-controls{display:flex;gap:10px;margin-bottom:15px}.preset-controls input{flex:1;padding:8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.save-preset-button{padding:8px 16px;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;white-space:nowrap}.save-preset-button:hover{background-color:#2980b9}.presets-list{display:flex;flex-direction:column;gap:10px}.preset-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background-color:#f8f9fa;border-radius:4px;border:1px solid #e9ecef}.preset-name{font-weight:500;color:#2c3e50}.preset-actions{display:flex;gap:8px}.load-button,.delete-button{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:13px}.load-button{background-color:#27ae60;color:#fff}.load-button:hover{background-color:#229954}.delete-button{background-color:#e74c3c;color:#fff}.delete-button:hover{background-color:#c0392b}.export-actions{margin-top:30px;display:flex;justify-content:center}.export-button{padding:12px 32px;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:500;transition:background-color .2s}.export-button:hover:not(:disabled){background-color:#2980b9}.export-button:disabled{background-color:#95a5a6;cursor:not-allowed}.analytics-dashboard{padding:20px;max-width:1400px;margin:0 auto;background:#f5f5f5;min-height:100vh}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.dashboard-header h2{margin:0;color:#333}.close-button{background:none;border:none;font-size:32px;color:#666;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.close-button:hover{background-color:#f0f0f0}.loading,.error{text-align:center;padding:40px;background:#fff;border-radius:8px;margin:20px 0}.error{color:#d32f2f}.overview-section{background:#fff;padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.overview-section h3{margin-top:0;margin-bottom:20px;color:#333}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;border-radius:8px;text-align:center}.stat-value{font-size:32px;font-weight:700;margin-bottom:8px}.stat-label{font-size:14px;opacity:.9}.scene-stats-section{background:#fff;padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.scene-stats-section h3{margin-top:0;margin-bottom:20px;color:#333}.scene-stats-list{display:flex;flex-direction:column;gap:15px}.scene-stat-item{display:grid;grid-template-columns:1fr 200px 60px;gap:15px;align-items:center}.scene-info{display:flex;flex-direction:column;gap:4px}.scene-title{font-weight:600;color:#333}.scene-count{font-size:14px;color:#666}.progress-bar{height:24px;background:#e0e0e0;border-radius:12px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);transition:width .3s ease}.completion-rate{font-weight:600;color:#333;text-align:right}.filters-section{background:#fff;padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a;display:flex;gap:20px;flex-wrap:wrap}.filter-group label{font-weight:600;color:#333}.filter-group select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:#fff;cursor:pointer}.student-status-section{background:#fff;padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.student-status-section h3{margin-top:0;margin-bottom:15px;color:#333}.status-legend{display:flex;gap:20px;margin-bottom:20px;padding:10px;background:#f9f9f9;border-radius:4px}.legend-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#666}.status-icon{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;font-weight:700}.status-icon.status-practiced{background:#4caf50;color:#fff}.status-icon.status-needs-attention{background:#ff9800;color:#fff}.status-icon.status-not-practiced{background:#f44336;color:#fff}.student-list{display:flex;flex-direction:column;gap:10px}.student-item{display:grid;grid-template-columns:40px 1fr 120px 150px;gap:15px;align-items:center;padding:12px;border-radius:4px;border-left:4px solid transparent}.student-item.status-practiced{background:#e8f5e9;border-left-color:#4caf50}.student-item.status-needs-attention{background:#fff3e0;border-left-color:#ff9800}.student-item.status-not-practiced{background:#ffebee;border-left-color:#f44336}.student-name{font-weight:600;color:#333}.practice-count{font-size:14px;color:#666}.last-practice{font-size:14px;color:#666;text-align:right}.practice-matrix{overflow-x:auto}.practice-matrix table{width:100%;border-collapse:collapse;font-size:14px}.practice-matrix th,.practice-matrix td{padding:12px;text-align:center;border:1px solid #e0e0e0}.practice-matrix th{background:#f5f5f5;font-weight:600;color:#333;position:sticky;top:0;z-index:1}.student-name-cell{text-align:left;font-weight:600;background:#fafafa;position:sticky;left:0;z-index:1}.status-cell{font-size:18px;font-weight:700}.status-cell.status-practiced{background:#e8f5e9;color:#4caf50}.status-cell.status-needs-attention{background:#fff3e0;color:#ff9800}.status-cell.status-not-practiced{background:#ffebee;color:#f44336}.cue-conflicts-section{background:#fff;padding:20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.cue-conflicts-section h3{margin-top:0;margin-bottom:20px;color:#333}.conflicts-list{display:flex;flex-direction:column;gap:12px}.conflict-item{padding:15px;border-radius:4px;border-left:4px solid transparent}.conflict-item.severity-high{background:#ffebee;border-left-color:#f44336}.conflict-item.severity-medium{background:#fff3e0;border-left-color:#ff9800}.conflict-item.severity-low{background:#fff9c4;border-left-color:#fbc02d}.conflict-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.cue-name{font-weight:600;font-size:16px;color:#333}.severity-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.severity-badge.severity-high{background:#f44336;color:#fff}.severity-badge.severity-medium{background:#ff9800;color:#fff}.severity-badge.severity-low{background:#fbc02d;color:#333}.conflict-details{display:flex;flex-direction:column;gap:4px}.conflict-details .scene-title{font-size:14px;color:#666}.conflict-stats{font-size:13px;color:#999}@media (max-width: 768px){.analytics-dashboard{padding:10px}.stats-grid{grid-template-columns:repeat(2,1fr)}.scene-stat-item{grid-template-columns:1fr;gap:8px}.progress-bar{width:100%}.filters-section{flex-direction:column}.student-item{grid-template-columns:40px 1fr;gap:10px}.practice-count,.last-practice{grid-column:2}.practice-matrix{font-size:12px}.practice-matrix th,.practice-matrix td{padding:8px 4px}}.portfolio-viewer{padding:20px;max-width:1200px;margin:0 auto}.portfolio-viewer.loading,.portfolio-viewer.error{text-align:center;padding:40px;font-size:18px}.portfolio-viewer.error{color:#f44336}.portfolio-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.portfolio-header h2{margin:0;font-size:28px;color:#333}.view-mode-toggle{display:flex;gap:10px}.view-mode-toggle button{padding:10px 20px;border:1px solid #ddd;background:#fff;cursor:pointer;border-radius:4px;transition:all .2s}.view-mode-toggle button.active{background:#2196f3;color:#fff;border-color:#2196f3}.view-mode-toggle button:hover:not(.active){background:#f5f5f5}.portfolio-filters{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.portfolio-filters input,.portfolio-filters select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.portfolio-filters button{padding:8px 16px;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:background .2s}.portfolio-filters button:hover{background:#e0e0e0}.portfolio-entries{display:flex;flex-direction:column;gap:15px}.no-entries{text-align:center;padding:40px;color:#666;font-size:16px}.portfolio-entry{border:1px solid #ddd;border-radius:8px;padding:20px;background:#fff;cursor:pointer;transition:all .2s}.portfolio-entry:hover{box-shadow:0 2px 8px #0000001a;border-color:#2196f3}.portfolio-entry.selected{border-color:#2196f3;box-shadow:0 2px 8px #2196f333}.entry-header{display:flex;gap:15px;margin-bottom:15px}.entry-icon{font-size:32px;line-height:1}.entry-info{flex:1}.entry-info h3{margin:0 0 5px;font-size:18px;color:#333}.entry-type,.entry-date{display:inline-block;margin-right:15px;font-size:14px;color:#666}.entry-type{font-weight:500}.entry-metrics{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:15px}.metric-badge{padding:4px 12px;background:#e3f2fd;color:#1976d2;border-radius:12px;font-size:13px;font-weight:500}.entry-feedback,.entry-rubric,.entry-reflection{margin-top:15px;padding:12px;background:#f9f9f9;border-radius:4px;font-size:14px}.entry-feedback strong,.entry-rubric strong,.entry-reflection strong{display:block;margin-bottom:5px;color:#333}.entry-feedback p,.entry-reflection p{margin:0;color:#666}.entry-reflection-edit{margin-top:15px}.entry-reflection-edit textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;resize:vertical}.reflection-actions{display:flex;gap:10px;margin-top:10px}.reflection-actions button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background .2s}.reflection-actions button:first-child{background:#4caf50;color:#fff}.reflection-actions button:first-child:hover{background:#45a049}.reflection-actions button:last-child{background:#f5f5f5;color:#333}.reflection-actions button:last-child:hover{background:#e0e0e0}.add-reflection-btn{margin-top:15px;padding:8px 16px;background:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background .2s}.add-reflection-btn:hover{background:#1976d2}.portfolio-growth{padding:20px 0}.no-growth-data{text-align:center;padding:40px;color:#666;font-size:16px}.growth-metrics{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.growth-metric-card{border:1px solid #ddd;border-radius:8px;padding:20px;background:#fff}.metric-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.metric-header h3{margin:0;font-size:16px;color:#333}.trend-indicator{font-size:14px;font-weight:500;padding:4px 8px;border-radius:4px;background:#f5f5f5}.metric-change{margin-bottom:15px}.change-value{font-size:24px;font-weight:700}.change-value.positive{color:#4caf50}.change-value.negative{color:#f44336}.metric-chart{margin-bottom:10px;background:#f9f9f9;border-radius:4px;padding:10px}.metric-data-points{font-size:13px;color:#666;text-align:center}@media (max-width: 768px){.portfolio-header{flex-direction:column;align-items:flex-start;gap:15px}.portfolio-filters{flex-direction:column}.portfolio-filters input,.portfolio-filters select,.portfolio-filters button{width:100%}.growth-metrics{grid-template-columns:1fr}}.student-role-dashboard{padding:20px;max-width:1200px;margin:0 auto}.student-role-dashboard h2{margin:0 0 20px;color:#333;font-size:2rem}.student-role-dashboard.loading,.student-role-dashboard.error,.student-role-dashboard.empty{text-align:center;padding:60px 20px;color:#666}.student-role-dashboard.error{color:#c33}.dashboard-filters{display:flex;gap:20px;margin-bottom:25px;padding:15px;background:#f9f9f9;border-radius:8px}.filter-group{display:flex;align-items:center;gap:10px}.filter-group label{font-weight:500;color:#555}.filter-group select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;min-width:150px}.dashboard-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;margin-bottom:30px}.summary-card{padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;text-align:center}.summary-card:nth-child(2){background:linear-gradient(135deg,#4caf50,#45a049)}.summary-card:nth-child(3){background:linear-gradient(135deg,#ff9800,#f57c00)}.summary-card:nth-child(4){background:linear-gradient(135deg,#2196f3,#1976d2)}.summary-value{font-size:2.5rem;font-weight:700;margin-bottom:5px}.summary-label{font-size:.9rem;opacity:.9}.roles-by-project{display:flex;flex-direction:column;gap:30px}.project-section{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.project-title{margin:0 0 20px;color:#333;font-size:1.5rem;padding-bottom:10px;border-bottom:2px solid #e0e0e0}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.role-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:15px;transition:transform .2s,box-shadow .2s}.role-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.role-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.role-discipline{display:flex;align-items:center;gap:8px}.discipline-icon{font-size:1.5rem}.discipline-name{font-weight:500;color:#555;font-size:.9rem}.understudy-badge{padding:4px 8px;background:#2196f3;color:#fff;border-radius:12px;font-size:.75rem;font-weight:500}.role-content{margin-bottom:15px}.role-name{margin:0 0 5px;color:#333;font-size:1.2rem;font-weight:600}.scene-name{margin:0 0 10px;color:#777;font-size:.9rem}.status-badge{display:inline-block;padding:6px 12px;border-radius:4px;font-size:.85rem;font-weight:500;margin-bottom:10px}.status-upcoming{background:#e3f2fd;color:#1976d2}.status-needs-practice{background:#fff3e0;color:#f57c00}.status-ready{background:#e8f5e9;color:#388e3c}.role-details{display:flex;flex-direction:column;gap:5px;font-size:.85rem}.detail-item{display:flex;justify-content:space-between}.detail-label{color:#777}.detail-value{color:#333;font-weight:500}.role-actions{display:flex;gap:10px}.practice-button{flex:1;padding:10px 16px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.practice-button:hover{background:#45a049}@media (max-width: 768px){.dashboard-filters{flex-direction:column}.filter-group{width:100%}.filter-group select{flex:1}.dashboard-summary{grid-template-columns:repeat(2,1fr)}.roles-grid{grid-template-columns:1fr}}@media (max-width: 480px){.dashboard-summary{grid-template-columns:1fr}.summary-value{font-size:2rem}}:root{--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--touch-target-min: 44px;--border-radius: .375rem;--color-primary: #3b82f6;--color-secondary: #8b5cf6;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-bg: #ffffff;--color-surface: #f3f4f6;--color-text: #1f2937;--color-text-secondary: #6b7280;--color-border: #e5e7eb}.container{width:100%;margin:0 auto;padding:var(--spacing-md)}@media (max-width: 768px){button,.nav-btn,.project-card,.discipline-layer-card,.cue-marker-item{min-height:var(--touch-target-min);min-width:var(--touch-target-min);padding:var(--spacing-md)}input[type=checkbox],input[type=radio]{width:24px;height:24px}}.project-dashboard{display:flex;flex-direction:column;min-height:100vh;background-color:var(--color-bg)}.dashboard-header{padding:var(--spacing-md);background-color:var(--color-surface);border-bottom:1px solid var(--color-border)}.dashboard-header h1{font-size:var(--font-size-xl);margin:0 0 var(--spacing-md) 0;color:var(--color-text)}.mode-switcher{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.mode-switcher button{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);background-color:var(--color-bg);border-radius:var(--border-radius);cursor:pointer;font-size:var(--font-size-base);transition:all .2s}.mode-switcher button:hover:not(:disabled){background-color:var(--color-surface)}.mode-switcher button.active{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.mode-switcher button:disabled{opacity:.5;cursor:not-allowed}.dashboard-content{flex:1;padding:var(--spacing-md)}.project-list{display:grid;gap:var(--spacing-md);grid-template-columns:1fr}@media (min-width: 768px){.container{padding:var(--spacing-lg)}.dashboard-header h1{font-size:var(--font-size-2xl)}.project-list{grid-template-columns:repeat(2,1fr)}.dashboard-content{padding:var(--spacing-lg)}}@media (min-width: 1024px){.container{max-width:1280px;padding:var(--spacing-xl)}.project-list{grid-template-columns:repeat(3,1fr)}.dashboard-content{padding:var(--spacing-xl)}}.project-card{padding:var(--spacing-lg);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--border-radius);cursor:pointer;transition:all .2s}.project-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.project-card:focus{outline:2px solid var(--color-primary);outline-offset:2px}.project-card h3{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-lg);color:var(--color-text)}.project-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0 0 var(--spacing-md) 0;line-height:1.5}.project-meta{display:flex;gap:var(--spacing-md);flex-wrap:wrap;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.scene-editor{display:flex;flex-direction:column;gap:var(--spacing-lg)}.scene-header{background-color:var(--color-surface);padding:var(--spacing-lg);border-radius:var(--border-radius)}.scene-navigation{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.scene-title{font-size:var(--font-size-lg);margin:0;text-align:center;flex:1}.nav-btn{padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--border-radius);cursor:pointer;font-size:var(--font-size-base);transition:all .2s}.nav-btn:hover:not(:disabled){background-color:var(--color-surface)}.nav-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.scene-navigation{flex-direction:column}.scene-title{font-size:var(--font-size-base);order:-1}.nav-btn{width:100%}}@media (min-width: 768px){.scene-title{font-size:var(--font-size-xl)}}.discipline-layers{background-color:var(--color-bg);padding:var(--spacing-lg);border-radius:var(--border-radius);border:1px solid var(--color-border)}.discipline-layers h3{margin:0 0 var(--spacing-md) 0;font-size:var(--font-size-lg)}.layer-list{display:grid;gap:var(--spacing-md);grid-template-columns:1fr}@media (min-width: 768px){.layer-list{grid-template-columns:repeat(3,1fr)}}.discipline-layer-card{padding:var(--spacing-lg);background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--border-radius);cursor:pointer;transition:all .2s}.discipline-layer-card:hover{border-color:var(--color-primary)}.discipline-layer-card.active{border-color:var(--color-primary);background-color:#3b82f61a}.discipline-layer-card:focus{outline:2px solid var(--color-primary);outline-offset:2px}.layer-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.discipline-icon{font-size:var(--font-size-2xl)}.discipline-name{margin:0;font-size:var(--font-size-lg)}.layer-status{margin-bottom:var(--spacing-sm)}.status-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius);font-size:var(--font-size-sm);font-weight:500}.status-empty{background-color:#f3f4f6;color:#6b7280}.status-draft{background-color:#fef3c7;color:#92400e}.status-complete{background-color:#d1fae5;color:#065f46}.status-approved{background-color:#dbeafe;color:#1e40af}.completion-bar{position:relative;height:8px;background-color:var(--color-border);border-radius:4px;overflow:hidden;margin-bottom:var(--spacing-sm)}.completion-fill{height:100%;background-color:var(--color-primary);transition:width .3s}.completion-text{position:absolute;top:-20px;right:0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.cue-markers-section{background-color:var(--color-bg);padding:var(--spacing-lg);border-radius:var(--border-radius);border:1px solid var(--color-border)}.cue-markers-section h3{margin:0 0 var(--spacing-md) 0;font-size:var(--font-size-lg)}.cue-marker-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.cue-marker-item{padding:var(--spacing-md);background-color:var(--color-surface);border-radius:var(--border-radius);border:1px solid var(--color-border)}.cue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.cue-name{font-weight:500;color:var(--color-text)}.cue-time{font-family:monospace;color:var(--color-text-secondary)}.cue-description{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.cue-meta{display:flex;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary);font-style:italic}.create-project-btn{width:100%;padding:var(--spacing-md);background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);font-size:var(--font-size-base);font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:var(--spacing-md)}.create-project-btn:hover{background-color:#2563eb}.create-project-btn:focus{outline:2px solid var(--color-primary);outline-offset:2px}@media (min-width: 768px){.create-project-btn{width:auto;display:inline-block}}.scene-metadata{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-lg);background-color:var(--color-surface);border-radius:var(--border-radius)}.metadata-item{display:flex;justify-content:space-between;align-items:center}.metadata-item .label{font-weight:500;color:var(--color-text)}.metadata-item .value{color:var(--color-text-secondary)}@media (min-width: 768px){.scene-metadata{flex-direction:row;justify-content:space-around}}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media print{.mode-switcher,.nav-btn,.create-project-btn{display:none}.project-card,.discipline-layer-card{break-inside:avoid}}*:focus{outline:2px solid #0066cc;outline-offset:2px}*:focus:not(:focus-visible){outline:none}*:focus-visible{outline:2px solid #0066cc;outline-offset:2px}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,[role=button]:focus-visible,[tabindex]:focus-visible{outline:3px solid #0066cc;outline-offset:2px;box-shadow:0 0 0 4px #06c3}.skip-to-main{position:absolute;top:-40px;left:0;background:#06c;color:#fff;padding:8px 16px;text-decoration:none;z-index:10000;border-radius:0 0 4px}.skip-to-main:focus{top:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.keyboard-hint{font-size:.875rem;color:#666;margin-top:4px}.focus-trap-container{position:relative}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:8px;padding:24px;max-width:90vw;max-height:90vh;overflow:auto;position:relative}.high-contrast{--text-color: #000;--bg-color: #fff;--border-color: #000;--link-color: #0000ff;--focus-color: #ff0000}.high-contrast *{color:var(--text-color)!important;background-color:var(--bg-color)!important;border-color:var(--border-color)!important}.high-contrast a{color:var(--link-color)!important;text-decoration:underline!important}.high-contrast *:focus-visible{outline:3px solid var(--focus-color)!important;outline-offset:2px!important}.text-size-small{font-size:14px}.text-size-medium{font-size:16px}.text-size-large{font-size:18px}.text-size-xlarge{font-size:20px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.reduced-motion *,.reduced-motion *:before,.reduced-motion *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.keyboard-shortcuts-panel{position:fixed;bottom:20px;right:20px;background:#fff;border:1px solid #ccc;border-radius:8px;padding:16px;box-shadow:0 4px 12px #00000026;max-width:300px;z-index:999}.keyboard-shortcuts-panel h3{margin:0 0 12px;font-size:1rem;font-weight:600}.keyboard-shortcuts-list{list-style:none;padding:0;margin:0}.keyboard-shortcuts-list li{display:flex;justify-content:space-between;padding:4px 0;font-size:.875rem}.keyboard-shortcuts-list kbd{background:#f0f0f0;border:1px solid #ccc;border-radius:3px;padding:2px 6px;font-family:monospace;font-size:.75rem}.aria-live-region{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}button[aria-pressed=true]{background-color:#06c;color:#fff}button[aria-expanded=true]:after{content:" (expanded)";position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}button[aria-expanded=false]:after{content:" (collapsed)";position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}label{display:block;margin-bottom:4px;font-weight:500}input[aria-invalid=true],textarea[aria-invalid=true],select[aria-invalid=true]{border-color:#d32f2f;outline-color:#d32f2f}.error-message{color:#d32f2f;font-size:.875rem;margin-top:4px}[aria-busy=true]{opacity:.6;pointer-events:none}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #0066cc;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}[role=tooltip]{position:absolute;background:#333;color:#fff;padding:4px 8px;border-radius:4px;font-size:.875rem;z-index:1000;pointer-events:none}[role=tablist]{display:flex;border-bottom:1px solid #ccc}[role=tab]{padding:8px 16px;border:none;background:none;cursor:pointer;border-bottom:2px solid transparent}[role=tab][aria-selected=true]{border-bottom-color:#06c;font-weight:600}[role=tabpanel]{padding:16px}[role=tabpanel][hidden]{display:none}body.high-contrast{background-color:#000;color:#fff}body.high-contrast button{border:2px solid #fff;background-color:#000;color:#fff}body.high-contrast button:hover{background-color:#fff;color:#000}body.high-contrast input,body.high-contrast textarea,body.high-contrast select{border:2px solid #fff;background-color:#000;color:#fff}body.high-contrast a{color:#ff0;text-decoration:underline}body.high-contrast a:visited{color:#f0f}body.high-contrast .project-card,body.high-contrast .scene-card,body.high-contrast .layer-card{border:2px solid #fff;background-color:#000}body.high-contrast .modal-content,body.high-contrast .dialog{border:3px solid #fff;background-color:#000}body.reduced-motion *,body.reduced-motion *:before,body.reduced-motion *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
