:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,SF Pro Text,Helvetica Neue,Arial,sans-serif;color:#0f172a;background:#f8fafc;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-secondary: #8b5cf6;--color-success: #10b981;--color-error: #ef4444;--color-warning: #f59e0b;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--shadow-md: 0 4px 12px rgba(15, 23, 42, .08);--shadow-lg: 0 12px 36px rgba(15, 23, 42, .12);--shadow-xl: 0 24px 48px rgba(15, 23, 42, .18);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--radius-full: 9999px}.app-shell.dark-mode{background:#0f172a;color:#e2e8f0}.app-shell.dark-mode .topbar,.app-shell.dark-mode .viewer-panel,.app-shell.dark-mode .side-panel,.app-shell.dark-mode .library-view{background:#1e293bf2;border-color:#4755694d;box-shadow:0 1px 3px #00000080}.app-shell.dark-mode h1,.app-shell.dark-mode h2,.app-shell.dark-mode h3,.app-shell.dark-mode p,.app-shell.dark-mode label,.app-shell.dark-mode span,.app-shell.dark-mode button{color:#e2e8f0}.app-shell.dark-mode input,.app-shell.dark-mode select,.app-shell.dark-mode textarea{background:#1e293bcc;border-color:#47556980;color:#e2e8f0}.app-shell.dark-mode input::placeholder,.app-shell.dark-mode textarea::placeholder{color:#94a3b8}.preview-container{width:100%;height:100%;display:flex;align-items:stretch;justify-content:center;background:#212f56;padding:0}.preview-card{background:#1e293bf2;border:1px solid rgba(71,85,105,.3);border-radius:8px;box-shadow:0 2px 8px #0000004d;width:100%;display:flex;flex-direction:column;justify-content:space-between}.preview-card-header{padding:12px 16px 10px;border-bottom:1px solid rgba(71,85,105,.3);flex-shrink:0}.preview-card-logo{width:28px;height:auto}.preview-card-body{padding:16px;flex:1;display:flex;flex-direction:column;justify-content:center}.preview-card-title{margin:0 0 8px;font-size:18px;font-weight:600;color:#e2e8f0;line-height:1.3}.preview-card-meta{display:flex;align-items:center;gap:6px;font-size:14px;color:#94a3b8}.preview-meta-item{font-weight:500}.preview-meta-separator{color:#64748b}.preview-card-footer{padding:12px 16px 14px;flex-shrink:0}.preview-launch-button{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:600;text-decoration:none;cursor:pointer;box-shadow:0 2px 8px #3b82f64d;transition:box-shadow .2s ease,transform .2s ease}.preview-launch-button:hover{box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}.preview-launch-button:active{transform:translateY(0)}*{box-sizing:border-box}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:var(--radius-sm)}button:focus-visible,.quiz-option:focus-visible{outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;background:var(--color-primary);color:#fff;padding:8px;text-decoration:none;z-index:1000}.skip-link:focus{top:0}html,body,#app{margin:0;width:100%;height:100%}body{overflow:hidden}.app-shell{display:flex;flex-direction:column;gap:12px;padding:14px;height:100%}.topbar,.viewer-panel,.side-panel,.library-view{border:1px solid rgba(15,23,42,.08);background:#fffffffa;box-shadow:0 1px 3px #0f172a0a;border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-base)}.topbar{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:14px 16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar-left{display:flex;flex-direction:column;align-items:flex-start;gap:8px;flex:1;min-width:0}.topbar-branding{display:flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0;transition:opacity var(--transition-fast)}.topbar-branding:hover{opacity:.8}.topbar-logo{width:32px;height:auto;flex-shrink:0}.topbar-wordmark{font-size:1.3rem;font-weight:700;color:#0f172a;letter-spacing:-.02em;line-height:1}.topbar-title{min-width:0;width:100%}.back-button{flex-shrink:0;font-weight:500;color:#64748b;background:transparent;padding:6px 12px}.back-button:hover:not(:disabled){background:#0f172a0a;color:#0f172a;transform:translate(-2px)}.back-button .btn-icon{margin-right:2px}.topbar h1{margin:0;font-size:clamp(1.75rem,2.5vw,2.25rem);font-weight:700;letter-spacing:-.03em;background:linear-gradient(135deg,#0f172a,#334155);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.topbar p{margin:6px 0 0;color:#475569;font-size:.975rem;font-weight:500;letter-spacing:-.01em}.save-status-line{margin:8px 0 0;display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:#64748b;line-height:1.2;flex-wrap:wrap}.save-status-line .icon{width:14px;height:14px;opacity:.9}.status-sep{opacity:.5}.status-folder-name{color:#334155;font-weight:600}.topbar-actions{display:flex;align-items:center;gap:8px}.student-view-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;font-size:.875rem;font-weight:600;text-decoration:none;transition:all var(--transition-fast);letter-spacing:-.01em;box-shadow:0 1px 3px #3b82f64d}.student-view-btn:hover{background:var(--color-primary-hover);box-shadow:0 2px 6px #3b82f666;transform:translateY(-1px)}.student-view-btn .icon{width:14px;height:14px}.fullscreen-btn{margin-left:4px}button{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;border-radius:var(--radius-md);padding:9px 16px;background:#0f172a0a;color:#475569;font:inherit;font-size:.9375rem;font-weight:500;letter-spacing:-.01em;cursor:pointer;transition:all var(--transition-fast);position:relative}button:hover:not(:disabled){background:#0f172a14;color:#0f172a}button:active:not(:disabled){transform:scale(.98)}button:disabled{opacity:.4;cursor:not-allowed}button.active{background:#0f172a;color:#fff;font-weight:600}button.active:hover:not(:disabled){background:#334155;color:#fff}button.danger{color:#dc2626}button.danger:hover:not(:disabled){background:#ef444414;color:#b91c1c}button.primary{background:var(--color-primary);color:#fff;font-weight:600}button.primary:hover:not(:disabled){background:var(--color-primary-hover)}button.ghost{background:transparent;color:#64748b}button.ghost:hover:not(:disabled){background:#0f172a0a;color:#475569}.icon{flex-shrink:0}button .icon{transition:transform var(--transition-fast)}button:hover:not(:disabled) .icon{transform:scale(1.05)}.viewer-layout{display:grid;grid-template-columns:minmax(0,1fr) 410px;gap:12px;flex:1;min-height:0}.viewer-panel,.side-panel,.library-view{padding:14px}.viewer-panel{display:flex;flex-direction:column;align-items:center;gap:9px;overflow:hidden}.canvas-shell,.author-toolbar,.author-quickbar,.slider-wrap,.help-text{width:min(100%,78vh)}.canvas-shell{position:relative;aspect-ratio:1 / 1;min-height:280px}:fullscreen .canvas-shell,::backdrop .canvas-shell{width:auto;height:100vh;max-width:100vh;margin:0 auto}.study-canvas{display:block;width:100%;height:100%;border-radius:var(--radius-lg);border:2px solid rgba(71,85,105,.95);background:linear-gradient(135deg,#020817,#0f1729,#0b1b3a);box-shadow:var(--shadow-xl),inset 0 1px 2px #0000004d;transition:all var(--transition-base)}.study-canvas:hover{border-color:#3b82f699;box-shadow:var(--shadow-xl),0 0 0 1px #3b82f64d,inset 0 1px 2px #0000004d}.author-quickbar{display:flex;align-items:center;justify-content:space-between;gap:4px}.author-quickbar.top{margin-bottom:0}.toolbar-group{display:flex;align-items:center;gap:4px}.toolbar-group.left{justify-content:flex-start}.toolbar-group.right{justify-content:flex-end}.icon-btn{padding:8px;min-width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center}.toolbar-divider{width:1px;height:24px;background:#0f172a1f;margin:0 4px}.contour-toolbar-group{display:flex;align-items:center;gap:4px}.contour-btn{padding:6px 12px;min-width:auto;height:36px;font-size:.875rem;font-weight:600;background:#0f172a0a;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);transition:all var(--transition-fast)}.contour-btn:hover{background:#0f172a14;border-color:#0f172a29}.contour-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.delete-confirmation{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);animation:expandIn .2s cubic-bezier(.4,0,.2,1)}@keyframes expandIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.delete-confirmation-text{font-size:.875rem;font-weight:500;color:#991b1b;white-space:nowrap}.btn-sm{padding:6px 12px;font-size:.875rem;height:auto;min-width:auto;display:inline-flex;align-items:center;gap:6px}.author-toolbar{border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-lg);padding:8px;background:#fffffff2;box-shadow:0 1px 3px #0f172a0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.slider-wrap{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px}input[type=range]{width:100%;height:32px;border-radius:var(--radius-full);accent-color:var(--color-primary);background:linear-gradient(180deg,#dbeafe,#bfdbfe);box-shadow:inset 0 2px 4px #3b82f626;transition:all var(--transition-base);cursor:pointer}input[type=range]:hover{background:linear-gradient(180deg,#bfdbfe,#93c5fd);box-shadow:inset 0 2px 4px #3b82f640,0 0 0 4px #3b82f614}input[type=range]:focus{outline:none;box-shadow:inset 0 2px 4px #3b82f640,0 0 0 4px #3b82f626}.help-text{margin:0;color:#334155;font-size:.95rem}.side-panel{display:flex;flex-direction:column;gap:6px;font-size:.98rem;overflow:hidden;position:relative}.topbar-cta{display:flex;align-items:center;gap:12px;padding:8px 16px;background:linear-gradient(135deg,#3b82f614,#2563eb1f);border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-md);flex-shrink:1;min-width:0;margin-right:12px}.topbar-cta-message{font-size:.875rem;color:#475569;font-weight:500;text-align:right;flex:1;min-width:0;line-height:1.3}.topbar-cta-link{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;background:var(--color-primary);color:#fff;font-size:.875rem;font-weight:600;text-decoration:none;border-radius:var(--radius-sm);white-space:nowrap;transition:all var(--transition-fast);box-shadow:0 1px 3px #3b82f64d}.topbar-cta-link:hover{background:var(--color-primary-hover);box-shadow:0 2px 6px #3b82f666;transform:translateY(-1px)}.panel-sticky-header{flex-shrink:0;background:#fff;position:sticky;top:0;z-index:10;padding-bottom:8px}.panel-scrollable{flex:1;overflow-y:auto;overflow-x:hidden;padding-right:4px}.panel-scrollable::-webkit-scrollbar{width:16px}.panel-scrollable::-webkit-scrollbar-track{background:#0f172a0f;border-radius:var(--radius-lg);margin:4px 0}.panel-scrollable::-webkit-scrollbar-thumb{background:#0f172a40;border-radius:var(--radius-lg);border:3px solid transparent;background-clip:padding-box;transition:background var(--transition-fast)}.panel-scrollable::-webkit-scrollbar-thumb:hover{background:#0f172a66;border:2px solid transparent;background-clip:padding-box}.panel-scrollable::-webkit-scrollbar-thumb:active{background:#0f172a8c;background-clip:padding-box}.panel-scrollable{scrollbar-width:auto;scrollbar-color:rgba(15,23,42,.25) rgba(15,23,42,.06);overflow-y:scroll}.side-panel h2,.side-panel h3{margin:0;letter-spacing:-.01em}.structure-name{margin:2px 0;font-size:1.18rem;font-weight:730}.structure-name.placeholder{visibility:hidden;min-height:1.18rem}.anatomy-details-content{min-height:4rem}.panel-kicker{margin:0;text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;font-weight:640;color:#64748b}.explore-card{border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-lg);padding:16px;background:#fff;box-shadow:0 1px 3px #0f172a0a;transition:all var(--transition-base)}.explore-card:hover{border-color:#0f172a1f;box-shadow:0 4px 12px #0f172a0f}.explore-card-label{margin:0;font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:#64748b;font-weight:640}.explore-description{margin:4px 0 0}.anatomy-list{margin-top:20px}.anatomy-list h3{margin:0 0 12px;font-size:.95rem;font-weight:600;color:#0f172a}.anatomy-list-items{display:flex;flex-direction:column;gap:4px}.anatomy-list-item{text-align:left;justify-content:flex-start;padding:10px 14px;background:#0f172a08;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-md);font-size:.9rem;color:#334155;cursor:pointer;transition:all var(--transition-fast)}.anatomy-list-item:hover:not(.active){background:#3b82f614;border-color:var(--color-primary);color:var(--color-primary);transform:translate(2px)}.anatomy-list-item.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:600;box-shadow:0 1px 3px #3b82f64d}.anatomy-list-item.active:hover{background:var(--color-primary-hover);transform:translate(2px)}.anatomy-list-item.hovered:not(.active){border-color:var(--color-primary);background:#3b82f626}.anatomy-list-full{padding-top:8px;padding-bottom:8px}.report-collapse{border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-lg);padding:14px 16px;background:#fff;box-shadow:0 1px 3px #0f172a0a;transition:all var(--transition-base)}.report-collapse:hover{border-color:#0f172a1f}.report-collapse summary{cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:600;padding:4px;border-radius:var(--radius-sm);transition:all var(--transition-fast);color:#0f172a}.report-collapse summary:hover{background:#0f172a0a}.report-block{margin-top:8px;display:grid;gap:8px}.report-block p{margin:0;line-height:1.4}.report-content{display:flex;flex-direction:column;gap:24px}.report-section{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-lg);padding:20px;box-shadow:0 1px 3px #0f172a0a}.report-section h3{margin:0 0 12px;font-size:1.1rem;font-weight:700;color:var(--color-primary);border-bottom:2px solid rgba(59,130,246,.15);padding-bottom:8px}.report-section p{margin:0;line-height:1.6;color:#334155;font-size:1rem;white-space:pre-wrap;word-wrap:break-word}.muted-text{margin:0;color:#475569;font-size:.875rem}.contour-selector{padding:14px;border:1px solid rgba(15,23,42,.08);border-radius:var(--radius-lg);background:#f8fafc80}.contour-selector label{display:block;margin:0 0 10px;font-weight:600;font-size:.9375rem}.contour-selector label .muted-text{font-weight:400;margin-left:4px}.contour-buttons{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.contour-buttons button{min-width:44px;padding:7px 12px;font-size:.875rem}.danger-zone{margin-top:24px;padding:16px;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-lg);background:#fef2f280}.danger-zone h3{margin:0 0 8px;color:#991b1b;font-size:.9375rem;font-weight:600}.danger-zone .muted-text{color:#7f1d1d;margin-bottom:12px}.delete-structure-confirmation{display:flex;flex-direction:column;gap:12px;padding:14px;background:#ef444414;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);animation:expandIn .2s cubic-bezier(.4,0,.2,1)}.delete-confirmation-prompt{margin:0;font-weight:600;color:#991b1b;font-size:.9375rem}.delete-confirmation-actions{display:flex;gap:8px}.delete-confirmation-actions button{flex:1}button.full-width{width:100%}hr{border:none;border-top:1px solid rgba(15,23,42,.08);margin:20px 0}.side-panel label{display:block;margin:7px 0 4px;font-weight:650}.side-panel input[type=text],.side-panel select,.side-panel textarea,.modal-card input[type=text],.modal-card textarea{width:100%;border:1.5px solid rgba(148,163,184,.4);border-radius:var(--radius-md);padding:10px 14px;margin:0;font:inherit;font-size:.95rem;background:#fff;transition:all var(--transition-base);box-shadow:0 1px 2px #0f172a0d}.side-panel input[type=text]:hover,.side-panel select:hover,.side-panel textarea:hover,.modal-card input[type=text]:hover,.modal-card textarea:hover{border-color:#94a3b899}.side-panel input[type=text]:focus,.side-panel select:focus,.side-panel textarea:focus,.modal-card input[type=text]:focus,.modal-card textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px #3b82f61f,0 1px 2px #0f172a0d}.side-panel textarea,.modal-card textarea{min-height:100px;resize:vertical;line-height:1.5}.panel-tabs{display:inline-flex;gap:3px;border-radius:var(--radius-md);padding:3px;background:#0f172a0a;width:fit-content}.panel-tabs button{border:0;margin:0;padding:7px 16px;min-width:0;font-size:.875rem;font-weight:500}.panel-tabs button.active{background:#fff;color:#0f172a;font-weight:600;box-shadow:0 1px 2px #0f172a14}.panel-tabs button:not(.active){background:transparent;color:#64748b}.panel-tabs button:not(.active):hover:not(:disabled){background:#0f172a0f;color:#475569}.panel-tabs.full-width{width:100%}.panel-tabs.full-width button{flex:1}.mode-switcher{display:flex;gap:3px;border-radius:var(--radius-md);padding:3px;background:#0f172a0a;margin-bottom:16px}.mode-switcher button{flex:1;border:0;margin:0;padding:10px 16px;min-width:0;font-size:.9375rem;font-weight:500;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.mode-switcher button.active{background:#fff;color:#0f172a;font-weight:600;box-shadow:0 1px 3px #0f172a1a}.mode-switcher button:not(.active){background:transparent;color:#64748b}.mode-switcher button:not(.active):hover{background:#0f172a0f;color:#475569}.author-controls{display:flex;flex-wrap:wrap;gap:8px;margin:2px 0}.structure-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.structure-chip{padding:8px 14px;font-size:.875rem;font-weight:500;background:#0f172a0a;border:1px solid rgba(15,23,42,.12);border-radius:var(--radius-full);color:#475569;cursor:pointer;transition:all var(--transition-fast)}.structure-chip:hover{background:#0f172a14;border-color:#0f172a33;color:#0f172a}.structure-chip.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:600;box-shadow:0 1px 3px #3b82f64d}.checkbox-row{display:flex;align-items:center;gap:10px;margin:12px 0;font-size:.95rem;cursor:pointer;padding:8px;border-radius:var(--radius-md);transition:all var(--transition-fast)}.checkbox-row:hover{background:#3b82f60d}.checkbox-row input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary);transition:all var(--transition-fast)}.checkbox-row input[type=checkbox]:hover{transform:scale(1.1)}.quiz-sticky-header{padding-bottom:16px;border-bottom:2px solid rgba(15,23,42,.06)}.quiz-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.quiz-header h2{margin:0}.streak-badge{display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;padding:8px 14px;border-radius:var(--radius-full);font-weight:700;box-shadow:0 4px 12px #f59e0b66}.streak-fire{font-size:1.3rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.streak-badge-count{font-size:1.2rem;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.15)}.streak-progress-card{background:linear-gradient(135deg,#a855f71a,#ec48991a);border:2px solid transparent;background-clip:padding-box;border-radius:var(--radius-lg);padding:16px;display:flex;flex-direction:column;align-items:center;gap:12px;position:relative;overflow:hidden;will-change:transform,opacity;backface-visibility:hidden;-webkit-backface-visibility:hidden}.streak-progress-card.resetting{animation:streakReset .6s cubic-bezier(.68,-.55,.27,1.55)}@keyframes streakReset{0%{transform:scale(1) translateZ(0);opacity:1}30%{transform:scale(.9) translateZ(0);opacity:.5}to{transform:scale(1) translateZ(0);opacity:1}}.streak-progress-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-lg);padding:2px;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude}.streak-goal-text{margin:0;font-size:.9rem;font-weight:600;color:#7c3aed;text-align:center}.streak-dots{display:flex;gap:12px}.streak-dot{width:36px;height:36px;border-radius:50%;background:#a855f71a;border:3px solid rgba(168,85,247,.25);transition:all .3s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;font-size:.9rem;position:relative;will-change:transform;backface-visibility:hidden;-webkit-backface-visibility:hidden}.streak-dot.filled{background:linear-gradient(135deg,#a855f7,#ec4899);border-color:#a855f7;box-shadow:0 0 16px #a855f799,0 4px 12px #a855f766;animation:streakDotPop .4s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes streakDotPop{0%{transform:scale(.3) translateZ(0)}50%{transform:scale(1.2) translateZ(0)}to{transform:scale(1.1) translateZ(0)}}.streak-dot-check{color:#fff;font-weight:900;font-size:1.2rem;text-shadow:0 2px 4px rgba(0,0,0,.3);will-change:transform,opacity;backface-visibility:hidden;-webkit-backface-visibility:hidden;animation:checkPop .35s cubic-bezier(.34,1.56,.64,1)}@keyframes checkPop{0%{transform:scale(0) translateZ(0);opacity:0}50%{transform:scale(1.3) translateZ(0)}to{transform:scale(1) translateZ(0);opacity:1}}.streak-count-text{margin:0;font-size:.875rem;font-weight:700;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.streak-celebration-wave{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 0%,rgba(251,191,36,.2) 30%,rgba(245,158,11,.4) 50%,rgba(245,158,11,.6) 70%,rgba(245,158,11,.8) 100%);border-radius:var(--radius-lg);display:flex;align-items:flex-end;justify-content:center;padding-bottom:20px;z-index:10;will-change:transform;backface-visibility:hidden;-webkit-backface-visibility:hidden;animation:waveRiseAndFall 1.8s cubic-bezier(.4,0,.2,1) forwards}@keyframes waveRiseAndFall{0%{transform:translateY(100%) translateZ(0)}40%{transform:translateY(0) translateZ(0)}55%{transform:translateY(0) translateZ(0)}to{transform:translateY(100%) translateZ(0)}}.streak-celebration-text{margin:0;color:#fff;font-size:1rem;font-weight:700;text-shadow:0 2px 6px rgba(0,0,0,.3);letter-spacing:.5px;will-change:opacity;backface-visibility:hidden;-webkit-backface-visibility:hidden;animation:textFadeInOut 1.8s cubic-bezier(.4,0,.2,1) forwards}@keyframes textFadeInOut{0%{opacity:0}40%{opacity:1}55%{opacity:1}to{opacity:0}}.quiz-prompt{margin:0 0 16px;font-size:1.05rem;font-weight:500}.quiz-scrollable{padding-bottom:16px}.quiz-options{display:grid;gap:10px;margin-bottom:16px}.quiz-option{border-radius:var(--radius-lg);border:2px solid rgba(15,23,42,.1);text-align:left;padding:14px 18px;font-size:1.05rem;font-weight:500;letter-spacing:-.015em;transition:all var(--transition-base);background:#fff;display:flex;align-items:center;gap:10px}.quiz-option-letter{font-weight:700;color:#0f172a66;min-width:28px}.quiz-option-text{flex:1}.quiz-option:hover:not(.correct):not(.incorrect){border-color:#0f172a33;background:#0f172a05}.quiz-option.correct{border-color:var(--color-success);background:#dcfce7;color:#166534;font-weight:600;animation:correctPulse .5s ease}.quiz-option.correct .quiz-option-letter{color:#166534}.quiz-option.incorrect{border-color:var(--color-error);background:#fee2e2;color:#991b1b;font-weight:600;animation:shake .4s ease}.quiz-option.incorrect .quiz-option-letter{color:#991b1b}@keyframes correctPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.quiz-sticky-footer{flex-shrink:0;padding-top:16px;background:#fff;position:sticky;bottom:0;border-top:2px solid rgba(15,23,42,.06);margin-top:auto}.quiz-next-large{width:100%;background:var(--color-primary);color:#fff;font-weight:600;font-size:1.1rem;padding:16px 24px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 2px 8px #3b82f633;transition:all var(--transition-base)}.quiz-next-large:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.quiz-next-large .icon{transition:transform var(--transition-fast)}.quiz-next-large:hover .icon{transform:translate(3px)}.keyboard-hint{margin:10px 0 0;text-align:center;font-size:.85rem;color:#64748b;font-weight:500}.keyboard-hint kbd{display:inline-block;padding:2px 8px;background:linear-gradient(180deg,#f8fafc,#e2e8f0);border:1px solid #cbd5e1;border-radius:4px;font-family:ui-monospace,monospace;font-size:.85rem;font-weight:600;color:#334155;box-shadow:0 2px #cbd5e1,0 3px 2px #0000001a;margin:0 3px}.quiz-result{margin-top:14px;font-size:1.2rem;font-weight:760}.quiz-result.good{color:#15803d}.quiz-result.bad{color:#b91c1c}.library-view{display:flex;flex-direction:column;gap:14px;overflow:auto}.library-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 1px 3px #0f172a0d}.library-table thead{background:#0f172a0a;border-bottom:2px solid rgba(15,23,42,.08)}.library-table th{padding:14px 16px;text-align:left;font-weight:600;font-size:.875rem;color:#475569;text-transform:uppercase;letter-spacing:.05em}.library-table tbody tr{border-bottom:1px solid rgba(15,23,42,.06);cursor:pointer;transition:all var(--transition-fast)}.library-table tbody tr:hover{background:#3b82f60a}.library-table tbody tr:last-child{border-bottom:none}.library-table td{padding:16px;color:#334155;font-size:.9375rem}.library-table-name{font-weight:600;color:#0f172a}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:grid;place-items:center;z-index:300;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{width:min(100%,560px);max-height:calc(100vh - 40px);overflow:auto;border-radius:var(--radius-xl);border:1px solid rgba(15,23,42,.08);background:#fff;box-shadow:0 20px 40px #0f172a26;padding:28px;animation:modalSlideIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-card.large{width:min(100%,740px)}.modal-card h3{margin:0 0 10px;font-size:1.4rem}.modal-card p{margin:0 0 10px;color:#334155}.modal-card label{display:block;margin:10px 0 4px;font-weight:650}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.modal-actions .danger{border-color:#dc2626;color:#b91c1c}.embed-code{min-height:160px;font-family:SF Mono,Menlo,monospace;font-size:.85rem;line-height:1.35}.toast{position:fixed;right:16px;bottom:20px;z-index:350;border-radius:var(--radius-lg);padding:12px 16px 12px 14px;border:1px solid rgba(15,23,42,.08);background:#fff;font-weight:500;font-size:.9375rem;box-shadow:0 8px 24px #0f172a1f;animation:toastSlideIn .3s cubic-bezier(.34,1.56,.64,1);overflow:hidden}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(20px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}.toast.success{color:#166534;border-left:4px solid var(--color-success)}.toast.error{color:#991b1b;border-left:4px solid var(--color-error)}.toast.info{color:#0369a1;border-left:4px solid var(--color-primary)}.confetti-layer{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.confetti-piece{position:absolute;top:-16px;width:10px;height:16px;border-radius:2px;opacity:.95;transform:rotate(8deg);animation:confetti-fall 1.2s ease-in forwards}.confetti-piece:nth-child(4n+1){background:#f43f5e}.confetti-piece:nth-child(4n+2){background:#f59e0b}.confetti-piece:nth-child(4n+3){background:#22c55e}.confetti-piece:nth-child(4n){background:#38bdf8}@keyframes confetti-fall{0%{transform:translateZ(0) rotate(0);opacity:1}to{transform:translate3d(20px,105%,0) rotate(520deg);opacity:0}}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(59,130,246,.2);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,#e2e8f0cc,#f1f5f9e6,#e2e8f0cc);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-text{height:1em;margin:.5em 0}.skeleton-title{height:1.5em;width:60%;margin:.5em 0}.skeleton-card{padding:18px;border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-lg)}.structure-autocomplete{position:relative}.structure-autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:1px solid rgba(15,23,42,.1);border-radius:var(--radius-lg);box-shadow:0 4px 12px #0000001a;max-height:300px;overflow-y:auto;z-index:100}.structure-autocomplete-item{width:100%;text-align:left;padding:10px 14px;border:none;background:#fff;font-size:1rem;cursor:pointer;transition:all var(--transition-fast);border-bottom:1px solid rgba(15,23,42,.05)}.structure-autocomplete-item:last-child{border-bottom:none}.structure-autocomplete-item:hover{background:#3b82f614;color:var(--color-primary)}.structure-autocomplete-item.active{background:#3b82f61f;color:var(--color-primary);font-weight:600}.fade-enter{opacity:0;transform:translateY(10px)}.fade-enter-active{opacity:1;transform:translateY(0);transition:all var(--transition-base)}.fade-exit{opacity:1}.fade-exit-active{opacity:0;transition:opacity var(--transition-fast)}@media(max-width:1150px){body{overflow:auto}.app-shell{height:auto;min-height:100%;overflow:visible;padding:10px;gap:10px}.viewer-layout{grid-template-columns:1fr;min-height:auto;gap:10px}.side-panel{max-height:none}.topbar,.viewer-panel,.side-panel,.library-view{border-radius:var(--radius-lg)}}.mobile-menu-button-topbar,.mobile-close-button,.mobile-drawer-overlay{display:none}@media(max-width:760px){.mobile-menu-button-topbar{display:flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;border-radius:var(--radius-md);padding:10px;box-shadow:0 2px 8px #3b82f64d}.side-panel{position:fixed;top:0;right:-100%;width:85%;max-width:380px;height:100vh;background:#fff;z-index:1000;transition:right .3s ease;box-shadow:-4px 0 20px #00000026;padding:16px;overflow-y:auto}.side-panel.mobile-open{right:0}.mobile-drawer-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-close-button{display:flex;align-items:center;justify-content:center;position:absolute;top:16px;right:16px;z-index:10;background:#0f172a14;border-radius:var(--radius-md);padding:8px}.viewer-layout{grid-template-columns:1fr}.app-shell{padding:8px;gap:8px}.topbar{flex-direction:column;align-items:flex-start;padding:12px 14px;gap:12px}.topbar-left{width:100%}.back-button{align-self:flex-start}.topbar h1{font-size:clamp(1.5rem,5vw,1.85rem)}.topbar p{font-size:.9rem}.topbar-actions{width:100%;flex-wrap:wrap;gap:6px}.student-view-btn{flex:1;justify-content:center;font-size:.8125rem;padding:8px 12px}.fullscreen-btn{margin-left:0}.canvas-shell,.author-toolbar,.author-quickbar,.slider-wrap,.help-text{width:100%}.canvas-shell{min-height:240px}.panel-tabs{width:100%}.panel-tabs button{flex:1;min-width:0}.library-table{font-size:.875rem}.library-table th,.library-table td{padding:12px}.library-table th{font-size:.8125rem}.modal-overlay{padding:12px}.modal-card{padding:18px}button{font-size:.9rem;padding:9px 14px}.author-quickbar{gap:5px}.author-quickbar button{font-size:.85rem;padding:8px 12px}.icon-btn{min-width:40px;height:40px;padding:10px}.toolbar-divider{margin:0 2px}.quiz-option{padding:12px 14px;font-size:1rem}}@media(max-width:480px){.topbar h1{font-size:1.35rem}.viewer-layout{gap:8px}.author-quickbar button{flex:1;justify-content:center}.btn-icon{display:none}.toast{right:12px;bottom:12px;left:12px;padding:12px 14px;font-size:.875rem}}@media(hover:none)and (pointer:coarse){button{min-height:44px;padding:12px 18px}.quiz-option{min-height:52px}input[type=range]{height:40px}.checkbox-row input[type=checkbox]{width:22px;height:22px}}@media(max-width:915px)and (orientation:landscape){.canvas-shell{max-height:60vh}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
