.dashboard-loading{padding:2rem;text-align:center;color:#495057;font-size:1rem}.synced{color:green;font-size:.9rem;margin-right:.5rem}.syncing{color:#666;font-size:.9rem;margin-right:.5rem}.canvas-workspace{display:flex;flex-direction:column;height:100%;min-height:0}.toolbar{padding:.5rem 1rem;background:#f1f1f1;display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.toolbar-group{display:flex;gap:.25rem;align-items:center;border-right:1px solid #d0d0d0;padding-right:.5rem}.toolbar button,.toolbar select{padding:.4rem .6rem;border-radius:4px;border:1px solid #ccc;background:#fff;cursor:pointer;font-size:.85rem;transition:background .15s,border-color .15s}.toolbar button:hover:not(:disabled){background:#e8e8e8}.toolbar button:disabled{opacity:.4;cursor:default}.toolbar button.tool-active{background:#d0e4ff;border-color:#4a90d9;font-weight:600}.toolbar button.tool-eraser.tool-active{background:#ffe0e0;border-color:#d94a4a}.toolbar button.tool-danger{color:#c0392b;border-color:#e0a0a0}.toolbar button.tool-danger:hover{background:#fde8e8}.toolbar .color-btn{width:24px;height:24px;padding:0;border-radius:50%;border:2px solid #bbb;min-width:24px}.toolbar .color-btn:hover{border-color:#333;transform:scale(1.15)}.toolbar-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.toolbar-color-wrap{display:flex;align-items:center}.color-picker-input{width:40px;height:32px;padding:0;border:1px solid #ccc;border-radius:4px;cursor:pointer;background:transparent}.color-recent{border-right:1px solid #d0d0d0;padding-right:.5rem}.color-btn-recent{border-style:dashed}.brush-slider-label{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:#334155}.brush-slider-label input[type=range]{width:100px}.brush-slider-value{min-width:2.5rem;font-variant-numeric:tabular-nums}.canvas-container{flex:1;min-height:320px;display:flex;justify-content:center;align-items:center;overflow:auto;position:relative;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;margin:0 .5rem .5rem}.student-pixi-host{flex:1;width:100%;min-height:300px;display:flex;justify-content:center;align-items:center}.student-pixi-host canvas{border-radius:4px;box-shadow:0 2px 8px #00000014}.student-text-overlay{font-family:system-ui,sans-serif;padding:2px 4px;border:1px solid #94a3b8;border-radius:4px;background:#ffffffeb;resize:both}.canvas-container canvas{border-radius:4px;box-shadow:0 2px 8px #00000014}.freeze-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0000002e;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);z-index:50;pointer-events:auto}.freeze-overlay-content{background:#ffffffeb;border-radius:16px;padding:1.5rem 2rem;text-align:center;box-shadow:0 4px 24px #0000001f}.freeze-overlay-content .freeze-icon{font-size:2rem;display:block;margin-bottom:.25rem}.freeze-overlay-content p{margin:0;font-weight:600;color:#334155;font-size:1rem}.symbol-palette{display:flex;flex-wrap:wrap;gap:.35rem;padding:.35rem 1rem;background:#f8f4ff;border-bottom:1px solid #e2d9f3}.symbol-group{display:flex;align-items:center;gap:2px;flex-wrap:wrap}.symbol-group-label{font-size:.65rem;color:#7c3aed;font-weight:600;text-transform:uppercase;letter-spacing:.03em;margin-right:2px;-webkit-user-select:none;user-select:none}.symbol-btn{width:28px;height:28px;padding:0;font-size:.95rem;line-height:28px;text-align:center;border:1px solid #d4c8ef;border-radius:4px;background:#fff;cursor:pointer;color:#1e1b4b;transition:background .12s,border-color .12s}.symbol-btn:hover{background:#ede9fe;border-color:#7c3aed}.symbol-btn:focus-visible{outline:2px solid #7c3aed;outline-offset:1px}.student-timer{text-align:center;font-size:1.4rem;font-weight:700;font-family:Courier New,monospace;color:#1e293b;padding:.35rem 1rem;background:#f1f5f9;border-bottom:1px solid #e2e8f0}.student-timer-urgent{color:#dc2626;background:#fef2f2;animation:pulse-student-timer .8s infinite}@keyframes pulse-student-timer{0%,to{opacity:1}50%{opacity:.5}}.canvas-focus-mode .toolbar-focus{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);z-index:100;border-radius:12px;box-shadow:0 4px 20px #0000002e;background:#fffffff5;padding:.35rem .75rem;gap:.4rem}.toolbar button.tool-highlight.tool-active{background:#fef9c3;border-color:#ca8a04}.toolbar button.tool-sticky.tool-active{background:#fef08a;border-color:#ca8a04}.student-sticky-overlay{border-radius:6px;border:1px solid #bbb88a;font-family:system-ui,sans-serif}.sticky-color-bar{display:flex;align-items:center;gap:.35rem;padding:.3rem 1rem;background:#fffbeb;border-bottom:1px solid #fde68a}.sticky-color-label{font-size:.75rem;color:#92400e;font-weight:600;-webkit-user-select:none;user-select:none}.sticky-color-active{outline:2px solid #92400e;outline-offset:1px}.stem-ruler,.stem-protractor{-webkit-user-select:none;user-select:none;touch-action:none}.stem-rotate-btn{position:absolute;top:2px;right:4px;width:22px;height:22px;border-radius:50%;border:1px solid #94a3b8;background:#fff;cursor:pointer;font-size:.85rem;line-height:1;padding:0}.stem-calculator{background:#fff;border:1px solid #94a3b8;border-radius:8px;box-shadow:0 4px 16px #0000001f;width:180px;-webkit-user-select:none;user-select:none}.calc-header{padding:.3rem .5rem;background:#f1f5f9;border-bottom:1px solid #e2e8f0;font-size:.75rem;font-weight:600;color:#475569;border-radius:8px 8px 0 0}.calc-display{padding:.4rem .5rem;text-align:right;font-family:Courier New,monospace;font-size:1.1rem;min-height:1.5rem;border-bottom:1px solid #e2e8f0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;padding:4px}.calc-btn{padding:.35rem;border:1px solid #e2e8f0;border-radius:4px;background:#fff;cursor:pointer;font-size:.85rem}.calc-btn:hover{background:#f1f5f9}.calc-btn-ins{background:#dbeafe;font-weight:600}.grid-select{padding:.3rem .5rem;border-radius:4px;border:1px solid #ccc;font-size:.8rem;background:#fff;cursor:pointer}.expanded-canvas-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.expanded-canvas-modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;max-width:90vw;max-height:90vh;display:flex;flex-direction:column}.expanded-canvas-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid #eee}.expanded-canvas-header h2{margin:0;flex:1}.expanded-canvas-close{padding:.4rem .8rem;cursor:pointer;background:#333;color:#fff;border:none;border-radius:4px}.annotate-toggle{padding:.4rem .8rem;cursor:pointer;background:#fff;color:#7c3aed;border:1px solid #7c3aed;border-radius:4px;font-size:.85rem}.annotate-toggle.annotate-on{background:#7c3aed;color:#fff}.teacher-annotate-wrap{position:relative;min-height:300px}.teacher-annotate-canvas{display:block}.expanded-canvas-body{padding:.5rem;min-width:400px;min-height:300px}.expanded-canvas-loading{padding:2rem;color:#666}
