@font-face{font-family:Noto Music;src:url(/assets/NotoMusic-regular-ZbJvDP-i.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}html,body{margin:0;height:100%;font-family:Arial,Helvetica,sans-serif;overflow-x:hidden}*{box-sizing:border-box}.view-hidden-my-lessons{display:none!important;visibility:hidden!important}.auth-must-hide{display:none!important}header{position:sticky;top:0;width:100%;z-index:1000;display:flex;justify-content:space-between;align-items:center;padding:5px 14px;background:linear-gradient(90deg,#f90,#fc0);color:#fff;font-weight:700;transition:top .3s ease-in-out}header #leftBar{display:flex;align-items:center;gap:4px;flex-wrap:wrap}#viewer{display:flex;height:100%;position:relative;z-index:0;overflow:hidden}.modal{display:none;position:fixed;z-index:100;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#0006;justify-content:center;align-items:center}.modal-content{background-color:#fefefe;margin:5% auto;padding:20px;border:1px solid #888;width:80%;max-width:500px;border-radius:5px;position:relative;max-height:90vh;overflow-y:auto}.modal-content.wide{max-width:800px;width:90%}.modal-close-btn{color:#aaa;position:absolute;top:18px;right:20px;font-size:28px;font-weight:700;cursor:pointer}.modal-close-btn:hover,.modal-close-btn:focus{color:#000;text-decoration:none;cursor:pointer}.button-explanation-modal{display:none;position:fixed;z-index:10000;left:0;top:0;width:100%;height:100%;background-color:#00000080;justify-content:center;align-items:center}.button-explanation-content{background-color:#fff;margin:5% auto;padding:25px;border-radius:8px;width:90%;max-width:500px;box-shadow:0 4px 15px #0003;position:relative;animation:modalFadeIn .3s ease-out}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.button-explanation-header{display:flex;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #f0f0f0}.button-explanation-icon{font-size:24px;margin-right:12px;width:30px;text-align:center}.button-explanation-title{font-size:20px;font-weight:700;color:#333;margin:0}.button-explanation-description{font-size:16px;line-height:1.5;color:#555;margin-bottom:20px}.login-prompt{background:linear-gradient(90deg,#f90,#fc0);color:#fff;padding:15px;border-radius:5px;text-align:center;margin-top:15px}.login-prompt-text{margin:0 0 10px;font-weight:700}.login-button{background:#fff;color:#f90;border:none;padding:8px 20px;border-radius:4px;font-weight:700;cursor:pointer;transition:background-color .3s}.login-button:hover{background:#f5f5f5}.toolbar-icon.logged-out-preview{position:relative;opacity:.8;cursor:help!important}body[data-current-view=pdf-list] #playSubmittedVideoBtn,body[data-current-view=pdf-list] #lessonLogBtn,body[data-current-view=pdf-list] #sendPaymentReminderBtn,body[data-current-view=pdf-list] #sendLessonLinkBtn,body[data-current-view=pdf-list] #recordForTeacherBtn,body[data-current-view=my-lessons] #playSubmittedVideoBtn,body[data-current-view=my-lessons] #lessonLogBtn,body[data-current-view=my-lessons] #sendPaymentReminderBtn,body[data-current-view=my-lessons] #sendLessonLinkBtn,body[data-current-view=manage-students] #playSubmittedVideoBtn,body[data-current-view=manage-students] #lessonLogBtn,body[data-current-view=manage-students] #sendPaymentReminderBtn,body[data-current-view=manage-students] #sendLessonLinkBtn,body[data-current-view=manage-students] #recordForTeacherBtn{display:none!important;visibility:hidden!important}.toolbar-icon.logged-out-preview:before{content:"ℹ️";position:absolute;top:-5px;right:-5px;font-size:10px;background:#fff;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #0000004d;z-index:1}.toolbar-icon.logged-out-preview:hover{opacity:1;transform:scale(1.05)}.toolbar-icon.logged-out-preview{display:inline-block!important;visibility:visible!important}#manageStudentsModal{display:none;position:fixed;z-index:100;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#0006;padding-top:60px}#manageStudentsModal .modal-content{width:90%;max-width:600px}#studentListTable{width:100%;border-collapse:collapse;margin-top:15px}#studentListTable th,#studentListTable td{border:1px solid #ddd;padding:8px;text-align:left}#studentListTable th{background-color:#f2f2f2}#studentListTable .student-actions button{margin-right:5px;padding:3px 6px;font-size:.9em}#addEditStudentModal{display:none;position:fixed;z-index:101;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#00000080;padding-top:7px;padding-bottom:7px}#addEditStudentForm label,#addEditStudentForm .form-section-label,#addEditStudentForm input,#addEditStudentForm select{display:block;margin-bottom:10px;width:100%}#addEditStudentForm button{margin-top:15px;margin-right:10px}#addEditStudentModal .modal-content{background:linear-gradient(180deg,#fffaf0,#fff5e6);border:1px solid #ffcc80;box-shadow:0 5px 15px #0003;max-width:700px;width:90%}#addEditStudentTitle{color:#d35400;margin-bottom:20px}#addEditStudentForm label,#addEditStudentForm .form-section-label{font-weight:700;color:#555;margin-bottom:5px}#addEditStudentForm input[type=email],#addEditStudentForm input[type=text],#addEditStudentForm select{padding:8px;border:1px solid #ccc;border-radius:4px;margin-bottom:15px}#addEditStudentForm input[readonly]{background-color:#eee;cursor:not-allowed}#submissionDaysContainer label:hover{background-color:#fff0e0!important}.teaching-mode-btn:hover{opacity:.9;transform:translateY(-1px)}.teaching-mode-btn.active{background-color:#6f42c1!important;box-shadow:0 2px 8px #6f42c14d}.teaching-mode-btn:not(.active){background-color:#6c757d!important}.toggle-switch .toggle-slider{background-color:#ccc!important}.toggle-switch input:checked+.toggle-slider{background-color:#4a2c7a!important}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 1px #6f42c1}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 1px 3px #0000004d}.toggle-switch input:checked+.toggle-slider:before{transform:translate(26px)}#addEditStudentForm .form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}#addEditStudentForm .form-actions button{padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-weight:700}#addEditStudentForm #saveStudentBtn{background:linear-gradient(45deg,#f90,#fc0);color:#fff}#addEditStudentForm #cancelStudentBtn{background-color:#ccc;color:#333}#editStudentStatusMsg{margin-top:15px;padding:10px;border-radius:4px;display:none;text-align:center}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.modal-header .modal-close-btn{position:static;font-size:24px}#messageAllStudentsModal{display:none;position:fixed;z-index:101;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#00000080;align-items:center;justify-content:center}#messageAllStudentsModal.show{display:flex}#messageAllStudentsModal .modal-content{background:linear-gradient(180deg,#fffaf0,#fff5e6);border:1px solid #ffcc80;box-shadow:0 5px 15px #0003;max-width:600px;width:90%;margin:0;position:relative;border-radius:8px;max-height:90vh;overflow-y:auto}#messageAllStudentsTitle{color:#d35400;margin-bottom:0;font-size:20px}#messageAllStudentsForm label{display:block;margin-bottom:5px;margin-top:15px;font-weight:700;color:#2c3e50;font-size:14px}#messageAllStudentsForm input,#messageAllStudentsForm textarea{display:block;width:100%;padding:8px 12px;margin-bottom:10px;border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;box-sizing:border-box}#messageAllStudentsForm input:focus,#messageAllStudentsForm textarea:focus{border-color:#d35400;outline:none;box-shadow:0 0 5px #d354004d}#messageAllStudentsForm textarea{font-family:inherit;line-height:1.4}#messageAllStudentsStatusMsg{padding:10px;margin:10px 0;border-radius:4px;background-color:#d4edda;border:1px solid #c3e6cb;color:#155724;font-size:14px}#messageAllStudentsStatusMsg.error{background-color:#f8d7da;border-color:#f5c6cb;color:#721c24}#messageAllStudentsModal .form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:15px;border-top:1px solid #eee}#messageAllStudentsModal .form-actions button{padding:8px 16px;border:none;border-radius:4px;font-size:14px;cursor:pointer;font-family:inherit}#messageAllStudentsModal #cancelMessageBtn{background-color:#6c757d;color:#fff}#messageAllStudentsModal #cancelMessageBtn:hover{background-color:#5a6268}#messageAllStudentsModal #sendMessageBtn{background-color:#d35400;color:#fff}#messageAllStudentsModal #sendMessageBtn:hover{background-color:#b8470f}#messageAllStudentsModal #sendMessageBtn:disabled{background-color:#ccc;cursor:not-allowed}#assignPdfModal{display:none;position:fixed;z-index:102;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#0009;padding-top:70px}#assignPdfModal .modal-content{width:90%;max-width:450px}#assignStudentList{list-style:none;padding:0;margin-top:15px;max-height:250px;overflow-y:auto;border:1px solid #eee}#assignStudentList li{padding:8px 12px;border-bottom:1px solid #eee}#assignStudentList li:last-child{border-bottom:none}#assignStudentList label{display:block;cursor:pointer}#assignStudentList input[type=radio]{margin-right:8px}#assignPdfModal button{margin-top:15px;margin-right:10px}#viewStudentWorkModal{display:none;position:fixed;z-index:102;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#0009;padding-top:70px}#viewStudentWorkModal .modal-content{width:90%;max-width:550px}#assignedPdfList{list-style:none;padding:0;margin-top:15px;max-height:300px;overflow-y:auto;border:1px solid #eee}#assignedPdfList li{padding:10px 15px;border-bottom:1px solid #eee;cursor:pointer}#copyAnnotationsModal{display:none;position:fixed;z-index:103;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#0009;padding-top:90px}#copyAnnotationsModal .modal-content{width:90%;max-width:400px}#copyAnnotationsForm label{display:block;margin-bottom:10px;cursor:pointer}#copyAnnotationsForm input[type=radio]{margin-right:8px}#copyAnnotationsModal button{margin-top:15px;margin-right:10px}#assignedPdfList li:hover{background-color:#f0f0f0}#assignedPdfList li:last-child{border-bottom:none}#viewStudentWorkModal button{margin-top:15px}#lessonLogModal{display:none;position:fixed;z-index:104;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#0009;align-items:center;justify-content:center}#lessonLogModal .modal-content{width:95%;max-width:1000px;max-height:90vh;overflow-y:auto;background-color:#fff;border-radius:8px;box-shadow:0 6px 20px #00000026}#lessonLogControls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:15px;background-color:#f8f9fa;border-radius:6px}#lessonLogControls button{padding:8px 12px;border:none;border-radius:4px;cursor:pointer;font-weight:700;transition:background-color .3s ease}#lessonLogControls button:hover{opacity:.8}#lessonLogControls button:disabled{opacity:.5;cursor:not-allowed}.week-section{margin-bottom:25px;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.week-header{background:linear-gradient(90deg,#f90,#fc0);color:#fff;padding:15px 20px;font-weight:700;font-size:16px}.week-content{padding:20px}.day-section{margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:6px;border-left:4px solid #ff9900}.day-section h4{margin:0 0 10px;color:#333;font-size:16px}.lesson-item{padding:12px;margin-bottom:8px;background:#fff;border-radius:4px;border-left:4px solid #ff9900;box-shadow:0 1px 3px #0000001a;transition:box-shadow .3s ease}.lesson-item:hover{box-shadow:0 2px 6px #00000026}.lesson-item strong{color:#333;font-size:15px}.lesson-item .lesson-meta{color:#666;font-size:13px;margin-top:4px}.lesson-item .lesson-time{color:#666;font-size:12px;text-align:right}.lesson-log-reminder-btn{border:none;background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;border-radius:6px;padding:5px 10px;cursor:pointer;font-size:16px;line-height:1;font-weight:600;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0000002e;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease}.lesson-log-reminder-btn:hover:not([disabled]){transform:translateY(-1px);box-shadow:0 4px 10px #00000038;filter:brightness(1.05)}.lesson-log-reminder-btn:active:not([disabled]){transform:translateY(0);box-shadow:0 1px 3px #0000002e}.lesson-log-reminder-btn[disabled]{pointer-events:none;cursor:wait}.lesson-log-reminder-btn.is-sending{animation:lessonLogReminderPulse .9s ease-in-out infinite alternate}.lesson-log-reminder-btn.is-success{background:linear-gradient(135deg,#4caf50,#2e7d32);box-shadow:0 3px 8px #2e7d3259}@keyframes lessonLogReminderPulse{0%{box-shadow:0 2px 6px #0000002e;transform:scale(.98)}to{box-shadow:0 4px 12px #0000003d;transform:scale(1)}}#modalFileList{list-style:none;padding:0;margin-top:20px;max-height:300px;overflow-y:auto}#modalFileList li{padding:10px;border-bottom:1px solid #eee;cursor:pointer}#modalFileList li:hover{background-color:#f0f0f0}#modalFileList li:last-child{border-bottom:none}.storage-graph-container{background-color:#e9ecef;border-radius:.3rem;height:20px!important;margin-top:5px;width:100%}.storage-graph-fill.exceeded{background-color:#f44336}#addTextBtn.active{background:#00008b;color:#fff}.toolbar-icon{width:34.2px;height:34.2px;border-radius:5px;display:flex;align-items:center;justify-content:center;background-color:#ffffff8c;border:1px solid rgba(0,0,0,.12);transition:all .2s ease;box-shadow:0 1px 3px #00000026;cursor:pointer;padding:0;position:relative}.toolbar-icon:hover{background-color:#ffffffbf;transform:translateY(-1px);box-shadow:0 2px 6px #00000040;transform-style:preserve-3d;isolation:isolate;z-index:1}.toolbar-zoom-container{position:relative;display:none;align-items:center;justify-content:center}.toolbar-icon.zoom-trigger{color:#111;overflow:hidden}.toolbar-icon.zoom-trigger .zoom-trigger-icon{display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%}.toolbar-icon.zoom-trigger .zoom-trigger-icon svg{width:22px;height:22px;stroke:currentColor;stroke-width:2.2;fill:none;stroke-linecap:round;stroke-linejoin:round}.toolbar-zoom-container .zoom-dropdown{position:absolute;top:calc(100% - 2px);left:50%;transform:translate(-50%) translateY(4px);background:linear-gradient(165deg,#0f172af5,#1e293beb);border-radius:14px;border:1px solid rgba(148,163,184,.4);box-shadow:0 18px 36px #0f172a7a;padding:12px;display:none;flex-direction:column;gap:8px;min-width:210px;z-index:1200;transition:background .25s ease,box-shadow .25s ease,transform .18s ease,opacity .18s ease;opacity:0;pointer-events:none;overflow:hidden}.toolbar-zoom-container .zoom-dropdown:after{content:"";position:absolute;top:10px;right:10px;bottom:10px;left:10px;border-radius:10px;background:linear-gradient(140deg,#3b82f614,#ec48990d);pointer-events:none;opacity:0;transition:opacity .2s ease}.toolbar-zoom-container.open .zoom-dropdown,.toolbar-zoom-container:hover .zoom-dropdown,.toolbar-zoom-container:focus-within .zoom-dropdown{display:flex;background:linear-gradient(165deg,#111827fa,#1e293bf0);box-shadow:0 26px 44px #0f172a85;transform:translate(-50%) translateY(8px);opacity:1;pointer-events:auto}.toolbar-zoom-container.open .zoom-dropdown:after,.toolbar-zoom-container:hover .zoom-dropdown:after,.toolbar-zoom-container:focus-within .zoom-dropdown:after{opacity:1}.toolbar-zoom-container .zoom-dropdown button{position:relative;background:#f8fafc14;border:1px solid rgba(148,163,184,.35);border-radius:10px;color:#f8fafc;font-weight:600;font-size:14px;line-height:1.35;padding:7px 12px;cursor:pointer;transition:background .2s ease,transform .2s ease,border-color .2s ease,box-shadow .2s ease,color .2s ease;text-align:left;white-space:nowrap}.toolbar-zoom-container .zoom-dropdown button:hover,.toolbar-zoom-container .zoom-dropdown button:focus{background:#3b82f638;border-color:#60a5faa6;outline:none;transform:translateY(-1px);box-shadow:0 10px 18px #2563eb47;color:#e0f2fe}.toolbar-zoom-container .zoom-dropdown button:disabled{opacity:.6;cursor:progress;transform:none}.toolbar-icon.zoom-trigger.loading{opacity:.6;cursor:progress}.toolbar-icon[data-disable-tooltip=true]:after{display:none!important}.toolbar-icon.active{background-color:#d35400;color:#fff;border-color:#ac4200;box-shadow:0 1px 3px #0000004d,inset 0 1px 5px #0003}.icon-text{font-family:Times New Roman,serif;font-size:20px;font-weight:700;font-style:italic;color:#333;text-shadow:0 1px 1px rgba(255,255,255,.5)}.toolbar-icon.active .icon-text{color:#fff;text-shadow:0 1px 1px rgba(0,0,0,.3)}.toolbar-icon:hover:after{content:attr(data-title);position:absolute;bottom:-28px;left:50%;transform:translate(-50%);background:#333333e6;color:#fff;padding:5px 10px;border-radius:4px;font-size:12px;font-weight:400;white-space:nowrap;z-index:10}#profileButton:hover:after{display:none!important}#favoritesBtn:after,#favoritesBtn:hover:after{content:none!important;display:none!important}.toolbar-button-with-text{width:auto;padding:0 12px}.toolbar-button-with-text .icon-text{white-space:nowrap}.toolbar-icon.promotional-button{background:linear-gradient(45deg,#f90,#fc0);border-color:#f60;position:relative;animation:promotionalPulse 2s infinite}.toolbar-icon.promotional-button:before{content:"⭐";position:absolute;top:-3px;right:-3px;font-size:12px;background:#f60;color:#fff;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-weight:700;z-index:2}.toolbar-icon.promotional-button:hover{background:linear-gradient(45deg,#fa0,#fd0);transform:translateY(-2px) scale(1.05);box-shadow:0 4px 8px #f906}@keyframes promotionalPulse{0%,to{box-shadow:0 0 #ff9900b3}50%{box-shadow:0 0 0 4px #f903}}.teacher-record-btn{background:linear-gradient(135deg,#4caf50,#45a049)!important;border:2px solid #4CAF50!important;box-shadow:0 2px 6px #4caf504d!important}.teacher-record-btn:hover{background:linear-gradient(135deg,#45a049,#4caf50)!important;border-color:#45a049!important;box-shadow:0 3px 8px #4caf5080!important;transform:translateY(-2px)!important}.teacher-record-btn .icon-text{color:#fff!important;text-shadow:0 1px 2px rgba(0,0,0,.3)!important;font-size:18px!important}#pdfArea .student-list-container{padding:20px;background-color:#fff8f0;height:100%;box-sizing:border-box;overflow-y:auto;-webkit-overflow-scrolling:touch;color:#333;text-align:center}#pdfArea .student-list-header{margin-bottom:10px;color:#d35400;text-align:center;font-size:10px}#pdfArea .students-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:20px}.manage-students-title{padding-top:10px;margin-bottom:10px!important}@media (max-width: 900px) and (orientation: landscape){body[data-current-view=manage-students] #pdfArea .student-list-container{overflow:visible!important;height:auto!important;width:100%!important}}@media (max-width: 900px) and (orientation: portrait){body[data-current-view=manage-students] #viewer{flex-direction:column!important;overflow:hidden!important}body[data-current-view=manage-students] #pdfArea{width:100%!important;flex:1!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important}body[data-current-view=manage-students] #videoArea{display:none!important;width:0!important;height:0!important;flex-basis:0!important;flex-grow:0!important;flex-shrink:0!important}body[data-current-view=manage-students] #resizer{display:none!important;width:0!important;height:0!important}body[data-current-view=manage-students] #pdfArea .student-list-container{overflow:visible!important;height:auto!important;width:100%!important;min-height:auto!important}body[data-current-view=pdf-list] #viewer{flex-direction:column!important;overflow:hidden!important}body[data-current-view=pdf-list] #pdfArea{width:100%!important;flex:1!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important;position:relative!important}body[data-current-view=pdf-list].allow-body-scroll-fallback{overflow:auto!important;-webkit-overflow-scrolling:touch!important}body[data-current-view=pdf-list] #videoArea{display:none!important;width:0!important;height:0!important;flex-basis:0!important;flex-grow:0!important;flex-shrink:0!important}body[data-current-view=pdf-list] #resizer{display:none!important;width:0!important;height:0!important}body[data-current-view=pdf-list] #pdfArea.pdf-list-container{overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important;height:100%!important;max-height:100%!important;width:100%!important;padding:20px!important;padding-bottom:calc(64px + env(safe-area-inset-bottom))!important}body[data-current-view=my-lessons] #viewer{flex-direction:column!important;overflow:hidden!important}body[data-current-view=my-lessons] #pdfArea{width:100%!important;flex:1!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important;position:relative!important}body[data-current-view=my-lessons] #videoArea{display:none!important;width:0!important;height:0!important;flex-basis:0!important;flex-grow:0!important;flex-shrink:0!important}body[data-current-view=my-lessons] #resizer{display:none!important;width:0!important;height:0!important}body[data-current-view=my-lessons]{overflow:visible!important}body[data-current-view=student-lessons] #viewer{flex-direction:column!important;overflow:hidden!important}body[data-current-view=student-lessons] #pdfArea{width:100%!important;flex:1!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important;position:relative!important}body[data-current-view=student-lessons] #videoArea{display:none!important;width:0!important;height:0!important;flex-basis:0!important;flex-grow:0!important;flex-shrink:0!important}body[data-current-view=student-lessons] #resizer{display:none!important;width:0!important;height:0!important}body[data-current-view=student-lessons]{overflow:visible!important}}#pdfArea .student-card{background:linear-gradient(45deg,indigo,#8a2be2);border-radius:8px;padding:15px;width:280px;box-shadow:0 2px 5px #0003;color:#fff;text-align:left}#pdfArea .student-card h2{margin-top:0;margin-bottom:5px;font-size:20px}#pdfArea .student-card .card-actions{margin-bottom:10px;display:flex;gap:5px}#pdfArea .student-card .card-actions button{background:none;border:none;color:#fff;cursor:pointer;font-size:1.1em;padding:2px 4px}#pdfArea .student-card .card-actions button:hover{background:#fff3}#pdfArea .lesson-buttons{display:flex;flex-direction:column;gap:8px;margin-top:10px}#pdfArea .lesson-buttons button{background-color:#fff;color:indigo;border:none;padding:8px 12px;border-radius:5px;cursor:pointer;font-size:13px;transition:background-color .3s,color .3s;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#pdfArea .lesson-buttons button:hover{background-color:#ffe5cc;color:#d35400}#pdfArea .lesson-buttons button.lesson-sent{background-color:#e6f4ea;color:#1e7e34;border-left:4px solid #28a745}#pdfArea .lesson-buttons button.lesson-sent:hover{background-color:#d9f0e1;color:#155724}#pdfArea .lesson-buttons button.lesson-pending{background-color:#fdecea;color:#c82333;border-left:4px solid #dc3545}#pdfArea .lesson-buttons button.lesson-pending:hover{background-color:#f9dedb;color:#a71d2a}.open-lesson-btn-full-list.lesson-sent{background-color:#e6f4ea!important;color:#1e7e34!important;border-left:4px solid #28a745!important}.open-lesson-btn-full-list.lesson-pending{background-color:#fdecea!important;color:#c82333!important;border-left:4px solid #dc3545!important}.lesson-item-full-list.lesson-sent-card{border-left:4px solid #28a745;background:#f9fcfa}.lesson-item-full-list.lesson-pending-card{border-left:4px solid #dc3545;background:#fdf6f6}#pdfArea .student-card .student-status{font-size:.9em;margin-bottom:8px;margin-top:0;color:#eee}#pdfArea .student-card .toggle-account-btn{font-size:1.1em}#pdfArea .student-card .toggle-account-btn:hover{background-color:#e0a800}#pdfArea .student-card.deactivated-student-card{opacity:.7}.assign-new-pdf-button,.add-student-button{background:linear-gradient(45deg,#f90,#fc0);color:#000!important;font-weight:700;border:none;border-radius:5px;cursor:pointer}#fingeringWidget{position:absolute;z-index:9999;background:#fffffff2;border:1px solid #ccc;padding:5px;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;-webkit-user-select:none;user-select:none;overflow:visible;width:180px;height:180px;border-radius:50%;background-color:#fffffff2;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);box-shadow:0 5px 15px #0003,0 0 30px #0000001a}#fingeringWidget span{position:absolute;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:700}.annotationText{position:absolute;font-family:Arial,sans-serif;white-space:pre;line-height:1;cursor:pointer;-webkit-user-select:none;user-select:none;pointer-events:auto;border:1px dashed transparent;padding:2px;min-width:10px;min-height:10px;z-index:170}.annotationText.editing{cursor:text;-webkit-user-select:text;user-select:text;border:1px dashed blue;background-color:#c8c8ff33;z-index:175}#pdfArea::-webkit-scrollbar{width:3px;height:3px}#pdfArea::-webkit-scrollbar-track{background:transparent}#pdfArea::-webkit-scrollbar-thumb{background-color:#0000001a;border-radius:5px}#pdfArea:hover::-webkit-scrollbar-thumb{background-color:#0000004d}#pdfArea{scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.fingeringAnnotation{position:absolute;transform:translate(-50%,-50%);font-family:Arial,sans-serif;white-space:pre;line-height:1;cursor:pointer;-webkit-user-select:none;user-select:none;pointer-events:auto;z-index:160;background-color:#ffffff59;padding:2px 6px;border-radius:50px;text-shadow:0 .5px .5px rgba(0,0,0,.35)}.fingeringAnnotation.musicalNotationAnnotation,#fingeringWidget .musical-notation-button{font-family:Noto Music,Segoe UI Symbol,Apple Symbols,Musical Symbols,Noto Sans Symbols,serif!important;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}#pdfArea.pdf-list-container{padding:28px 32px;padding-bottom:calc(64px + env(safe-area-inset-bottom));background:linear-gradient(168deg,#fefefe,#f7f5f0);height:100%;box-sizing:border-box;overflow-y:auto;color:#2c3e50;font-family:Segoe UI,-apple-system,BlinkMacSystemFont,Roboto,Oxygen,Ubuntu,sans-serif}#pdfArea .pdf-list-header{margin-bottom:18px;padding-bottom:14px;border-bottom:2px solid rgba(255,153,0,.18);display:flex;align-items:flex-start;gap:15px}#pdfArea .pdf-list-header h2{margin:0 0 5px;font-size:1.35em;font-weight:700;color:#2c3e50;text-align:left;letter-spacing:-.3px}#pdfArea .pdf-list-header .header-left-content{flex-grow:1}#pdfArea .pdf-upload-section{margin-bottom:10px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}#pdfArea #pdfSearchInput{padding:9px 14px;border:1px solid #d5d5d5;border-radius:8px;font-size:.92em;background:#fff;transition:border-color .2s,box-shadow .2s}#pdfArea #pdfSearchInput:focus{border-color:#f90;box-shadow:0 0 0 3px #ff99001f;outline:none}#pdfArea #uploadBtn{background:linear-gradient(135deg,#f90,#fc0);color:#1a1a1a;font-weight:700;font-size:.9em;padding:9px 18px;border:none;border-radius:8px;cursor:pointer;margin-left:auto;box-shadow:0 2px 6px #ff990038;transition:transform .15s,box-shadow .15s}#pdfArea #uploadBtn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ff990052}#pdfArea #pdfSearchBtn{padding:9px 16px;border:1px solid #d5d5d5;border-radius:8px;cursor:pointer;background:#fff;font-size:.9em;font-weight:600;color:#444;transition:background .15s,border-color .15s}#pdfArea #pdfSearchBtn:hover{background:#f0f0f0;border-color:#bbb}#pdfArea .pdf-list{list-style:none;padding:0 0 40px;margin:0}#pdfArea .pdf-list-item{padding:14px 16px;margin-bottom:6px;background:#fff;border:1px solid #eaeaea;border-radius:10px;display:flex;justify-content:space-between;align-items:center;transition:box-shadow .18s,border-color .18s,transform .12s}#pdfArea .pdf-list-item:hover{box-shadow:0 3px 14px #00000012;border-color:#ddd;transform:translateY(-1px)}#pdfArea .pdf-list-item:last-child{margin-bottom:0}#pdfArea .pdf-name{cursor:pointer;flex-grow:1;margin-right:12px;font-weight:600;font-size:.95em;color:#2c3e50;transition:color .15s}#pdfArea .pdf-name:hover{color:#d35400;text-decoration:none}#pdfArea .delete-pdf-btn{cursor:pointer;padding:6px 8px;font-size:1.05em;margin-left:8px;flex-shrink:0;border-radius:6px;transition:background .15s,transform .12s}#pdfArea .delete-pdf-btn:hover{background:#dc35451a;color:#c0392b;transform:scale(1.12)}#pdfArea #backToStudentMgmtBtn{background-color:#f90;border-color:#e68a00}#pdfArea #backToStudentMgmtBtn .icon-text{color:#333}#pdfArea .assign-pdf-btn{cursor:pointer;padding:6px 8px;font-size:1.1em;margin-left:5px;flex-shrink:0;border-radius:6px;transition:background .15s,transform .12s}#pdfArea .assign-pdf-btn:hover{background:#007bff14;transform:scale(1.1)}#pdfArea .no-pdfs-message{color:#888;font-style:italic;padding:32px 0;text-align:center;font-size:1.05em}#pdfArea .multi-select-btn{padding:9px 16px;border:1px solid #d5d5d5;border-radius:8px;cursor:pointer;background:#fff;font-size:.9em;font-weight:600;color:#444;white-space:nowrap;transition:background .15s,border-color .15s}#pdfArea .multi-select-btn:hover{background:#f0f0f0;border-color:#bbb}#pdfArea .multi-select-action-bar{display:flex;align-items:center;gap:14px;padding:10px 16px;background:linear-gradient(135deg,#fff8e1,#fff3cd);border:1px solid #ffe082;border-radius:10px;margin-bottom:12px;flex-wrap:wrap;box-shadow:0 2px 8px #ffc1071f}#pdfArea .multi-select-all-label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:.9em;font-weight:600;color:#5d4037;white-space:nowrap}#pdfArea .multi-select-count{font-size:.9em;color:#6d4c41;font-weight:600;white-space:nowrap}#pdfArea .delete-selected-btn{padding:8px 18px;border:none;border-radius:8px;cursor:pointer;background:#dc3545;color:#fff;font-weight:700;font-size:.9em;white-space:nowrap;box-shadow:0 2px 6px #dc354533;transition:background .15s,transform .12s,box-shadow .15s}#pdfArea .delete-selected-btn:disabled{background:#d0d0d0;color:#999;cursor:not-allowed;box-shadow:none}#pdfArea .delete-selected-btn:not(:disabled):hover{background:#c0392b;transform:translateY(-1px);box-shadow:0 4px 12px #dc35454d}#pdfArea .cancel-multi-select-btn{padding:8px 18px;border:1px solid #bbb;border-radius:8px;cursor:pointer;background:#fff;font-size:.9em;font-weight:600;color:#555;white-space:nowrap;transition:background .15s,border-color .15s}#pdfArea .cancel-multi-select-btn:hover{background:#f0f0f0;border-color:#999}#pdfArea .multi-select-checkbox{width:18px;height:18px;cursor:pointer;flex-shrink:0;margin-right:10px;accent-color:#ff9900}#pdfArea .multi-select-active .pdf-list-item{cursor:pointer}#pdfArea .multi-select-active .pdf-list-item:hover{background:#fff8e1;border-color:#ffe082}#pdfArea .pdf-list-header .header-left-content .storage-info-container{min-width:150px;text-align:left;margin-bottom:5px}#pdfArea .pdf-list-header .header-left-content .storage-info-container:last-child{flex-shrink:0}#stripePortalWarningModal .modal-actions .toolbar-icon:hover:after{display:none!important}#pdfArea .pdf-list-header.assign-context{display:flex;align-items:center;justify-content:space-between;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #eee}#pdfArea .pdf-list-header.assign-context h2{margin:0;text-align:left;font-size:1.2em}#pdfArea .back-button{padding:5px 10px;flex-shrink:0}#pdfAssignViewTitle{color:#d35400;font-weight:700}#leftBar a.logo-link{display:flex;align-items:center;margin-right:6px;text-decoration:none}#appLogo{height:34.2px;width:auto;display:block}@media (max-width: 900px){#appLogo{height:28px}}#pdfArea .pdf-list-header.assign-context .storage-info-container{min-width:150px;text-align:right;flex-shrink:0}#pdfArea{min-width:0;background:#444;overflow-y:scroll;overflow-x:auto;position:relative;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}#pdfPagesWrapper{display:block;transform-origin:0 0;will-change:transform}#pdfArea:not(.pdf-list-container){padding:0!important}#resizer{width:5px;background-color:#aaa;cursor:col-resize;transition:background-color .2s;position:relative;z-index:25000!important;flex-shrink:0;touch-action:none}#resizer:before{content:"⬌";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#00f;font-size:40px;font-weight:700;pointer-events:none;z-index:25000!important;animation:jumpTwice 2s ease-out .5s forwards}@media (pointer: coarse){#resizer:after{content:"";position:absolute;top:-16px;bottom:-16px;left:-16px;right:-16px;pointer-events:auto;background:transparent}}@keyframes jumpTwice{0%{transform:translate(-50%,-50%) translateY(0)}20%{transform:translate(-50%,-50%) translateY(-20px)}40%{transform:translate(-50%,-50%) translateY(0)}60%{transform:translate(-50%,-50%) translateY(-20px)}80%{transform:translate(-50%,-50%) translateY(0)}to{transform:translate(-50%,-50%) translateY(0)}}#resizer:hover{background-color:#888}#videoArea{flex-grow:1;background:#f8f8f8;min-width:0;position:relative;overflow:hidden}#fileList{display:flex;gap:6px;overflow-x:auto}#fileList button{padding:5px 10px;border:none;border-radius:4px;background:#fff;cursor:pointer}.page{position:relative;margin:0 auto;background:#fff;box-shadow:0 0 4px #0003;display:inline-block;max-width:100%;-webkit-user-drag:none}.pdfCanvas{display:block;z-index:10;-webkit-user-drag:none}.annotCanvas{position:absolute;left:0;top:0;z-index:50;pointer-events:none}.page,.pdfCanvas,.annotCanvas,.textOverlay,.fingeringsOverlay{will-change:transform;contain:layout paint}.page-toolbar{position:absolute;top:6px;left:6px;right:6px;z-index:200;display:flex;flex-direction:row-reverse;flex-wrap:wrap;gap:6px;opacity:0;pointer-events:none;transition:opacity .18s ease}.page:hover>.page-toolbar,.page-hidden-wrapper:hover>.page-toolbar{opacity:1;pointer-events:auto}.page-toolbar.has-show-action{opacity:.85;pointer-events:auto}.page-toolbar.has-show-action:hover{opacity:1}.page-toolbar{cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none}.page-toolbar.page-toolbar--dragging{cursor:grabbing;opacity:1!important;pointer-events:auto!important}.page-toolbar button{padding:4px 10px;border:none;border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;box-shadow:0 2px 6px #00000040;font-family:system-ui,-apple-system,sans-serif;white-space:nowrap;transition:background .15s ease}.page-hide-btn.hide-action{background:#e53935;color:#fff}.page-hide-btn.hide-action:hover{background:#c62828}.page-hide-btn.show-action{background:#43a047;color:#fff}.page-hide-btn.show-action:hover{background:#2e7d32}.page-hide-all-btn.hide-all-action{background:#bf360c;color:#fff}.page-hide-all-btn.hide-all-action:hover{background:#a02b0a}.page-hide-all-btn.show-all-action{background:#2e7d32;color:#fff}.page-hide-all-btn.show-all-action:hover{background:#1b5e20}.page-insert-pdf-btn{background:#1565c0;color:#fff}.page-insert-pdf-btn:hover{background:#0d47a1}.page-copy-annot-btn{background:#6a1b9a;color:#fff}.page-copy-annot-btn:hover{background:#4a148c}.page-delete-btn{background:#c62828;color:#fff}.page-delete-btn:hover{background:#b71c1c}.insert-option-cards{display:flex;flex-direction:column;gap:10px;padding:8px 0}.insert-option-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s;background:#fafafa}.insert-option-card:hover{border-color:#1565c0;background:#e3f2fd;box-shadow:0 2px 8px #1565c01f}.insert-option-icon{font-size:28px;flex-shrink:0;width:40px;text-align:center}.insert-option-text h4{margin:0 0 2px;font-size:14px;font-weight:700;color:#333}.insert-option-text p{margin:0;font-size:12px;color:#777}.insert-back-btn{background:none;border:none;color:#1565c0;font-size:13px;font-weight:600;cursor:pointer;padding:4px 0;margin-bottom:6px;display:flex;align-items:center;gap:4px}.insert-back-btn:hover{color:#0d47a1}.insert-student-list,.insert-student-pdf-list{list-style:none;margin:0;padding:0}.insert-student-list li,.insert-student-pdf-list li{padding:10px 12px;border-bottom:1px solid #f0f0f0;cursor:pointer;border-radius:4px;font-size:13px;color:#333;transition:background .12s}.insert-student-list li:hover,.insert-student-pdf-list li:hover{background:#e3f2fd}.insert-student-name{font-weight:600}.insert-student-email{font-size:11px;color:#888;margin-left:8px}.insert-pdf-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0000008c;z-index:100000;display:flex;align-items:center;justify-content:center}.insert-pdf-modal{background:#fff;border-radius:10px;box-shadow:0 8px 32px #0000004d;width:90%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.insert-pdf-modal-header{padding:16px 20px;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between}.insert-pdf-modal-header h3{margin:0;font-size:16px;font-weight:700;color:#333}.insert-pdf-modal-close{background:none;border:none;font-size:22px;cursor:pointer;color:#999;padding:0 4px;line-height:1}.insert-pdf-modal-close:hover{color:#333}.insert-pdf-modal-body{padding:12px 20px;overflow-y:auto;flex:1}.insert-pdf-modal-body .insert-pdf-search{width:100%;padding:8px 12px;border:1px solid #ccc;border-radius:6px;font-size:13px;margin-bottom:10px;box-sizing:border-box}.insert-pdf-modal-body .insert-pdf-list{list-style:none;margin:0;padding:0}.insert-pdf-modal-body .insert-pdf-list li{padding:10px 12px;border-bottom:1px solid #f0f0f0;cursor:pointer;border-radius:4px;font-size:13px;color:#333;transition:background .12s}.insert-pdf-modal-body .insert-pdf-list li:hover{background:#e3f2fd}.insert-pdf-modal-body .insert-pdf-list li .pdf-item-name{font-weight:600}.insert-pdf-modal-body .insert-pdf-list li .pdf-item-pages{font-size:11px;color:#888;margin-left:8px}.insert-pdf-modal-footer{padding:12px 20px;border-top:1px solid #e0e0e0;display:flex;justify-content:space-between;gap:10px}.insert-pdf-modal-footer button{padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer}.insert-pdf-upload-btn{background:#1565c0;color:#fff}.insert-pdf-upload-btn:hover{background:#0d47a1}.insert-pdf-cancel-btn{background:#e0e0e0;color:#333}.insert-pdf-cancel-btn:hover{background:#bdbdbd}.delete-pages-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;width:94%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.delete-pages-modal-header{padding:16px 20px;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between}.delete-pages-modal-header h3{margin:0;font-size:16px;font-weight:700;color:#333}.delete-pages-modal-close{background:none;border:none;font-size:22px;cursor:pointer;color:#999;padding:0 4px;line-height:1}.delete-pages-modal-close:hover{color:#333}.delete-pages-hint{padding:8px 20px 4px;font-size:12px;color:#888}.delete-pages-grid{display:flex;flex-wrap:wrap;gap:12px;padding:12px 20px;overflow-y:auto;flex:1;align-items:flex-start;align-content:flex-start;justify-content:center}.delete-page-thumb{position:relative;border:3px solid #e0e0e0;border-radius:8px;overflow:visible;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .12s;background:#fafafa;display:flex;flex-direction:column;align-items:center;width:120px;flex-shrink:0}.delete-page-thumb:hover{border-color:#90a4ae;box-shadow:0 2px 8px #0000001f;transform:translateY(-1px)}.delete-page-thumb.selected{border-color:#c62828;box-shadow:0 0 0 2px #c6282840,0 2px 8px #c628282e}.delete-page-thumb.selected:after{content:"✕";position:absolute;top:4px;right:6px;background:#c62828;color:#fff;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;box-shadow:0 1px 4px #0000004d}.delete-page-thumb canvas{width:100%;height:auto;display:block}.delete-page-thumb .thumb-label{padding:4px 0 6px;font-size:11px;font-weight:600;color:#555;text-align:center}.delete-page-thumb.selected .thumb-label{color:#c62828}.delete-pages-footer{padding:12px 20px;border-top:1px solid #e0e0e0;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0}.delete-pages-footer .delete-count{font-size:13px;color:#888}.delete-pages-footer .delete-count strong{color:#c62828}.delete-pages-footer .footer-btns{display:flex;gap:8px}.delete-pages-cancel-btn{padding:8px 18px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;background:#e0e0e0;color:#333}.delete-pages-cancel-btn:hover{background:#bdbdbd}.delete-pages-confirm-btn{padding:8px 18px;border:none;border-radius:6px;font-size:13px;font-weight:700;cursor:pointer;background:#c62828;color:#fff;transition:background .15s,opacity .15s}.delete-pages-confirm-btn:hover{background:#b71c1c}.delete-pages-confirm-btn:disabled{opacity:.4;cursor:not-allowed}.page-hidden-wrapper{position:relative;display:inline-block;margin:0 auto;max-width:100%;-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.page-hidden-wrapper>.page{opacity:.2;-webkit-user-drag:none}.page-hidden-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#e53935;font-size:18px;font-weight:700;font-family:system-ui,-apple-system,sans-serif;text-transform:uppercase;letter-spacing:2px;pointer-events:none;z-index:190;text-shadow:0 1px 3px rgba(0,0,0,.15)}.page.student-hidden-page{display:none!important;visibility:hidden!important;height:0!important;overflow:hidden!important;margin:0!important;padding:0!important}#looperOverlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;display:none;flex-direction:column;z-index:4}#looperHeader{display:flex;justify-content:space-between;align-items:center;background:#006400;color:#fff;padding:6px 10px;font-size:14px}.timeline{height:8px;background:#ddd;border-radius:4px;margin:4px 8px;cursor:pointer}.progress{height:100%;background:#1b5e20;border-radius:4px;width:0%}#looperControls{display:flex;gap:8px;align-items:center;padding:6px 8px;font-size:14px}#looperControls input[type=range]{width:120px}#placeDotBtn.active{background:#006400;color:#fff}.practiceDot.placing{width:24px;height:24px;background:#0064004d;border:2px dashed #000;opacity:.7;animation:none;cursor:default;pointer-events:none;z-index:155}.practiceDot{position:absolute;width:24px;height:24px;border-radius:50%;background:#006400;border:2px solid #000;cursor:pointer;z-index:150}@keyframes blink{0%{box-shadow:0 0 #ffa500cc}50%{box-shadow:0 0 0 8px #ffa50000}to{box-shadow:0 0 #ffa500cc}}.practiceDot.blinking{animation:blink 1s infinite;z-index:165}.videoAnnotation.blinking{animation:blink 1s infinite;z-index:185}#addSquareBtn.active{background:#00008b;color:#fff}.textOverlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:120;pointer-events:none}.fingeringsOverlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:130}.textOverlay.placing-text{pointer-events:auto;cursor:text}.submenu-container{position:relative}.submenu{display:none;position:absolute;top:100%;left:0;background-color:#fff;border:1px solid #ccc;color:#333;border-radius:4px;box-shadow:0 4px 8px #0000001a;z-index:1000;min-width:120px;padding:5px 0}.submenu a{display:block;padding:8px 15px;color:#333;text-decoration:none;font-size:14px}.submenu a:hover{background-color:#f0f0f0}.superuser-submenu{border-top:1px solid #eee;padding-top:6px;margin-top:4px}.superuser-submenu-toggle{width:100%;background:none;border:none;padding:8px 15px;text-align:left;font-size:14px;color:#333;cursor:pointer}.superuser-submenu-toggle:hover,.superuser-submenu-toggle:focus{background-color:#f0f0f0;outline:none}.superuser-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f131cc7;display:none;align-items:center;justify-content:center;padding:40px 24px;z-index:3500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.superuser-overlay.visible{display:flex}body.modal-open--superuser{overflow:hidden}.superuser-overlay-panel{background:#fff;color:#1a1f2b;width:min(1100px,94vw);max-height:85vh;border-radius:18px;box-shadow:0 30px 80px #00000059;display:flex;flex-direction:column;padding:28px 32px 32px;position:relative;overflow:hidden}.superuser-overlay-header{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:16px}.superuser-overlay-title{font-size:clamp(22px,3vw,30px);font-weight:700;margin:0}.superuser-overlay-close{border:none;background:transparent;font-size:28px;line-height:1;cursor:pointer;color:#5c6379;transition:color .2s ease}.superuser-overlay-close:hover,.superuser-overlay-close:focus{color:#1a1f2b;outline:none}.superuser-overlay-status{font-size:14px;color:#4a5166;margin-bottom:16px;min-height:20px}.superuser-table-container{flex:1;overflow:auto;border:1px solid #d7d9e2;border-radius:12px;background:linear-gradient(135deg,#f7f8fc,#fff 35%);position:relative}.superuser-table{width:100%;border-collapse:collapse;min-width:680px}.superuser-table thead{position:sticky;top:0;background:#f5f6fcf0;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1}.superuser-table th,.superuser-table td{padding:12px 16px;text-align:left;font-size:14px;border-bottom:1px solid #e6e8f0;vertical-align:middle}.superuser-table th{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:#5c6379}.superuser-table tbody tr:hover{background:#667eea14}.superuser-email-cell{color:#3f4660;word-break:break-word}.superuser-table td:nth-child(4),.superuser-table td:nth-child(5),.superuser-table td:nth-child(6){text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.superuser-account-error{color:#b3261e}.superuser-account-quiet{color:#6b7085;font-size:12px}.superuser-overlay-empty{padding:40px;text-align:center;color:#5c6379;font-size:15px}@media (max-width: 768px){.superuser-overlay{padding:16px}.superuser-overlay-panel{padding:20px;width:100%;max-height:90vh}.superuser-table{min-width:100%}}.submenu.show{display:block!important}.submenu-container:hover .submenu,.submenu-container:focus-within .submenu{display:block}.favorites-submenu{min-width:220px;max-height:320px;overflow-y:auto}.favorites-dropdown-item{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;padding:8px 10px 8px 15px;background:transparent;border:none;font-family:inherit;font-size:14px;font-weight:600;font-style:normal;color:#333;cursor:pointer;white-space:nowrap}.favorites-submenu.favorites-drag-enabled .favorites-dropdown-item{cursor:grab}.favorites-dropdown-item.dragging{opacity:.65;cursor:grabbing}.favorites-dropdown-item:hover{background-color:#f0f0f0}.favorites-open-btn{flex:1 1 auto;background:none;border:none;padding:0;text-align:left;font:inherit;color:inherit;cursor:pointer;white-space:nowrap}.favorites-open-btn:hover,.favorites-open-btn:focus{text-decoration:underline}.favorites-remove-btn{flex:0 0 auto;background:transparent;border:none;color:#aa2e2e;cursor:pointer;padding:4px;border-radius:4px;line-height:0;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease,color .15s ease}.favorites-remove-btn:hover,.favorites-remove-btn:focus{background-color:#aa2e2e1f;color:#7a1f1f}.favorites-remove-btn svg{width:14px;height:14px;pointer-events:none}.favorites-empty-message{display:flex;align-items:center;gap:8px;padding:8px 10px 8px 15px;font-family:inherit;font-size:14px;font-weight:600;color:#333;white-space:nowrap}.favorites-button-saved{animation:favoritesPulse .4s ease-in-out}@keyframes favoritesPulse{0%{transform:scale(1)}50%{transform:scale(1.18)}to{transform:scale(1)}}.feature-gif-wrapper{margin-top:14px;display:flex;justify-content:center;align-items:center;flex-direction:column;gap:6px}.feature-gif-wrapper .feature-loop{width:100%;max-width:1200px;border-radius:16px;box-shadow:0 6px 22px #00000047;border:1px solid #e0e0e0;background:#000;display:block;aspect-ratio:16 / 9;object-fit:contain;image-rendering:-webkit-optimize-contrast;transition:box-shadow .25s ease,transform .25s ease}.feature-gif-wrapper .feature-loop:hover{box-shadow:0 10px 32px #00000059;transform:translateY(-2px)}.feature-gif-wrapper .feature-loop::-webkit-media-controls{display:none!important}.feature-gif-caption{font-size:.85em;color:#555;max-width:700px;text-align:center;font-style:italic}.section .features-list.single-column-wide{max-width:100%!important;padding-left:0!important;list-style:none!important}.features-list.single-column-wide>li{list-style:none!important}.features-list.single-column-wide>li::marker{content:""!important}.howit-features-wide{width:100%;max-width:1600px;margin:50px auto 20px;display:flex;flex-direction:column;gap:54px;padding:0 2vw}.howit-feature-item-wide{background:linear-gradient(135deg,#fff,#fff8ef 60%,#fff2e0);border:1px solid #eadbc8;border-radius:28px;padding:clamp(38px,4.5vw,88px) clamp(28px,4vw,120px) clamp(54px,5vw,110px);box-shadow:0 6px 28px -4px #0000001f;position:relative;overflow:hidden}.howit-feature-item-wide:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 85% 20%,rgba(255,187,102,.28),transparent 65%),radial-gradient(circle at 12% 80%,rgba(255,204,136,.18),transparent 70%);pointer-events:none}.howit-feature-head{display:flex;flex-direction:column;align-items:center;margin-bottom:26px}.howit-feature-icon{font-size:clamp(2.2rem,3.4vw,3.8rem);width:clamp(70px,6vw,120px);height:clamp(70px,6vw,120px);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffb347,#ffd480);color:indigo;border-radius:22px;box-shadow:0 5px 18px #ff990059;margin-bottom:18px}.howit-feature-item-wide h4{font-size:clamp(1.6rem,2.1vw,2.6rem);margin:0 0 12px;text-align:center;color:indigo;letter-spacing:.5px}.howit-feature-item-wide p{font-size:clamp(1rem,1.1vw,1.25rem);line-height:1.55;max-width:1400px;margin:0 auto;text-align:center;color:#3d3550}.howit-feature-item-wide .feature-gif-wrapper{margin-top:34px}.howit-feature-item-wide .feature-gif-wrapper .feature-loop{max-width:100%;border-radius:18px}.howit-feature-item-wide:hover{box-shadow:0 10px 38px -6px #0000002e;transform:translateY(-4px);transition:all .35s ease}.howit-feature-item-wide{transition:all .35s ease}@media (max-width: 900px){.howit-feature-item-wide{padding:42px 28px 60px}.howit-feature-item-wide p{text-align:left}}.how-it-works-teacher-section .features-list.single-column-wide{display:flex!important}.how-it-works-teacher-section .features-list.single-column-wide .feature-item{max-width:100%!important;width:100%!important}.textOverlay .annotationText,.textOverlay .redBracketAnnotation{pointer-events:auto!important}#videoModal{display:none;position:fixed;bottom:7px;right:7px;width:calc(35vw - 40px);max-width:450px;min-width:280px;background:#fff;padding:7px;border:1px solid #ccc;border-radius:8px;box-shadow:0 4px 15px #0000004d;overflow:hidden;z-index:1001}#videoModal button{margin:0 5px 0 0;padding:8px 16px;cursor:pointer;font-weight:700;border-radius:5px}#videoModal #uploadRecordingBtn{background:linear-gradient(45deg,#f90,#fc0);color:#fff;border:none;padding:8px 20px}#videoModal #closeVideoModalBtn{background:#e0e0e0;color:#333;border:1px solid #ccc;padding:8px 15px}#videoPreviewContainer{position:relative;margin-bottom:10px}#videoModal video#preview{width:100%;height:auto;aspect-ratio:16/9;background:#000;display:block;margin-bottom:0;object-fit:cover}#minimizeVideoModalBtn{position:absolute;top:4px;right:4px;width:28px;height:28px;padding:0;margin:0;background:linear-gradient(135deg,#6c757d,#495057);color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:700;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #0003}#minimizeVideoModalBtn:hover{background:linear-gradient(135deg,#5a6268,#343a40);transform:scale(1.05)}#videoModalMinimized{position:fixed;bottom:10px;right:10px;display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#2d2d2d,#1a1a1a);color:#fff;padding:8px 12px;border-radius:20px;box-shadow:0 4px 12px #0006;z-index:1001;transition:all .2s ease;border:2px solid #e60000}#minimizedRecordingDot{width:12px;height:12px;background:#e60000;border-radius:50%;animation:blinkRedDot 1s infinite;flex-shrink:0}#minimizedRecordingText{font-size:12px;font-weight:700;letter-spacing:1px;color:#f44;flex-shrink:0}#minimizedButtonsContainer{display:flex;align-items:center;gap:4px;margin-left:4px;padding-left:8px;border-left:1px solid rgba(255,255,255,.2)}.minimized-btn{width:32px;height:32px;padding:0;margin:0;border:none;border-radius:6px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;box-shadow:0 2px 6px #0006,inset 0 1px #ffffff1a}.minimized-btn:hover{transform:scale(1.1);box-shadow:0 4px 8px #00000080,inset 0 1px #fff3}.minimized-upload{background:linear-gradient(135deg,#f90,#fa2);color:#000;border:2px solid #ffcc00}.minimized-upload:hover{background:linear-gradient(135deg,#fa2,#fb4)}.minimized-switch{background:linear-gradient(135deg,#38f,#49f);color:#fff;border:2px solid #66bbff}.minimized-switch:hover{background:linear-gradient(135deg,#49f,#5af)}.minimized-switch.state-screen-main{background:linear-gradient(135deg,#28a745,#34c759);color:#fff;border:2px solid #5fd77a}.minimized-switch.state-screen-main:hover{background:linear-gradient(135deg,#34c759,#48d96d)}.minimized-switch.state-self-main{background:linear-gradient(135deg,#93c,#a4d);color:#fff;border:2px solid #cc77ff}.minimized-switch.state-self-main:hover{background:linear-gradient(135deg,#a4d,#b5e)}.minimized-cam{background:linear-gradient(135deg,#f75,#f86);color:#fff;border:2px solid #ffaa88}.minimized-cam:hover{background:linear-gradient(135deg,#f86,#f97)}.minimized-cam.state-visible{background:linear-gradient(135deg,#28a745,#34c759);color:#fff;border:2px solid #5fd77a}.minimized-cam.state-visible:hover{background:linear-gradient(135deg,#34c759,#48d96d)}.minimized-cam.state-hidden{background:linear-gradient(135deg,#dc3545,#e04555);color:#fff;border:2px solid #ff6b7a}.minimized-cam.state-hidden:hover{background:linear-gradient(135deg,#e04555,#e85565)}.minimized-cancel{background:linear-gradient(135deg,#888,#999);color:#fff;border:2px solid #bbbbbb}.minimized-cancel:hover{background:linear-gradient(135deg,#999,#aaa)}#restoreVideoModalBtn{background:linear-gradient(135deg,#28a745,#34c759);color:#fff;border:2px solid #5fd77a;border-radius:6px;width:32px;height:32px;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;margin:0 0 0 4px;padding:0;transition:all .2s ease;flex-shrink:0;box-shadow:0 2px 6px #0006,inset 0 1px #fff3}#restoreVideoModalBtn:hover{background:linear-gradient(135deg,#34c759,#48d96d);transform:scale(1.1);box-shadow:0 4px 8px #00000080,inset 0 1px #ffffff4d}#recordingIndicatorDot{position:absolute;top:8px;right:calc(100% - 100px);width:14px;height:14px;background:#e60000;border-radius:50%;animation:blinkRedDot 1s infinite;pointer-events:none;z-index:9999}@keyframes blinkRedDot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}#videoModalBackdrop{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;z-index:1000;animation:fadeInBackdrop .3s ease}@keyframes fadeInBackdrop{0%{opacity:0}to{opacity:1}}#videoModal.preview-confirmation-mode{position:fixed;top:50%!important;left:50%!important;transform:translate(-50%,-50%);bottom:auto!important;right:auto!important;width:94vw!important;max-width:900px!important;min-width:280px!important;height:94vh!important;height:94dvh!important;max-height:94vh!important;max-height:94dvh!important;display:flex!important;flex-direction:column!important;overflow:hidden!important;padding:15px!important;box-shadow:0 10px 50px #00000080!important;border:3px solid #ff9900!important;animation:popInModal .3s ease;z-index:1002!important}@keyframes popInModal{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}#previewConfirmationBanner{display:none;background:linear-gradient(135deg,#f90,#fc0,#9c27b0);color:#fff;padding:12px;margin:-15px -15px 10px;border-radius:5px 5px 0 0;text-align:center;animation:pulseBanner 2s ease-in-out infinite;flex-shrink:0}@keyframes pulseBanner{0%,to{box-shadow:0 0 #ff990080}50%{box-shadow:0 0 20px 5px #ff99004d}}#previewConfirmationBanner h2{margin:0 0 4px;font-size:clamp(1.1em,4vw,1.6em);font-weight:700;text-shadow:1px 1px 2px rgba(0,0,0,.2)}#previewConfirmationBanner p{margin:0;font-size:clamp(.9em,3vw,1.1em);opacity:.95}#videoModal.preview-confirmation-mode #previewConfirmationBanner{display:block}#videoModal.preview-confirmation-mode #minimizeVideoModalBtn{display:none!important}#videoModal.preview-confirmation-mode #videoPreviewContainer{flex:1 1 auto;min-height:0;display:flex;align-items:center;justify-content:center;margin-bottom:10px;overflow:hidden;position:relative}#videoModal.preview-confirmation-mode video#preview{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:8px;border:2px solid #dee2e6;display:block}#videoModal.preview-confirmation-mode #audioControlsContainer{display:none!important}#videoModal.preview-confirmation-mode p#recordingStatus{font-size:clamp(.9em,3vw,1.2em)!important;font-weight:700!important;color:#7b1fa2!important;text-align:center;margin:8px 0!important;padding:8px;background:linear-gradient(135deg,#fff8e1,#f3e5f5);border-radius:8px;border:1px solid #ffcc00;flex-shrink:0}#videoOverwriteWarning{display:none}#videoModal.preview-confirmation-mode #videoOverwriteWarning{display:block;text-align:center;margin:4px 0 8px;padding:8px 12px;background:linear-gradient(135deg,#ffebee,#fff3e0);border:2px solid #f44336;border-radius:8px;font-size:clamp(.85em,2.5vw,1.05em);font-weight:700;color:#c62828;animation:warningPulse 2s ease-in-out infinite;flex-shrink:0}@keyframes warningPulse{0%,to{box-shadow:0 0 5px #f4433680;transform:scale(1)}50%{box-shadow:0 0 15px #f44336cc,0 0 25px #f4433666;transform:scale(1.01)}}#videoModal.preview-confirmation-mode .video-modal-actions{gap:12px!important;margin-top:10px!important;flex-wrap:wrap;justify-content:center;flex-shrink:0}#videoModal.preview-confirmation-mode #uploadRecordingBtn{font-size:clamp(1em,3.5vw,1.4em)!important;padding:clamp(12px,3vw,18px) clamp(25px,6vw,45px)!important;background:linear-gradient(45deg,#f90,#fc0)!important;color:#fff!important;border:3px solid #e68a00!important;border-radius:12px!important;box-shadow:0 6px 20px #f906!important;transition:all .2s ease!important;animation:blinkUploadBtn .8s ease-in-out infinite;min-width:0}@keyframes blinkUploadBtn{0%,to{transform:scale(1);opacity:1;box-shadow:0 6px 20px #f906}50%{transform:scale(1.05);opacity:.7;box-shadow:0 10px 35px #f90c,0 0 20px #fc09}}#videoModal.preview-confirmation-mode #uploadRecordingBtn:hover{transform:scale(1.08)!important;box-shadow:0 8px 25px #ff990080!important;background:linear-gradient(45deg,#e68a00,#f90)!important;animation:none!important}#videoModal.preview-confirmation-mode #closeVideoModalBtn{font-size:clamp(.9em,3vw,1.1em)!important;padding:clamp(10px,2.5vw,14px) clamp(20px,5vw,28px)!important;background:#7b1fa2!important;color:#fff!important;border:2px solid #6a1b9a!important;border-radius:10px!important;min-width:0}#videoModal.preview-confirmation-mode #closeVideoModalBtn:hover{background:#6a1b9a!important}#videoModal.preview-confirmation-mode #switchScreenSelfLayoutBtn,#videoModal.preview-confirmation-mode #toggleCameraPipBtn{display:none!important}@media (max-width: 600px){#videoModal.preview-confirmation-mode{width:96vw!important;max-width:none!important;min-width:unset!important;padding:10px!important;max-height:94vh!important;max-height:94dvh!important;border-width:2px!important}#videoModal.preview-confirmation-mode #previewConfirmationBanner{padding:10px!important;margin:-10px -10px 8px!important}#videoModal.preview-confirmation-mode p#recordingStatus{padding:6px!important;margin:6px 0!important}#videoModal.preview-confirmation-mode .video-modal-actions{flex-direction:column!important;gap:10px!important;margin-top:8px!important}#videoModal.preview-confirmation-mode #uploadRecordingBtn,#videoModal.preview-confirmation-mode #closeVideoModalBtn{width:100%!important}}@media (max-width: 360px){#videoModal.preview-confirmation-mode{padding:8px!important}#videoModal.preview-confirmation-mode #previewConfirmationBanner{padding:8px!important;margin:-8px -8px 6px!important}#videoModal.preview-confirmation-mode p#recordingStatus{padding:5px!important;margin:5px 0!important}}@media (max-height: 500px){#videoModal.preview-confirmation-mode{max-height:94vh!important;max-height:94dvh!important;padding:8px!important}#videoModal.preview-confirmation-mode #previewConfirmationBanner{padding:6px 10px!important;margin:-8px -8px 6px!important}#videoModal.preview-confirmation-mode #previewConfirmationBanner h2{font-size:1em!important;margin-bottom:2px!important}#videoModal.preview-confirmation-mode #previewConfirmationBanner p{font-size:.85em!important}#videoModal.preview-confirmation-mode p#recordingStatus{font-size:.9em!important;padding:4px 8px!important;margin:4px 0!important}#videoModal.preview-confirmation-mode .video-modal-actions{flex-direction:row!important;gap:8px!important;margin-top:6px!important}#videoModal.preview-confirmation-mode #uploadRecordingBtn{font-size:.95em!important;padding:8px 16px!important;flex:1}#videoModal.preview-confirmation-mode #closeVideoModalBtn{font-size:.85em!important;padding:6px 12px!important;flex:0 0 auto}}@media (max-height: 400px){#videoModal.preview-confirmation-mode #previewConfirmationBanner{padding:4px 8px!important}#videoModal.preview-confirmation-mode #previewConfirmationBanner h2{font-size:.9em!important;margin-bottom:0!important}#videoModal.preview-confirmation-mode #previewConfirmationBanner p,#videoModal.preview-confirmation-mode p#recordingStatus{display:none!important}#videoModal.preview-confirmation-mode .video-modal-actions{margin-top:4px!important}}#videoModal p#recordingStatus{margin:0 0 10px;font-size:14px;color:#555;min-height:1.2em}.video-modal-actions{display:flex;justify-content:center;gap:10px;margin-top:10px}#videoModal .video-modal-switch-btn{display:inline-block;padding:8px 15px;background:#007bff;color:#fff;border:1px solid #0056b3;text-align:center;margin:0;box-shadow:none;transition:background-color .2s ease,border-color .2s ease,color .2s ease}#videoModal .video-modal-switch-btn:hover{background:#0056b3;border-color:#004085}#audioControlsContainer{background:#f8f9fa!important;border:1px solid #dee2e6;border-radius:6px;padding:12px;margin:10px 0}#recordingVolumeControl{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:#ddd;border-radius:3px;outline:none;flex:1;margin:0 8px}#recordingVolumeControl::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:#007bff;border-radius:50%;cursor:pointer}#recordingVolumeControl::-moz-range-thumb{width:16px;height:16px;background:#007bff;border-radius:50%;cursor:pointer;border:none}.volume-bar{transition:background-color .08s ease,transform .06s ease,box-shadow .08s ease}.volume-bar.clipping{background-color:red!important;animation:pulse-red .3s infinite;transform:scale(1.05);box-shadow:0 0 8px #f009}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.7}}#calibrateVolumeButton{transition:background-color .2s ease;font-weight:500;min-width:28px;height:22px;line-height:1}#calibrateVolumeButton:hover:not(:disabled){background:#45a049!important}#calibrateVolumeButton:disabled{cursor:not-allowed!important;opacity:.7}#autoGainStatusContainer,#autoGainStatus,#manualModeToggleContainer{transition:all .3s ease}#manualModeToggleContainer:hover{background:linear-gradient(135deg,#bbdefb,#e1bee7)}#manualVolumeModeCheckbox{transition:transform .2s ease}#manualVolumeModeCheckbox:hover{transform:scale(1.1)}#manualVolumeModeCheckbox:checked+label{color:#7b1fa2;font-weight:600}#manualModeToggleStatus{transition:all .3s ease}#calibrationProgressContainer{animation:pulse-progress 1.5s ease-in-out infinite}#calibrationProgress{animation:shimmer 2s ease-in-out infinite}@keyframes pulse-progress{0%,to{opacity:1}50%{opacity:.8}}@keyframes shimmer{0%{background:linear-gradient(90deg,#4caf50,#4caf50)}50%{background:linear-gradient(90deg,#4caf50,#66bb6a,#4caf50)}to{background:linear-gradient(90deg,#4caf50,#4caf50)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}#clippingIndicator{background:linear-gradient(45deg,#f44,#c00);border:2px solid #fff;box-shadow:0 2px 8px #f446;font-size:11px;letter-spacing:.5px}#clippingWarning{background:#ff44441a;border:1px solid #ff4444;border-radius:4px;padding:8px;font-size:.85em;animation:shake .5s ease-in-out}.video-modal-tiny-btn{padding:5px 8px;font-size:11px;min-width:auto;background:#ffa07a;color:#000;border:1px solid #ff8c69;border-radius:4px;cursor:pointer;line-height:1.2;transition:background-color .2s ease,border-color .2s ease,color .2s ease}.video-modal-tiny-btn:hover{background:#ff8c69;border-color:#ff704d}@keyframes blinkRedDotEffect{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.6;transform:translate(-50%,-50%) scale(.8)}}#downscaleCanvas{display:none}@media (max-width: 600px){#videoModal{width:85vw;max-width:400px;min-width:250px;right:7.5vw;left:7.5vw}#videoModal video#preview{max-height:47.8125vw}#recordingIndicatorDot{right:15%}}@media (max-width: 900px){#viewer{flex-direction:column;overflow-y:auto;overflow-x:hidden}#pdfArea,#videoArea{width:100%;min-width:0}#videoArea{min-height:120px}#resizer{display:block!important;width:100%!important;height:8px!important;cursor:row-resize!important;background-color:#aaa}#resizer:before{content:"⬍";font-size:34px}#resizer:after{content:"";position:absolute;left:0;right:0;top:-18px;bottom:-18px;pointer-events:auto;background:transparent}body[data-current-view=manage-students] #videoArea,body[data-current-view=manage-students] #resizer,body[data-current-view=pdf-list] #videoArea,body[data-current-view=pdf-list] #resizer,body[data-current-view=my-lessons] #videoArea,body[data-current-view=my-lessons] #resizer,body[data-current-view=student-lessons] #videoArea,body[data-current-view=student-lessons] #resizer{display:none!important}body[data-current-view=pdf-list] #pdfArea{width:100%!important;height:100%!important;flex:1!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important}}@media (max-width: 900px) and (orientation: landscape){body:not([data-current-view=manage-students]) #viewer{flex-direction:row;overflow:hidden}body:not([data-current-view=manage-students]) #pdfArea,body:not([data-current-view=manage-students]) #videoArea{width:auto}body:not([data-current-view=manage-students]) #videoArea{min-height:0}body:not([data-current-view=manage-students]) #resizer{display:block!important;width:5px!important;height:auto!important;cursor:col-resize!important}body:not([data-current-view=manage-students]) #resizer:before{content:"⬌";font-size:40px}body:not([data-current-view=manage-students]) #resizer:after{content:"";position:absolute;top:-28px;bottom:-28px;left:-24px;right:-24px;pointer-events:auto;background:transparent}body[data-current-view=manage-students] #viewer{flex-direction:column!important;overflow:hidden!important}body[data-current-view=manage-students] #pdfArea{width:100%!important;flex:1!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important;position:relative!important}body[data-current-view=manage-students] #videoArea,body[data-current-view=manage-students] #resizer{display:none!important}body[data-current-view=pdf-list] #viewer,body[data-current-view=my-lessons] #viewer,body[data-current-view=student-lessons] #viewer{flex-direction:column!important}body[data-current-view=pdf-list] #pdfArea,body[data-current-view=my-lessons] #pdfArea,body[data-current-view=student-lessons] #pdfArea{width:100%!important;flex:1!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important}body[data-current-view=pdf-list] #videoArea,body[data-current-view=my-lessons] #videoArea,body[data-current-view=student-lessons] #videoArea,body[data-current-view=pdf-list] #resizer,body[data-current-view=my-lessons] #resizer,body[data-current-view=student-lessons] #resizer{display:none!important}}@media (max-width: 900px) and (orientation: landscape){body.pdf-list-single-column #viewer{flex-direction:column!important}body.pdf-list-single-column #pdfArea,body.pdf-list-single-column #videoArea{width:100%!important}body.pdf-list-single-column #videoArea,body.pdf-list-single-column #resizer{display:none!important}body.pdf-list-single-column #pdfArea.pdf-list-container{height:100vh!important;max-height:100vh!important;overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;overscroll-behavior:contain!important}}.videoAnnotation{position:absolute;width:24px;height:24px;border:2px solid black;border-radius:50%;cursor:pointer;z-index:180;pointer-events:auto;background-color:#ff0;transition:opacity .3s,border .3s,background-color .3s}.videoAnnotation.placing{border:2px dashed #000000;opacity:.6;background-color:#ffdf0066}.screenSelfAnnotation.placing{border:2px dashed #000000;opacity:.6;background-color:#6495ed66}.html5VideoLoopAnnotation.placing{border:2px dashed #000000;opacity:.6;background-color:#90ee9066}.queued{opacity:.6!important;border:2px dashed #333!important;animation:pulse-faint 2s infinite}.uploading{opacity:.8!important;border:2px solid #333!important;animation:pulse-strong 1s infinite}.failed{border-color:red!important;background-color:#fcc!important;opacity:.7!important}.videoAnnotation:not(.placing):not(.queued):not(.uploading):not(.failed):not(.blinking){opacity:1!important;border:2px solid black!important;background-color:#ff0!important;animation:none!important}@keyframes pulse-faint{0%{opacity:.6}50%{opacity:.8}to{opacity:.6}}@keyframes pulse-strong{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.html5VideoLoopAnnotation{position:absolute;width:24px;height:24px;border:2px solid black;border-radius:50%;cursor:pointer;z-index:180;background-color:#90ee90}.screenSelfAnnotation{position:absolute;width:24px;height:24px;border:2px solid black;border-radius:50%;cursor:pointer;z-index:180;background-color:#6495ed}.html5VideoLoopAnnotation.blinking,.screenSelfAnnotation.blinking{animation:blink 1s infinite;z-index:185}.screenSelfAnnotation:not(.placing):not(.queued):not(.uploading):not(.failed){background-color:#6495ed!important}.html5VideoLoopAnnotation:not(.placing):not(.queued):not(.uploading):not(.failed){background-color:#90ee90!important}.imageAnnotation{position:absolute;border:1px solid rgba(0,0,0,.2);border-radius:6px;box-shadow:0 2px 6px #00000040;background:#fff;overflow:hidden;cursor:grab;z-index:20;-webkit-user-select:none;user-select:none;touch-action:none;pointer-events:auto}.imageAnnotation--dragging,.imageAnnotation--resizing{cursor:grabbing;opacity:.92;z-index:48}.imageAnnotation--pending{opacity:.6;cursor:wait}.imageAnnotation__img{width:100%;height:100%;object-fit:contain;display:block;pointer-events:none;background:#fff}.imageAnnotation__resizeHandle{position:absolute;width:14px;height:14px;border-radius:50%;right:-7px;bottom:-7px;background:#fffffff2;border:2px solid #0d6efd;box-shadow:0 1px 4px #00000040;cursor:nwse-resize}.imageAnnotation--pending .imageAnnotation__resizeHandle{border-color:#00000040;cursor:not-allowed}#videoPlaybackOverlay{display:flex;flex-direction:column;min-height:0}#videoPlaybackOverlay .overlay-header{background:#333;color:#fff;padding:5px 10px;display:flex;justify-content:flex-end;align-items:center}.overlay-header-button{background:#eee;color:#333;border:none;border-radius:4px;font-size:18px;font-weight:700;cursor:pointer;padding:0 6px;line-height:1}#videoPlaybackOverlay video{flex:1 1 auto;width:100%;height:auto;min-height:0;object-fit:contain;background:transparent}#videoPlaybackOverlay .video-text-container{width:90%;max-width:450px;padding:15px;background-color:#f5f5f5;border-radius:8px;box-shadow:0 2px 5px #0000001a;margin:15px auto;text-align:left;color:#333;flex-shrink:0}#videoPlaybackOverlay .video-text-container h3{text-align:center;color:#1b5e20;font-style:italic;margin-top:0;margin-bottom:10px}#videoPlaybackOverlay .video-text-container ul{margin:0;padding-left:20px}#videoPlaybackOverlay .video-text-container,#videoPlaybackOverlay .overlay-header{flex-shrink:0}#videoPlaybackOverlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background-color:#000000e6}#videoPlaybackOverlay .overlay-header,#videoPlaybackOverlay .video-text-container{flex:0 0 auto}#videoPlaybackOverlay video{display:block;width:100%;height:auto;flex:0 0 auto;max-height:100%;object-fit:contain;background:transparent}#uploadProgressMessage{color:#000}#pdfArea.my-lessons-view-active{background:linear-gradient(135deg,indigo,#6a0dad 60%,#8a2be2);color:#fff;padding:25px;height:100%;box-sizing:border-box;overflow-y:auto}#my-lessons-list-content{padding:20px;margin:0 auto}#my-lessons-list-content .my-lessons-header{text-align:center;margin-bottom:28px;padding-bottom:4px;border-bottom:2px solid rgba(255,204,0,.5)}#my-lessons-list-content .my-lessons-header h1{font-size:2.8em;color:#fc0;text-shadow:2px 2px 4px rgba(0,0,0,.6);margin:0;font-weight:700}#my-lessons-list-content .my-lessons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:30px;padding-left:20px;padding-right:20px}#my-lessons-list-content .my-lesson-card{background:#ffffff14;border-radius:12px;padding:16px;box-shadow:0 5px 20px #00000040;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;justify-content:space-between;border:1px solid rgba(255,153,0,.3);border-top:5px solid #ff9900}#my-lessons-list-content .my-lesson-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 10px 30px #0006;border-color:#ffcc00b3}#my-lessons-list-content .my-lesson-card .my-lesson-title{font-size:1.6em;color:#fff;margin-top:0;margin-bottom:12px;font-weight:700;white-space:normal;overflow-wrap:break-word;word-break:break-word}#my-lessons-list-content .my-lesson-card .my-lesson-details{font-size:.95em;color:#e0e0e0;margin-bottom:15px;margin-top:0;flex-grow:1}#my-lessons-list-content .my-lesson-card .my-lesson-open-btn{background:linear-gradient(45deg,#f90,#ffc107);color:indigo;border:none;padding:12px 18px;border-radius:8px;cursor:pointer;font-weight:700;text-transform:uppercase;font-size:.9em;transition:background .3s ease,transform .2s ease,box-shadow .2s ease;align-self:flex-start;box-shadow:0 2px 5px #0003}#my-lessons-list-content .my-lesson-card .my-lesson-open-btn:hover{background:linear-gradient(45deg,#ffc107,#f90);transform:scale(1.05);box-shadow:0 4px 10px #0000004d}#my-lessons-list-content .no-lessons-message{grid-column:1 / -1;text-align:center;font-size:1.5em;color:#fc0;padding:40px 20px;background:#00000040;border-radius:10px;border:1px dashed rgba(255,204,0,.5)}.my-lesson-card .my-lesson-teacher-info{font-size:.85em;color:#e0e0e0;margin-bottom:5px;margin-top:5px}.teacher-lessons-deactivated-notice{grid-column:1 / -1;background-color:#fff2f2;border:1px solid #ffcccc;color:#c00;padding:15px;border-radius:6px;text-align:center;margin-bottom:20px;font-size:.95em}.teacher-header-deactivated{opacity:.6}.lesson-access-deactivated-message{padding:20px;background-color:#fff2f2;border:1px solid #ffcccc;color:#c00;border-radius:8px;text-align:center;font-size:1em;margin:20px auto;max-width:80%}.storage-overview-container{display:flex;width:100%;margin-bottom:20px;gap:16px;flex-wrap:wrap}.storage-column{flex:1;min-width:0}.storage-info-item{padding:20px 22px;margin-bottom:14px;background:#fff;border:1px solid #eaeaea;border-radius:14px;box-shadow:0 2px 10px #0000000d}.storage-info-item .storage-header{font-size:1.3em;font-weight:800;margin-top:0;margin-bottom:10px;color:#1a1a2e;letter-spacing:-.3px}.storage-info-item .storage-details{font-size:.9em;color:#555;display:block;margin-bottom:10px;font-weight:500}.storage-info-item .storage-graph-container{background-color:#e8ecf1;border-radius:12px;height:18px;overflow:hidden;width:100%;margin-top:8px;box-shadow:inset 0 1px 3px #00000014}.storage-info-item .storage-details-extra{font-size:.8em;color:#888;margin-left:3px;margin-top:6px;display:inline-block}.storage-info-item .storage-graph-fill{height:100%;border-radius:0;transition:width .6s cubic-bezier(.4,0,.2,1),background-color .5s ease-in-out}.storage-info-item .storage-graph-container>.storage-graph-fill:first-child{border-radius:12px 0 0 12px}.storage-info-item .storage-graph-container>.storage-graph-fill:last-child{border-radius:0 12px 12px 0}.storage-info-item .storage-graph-container>.storage-graph-fill:only-child{border-radius:12px}#pdfStorageFill{background-color:#007bff}.custom-storage-tooltip{display:none;position:absolute;background-color:#2c3e50;color:#ecf0f1;padding:8px 12px;border-radius:6px;font-size:.9em;white-space:nowrap;z-index:10000;box-shadow:0 3px 8px #00000040;pointer-events:none;transition:opacity .15s ease-in-out;opacity:0}.custom-storage-tooltip.visible{display:block;opacity:1}.custom-storage-tooltip .tooltip-arrow{content:"";position:absolute;left:50%;transform:translate(-50%);border-width:6px;border-style:solid}.custom-storage-tooltip .tooltip-arrow{top:100%;border-color:#2c3e50 transparent transparent transparent}.custom-storage-tooltip .tooltip-content{text-align:left;line-height:1.4}.landing-page-container{padding:0;background-color:#eef1f5;min-height:100vh;width:100%;box-sizing:border-box;overflow-y:visible;color:#333;text-align:center;display:flex;justify-content:center;align-items:flex-start}.hero-section{text-align:center;padding:0;margin-bottom:30px}.hero-section h1{font-size:2.5em;color:#d35400;margin-bottom:15px}.hero-section .sub-headline{font-size:1.1em;color:#555;max-width:700px;margin:0 auto 25px}.hero-visual-placeholder{width:100%;max-width:960px;aspect-ratio:16 / 9;background-color:#000;margin:0 auto 25px;border-radius:8px;overflow:hidden}.hero-visual-placeholder iframe{width:100%;height:100%;border:none}.section{padding:40px 0;margin-bottom:30px;border-bottom:1px solid #dcdcdc;text-align:center}.section:last-child{border-bottom:none;margin-bottom:0}.section h2{font-size:2em;color:indigo;margin-bottom:25px}.section p{font-size:1.1em;color:#555;max-width:800px;margin:0 auto 20px;line-height:1.6}.section ul{list-style:disc;padding-left:40px;text-align:left;max-width:600px;margin:0 auto 20px}.section ul li{margin-bottom:10px;font-size:1.05em}.how-it-works-section .features-list{list-style:none;padding:0;margin-top:30px;display:flex;flex-wrap:wrap;justify-content:center;gap:30px}.how-it-works-section .feature-item{background-color:#fff;border-radius:8px;padding:20px;text-align:center;width:100%;max-width:280px;box-shadow:0 2px 8px #00000014;border:1px solid #e7e7e7}.feature-item .feature-icon-placeholder{font-size:2.5em;color:#d35400;margin-bottom:15px}.feature-item h3{font-size:1.3em;color:indigo;margin-bottom:10px}.feature-item p{font-size:.95em;color:#555;line-height:1.5;max-width:100%;margin-bottom:0}.testimonials-section .testimonial-list{list-style:none;padding:0;margin-top:30px;display:flex;flex-wrap:wrap;justify-content:center;gap:30px}.testimonial-item{background-color:#f9f9f9;border-left:5px solid #d35400;padding:20px;border-radius:8px;max-width:350px;box-shadow:0 2px 8px #00000012;text-align:left}.testimonial-item blockquote{margin:0 0 15px;font-style:italic;color:#444;font-size:1.05em}.testimonial-item .testimonial-author{font-weight:700;color:#d35400;text-align:right}.testimonial-item .testimonial-author span{font-weight:400;color:#777;font-size:.9em;display:block}#manageMembershipModal{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:1000;display:none;align-items:center;justify-content:center;padding:20px;box-sizing:border-box}#manageMembershipModal .modal-content{background:#fff;width:100%;max-width:900px;max-height:90vh;border-radius:16px;box-shadow:0 25px 80px #4b008266;overflow:hidden;position:relative;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}#manageMembershipModal .modal-header{background:linear-gradient(135deg,gold,#ff8c00);color:indigo;padding:30px 40px;position:relative}#manageMembershipModal .modal-header h2{margin:0;font-size:32px;font-weight:700;text-align:center;text-shadow:0 2px 4px rgba(255,255,255,.3)}#manageMembershipModal .modal-close-btn{position:absolute;top:25px;right:30px;background:#4b00821a;border:none;color:indigo;font-size:28px;cursor:pointer;padding:8px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}#manageMembershipModal .modal-close-btn:hover{background:#4b008233;transform:scale(1.1)}#manageMembershipModal .modal-body{padding:0;max-height:calc(90vh - 140px);overflow-y:auto}#advancedSubscriptionManagement{padding:40px}#advancedSubscriptionManagement h3{color:indigo;font-size:28px;font-weight:700;margin:0 0 30px;text-align:center}#subscriptionManagementLoading{text-align:center;padding:80px 20px;color:#666}#subscriptionManagementLoading .loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 25px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}#subscriptionManagementLoading p{font-size:20px;margin:0;color:#777}#subscriptionManagementContent{display:none}.billing-toggle-section{display:flex;justify-content:center;align-items:center;margin:30px 0;gap:20px;font-size:18px;font-weight:600;color:indigo}.billing-toggle{position:relative;display:inline-block;width:70px;height:36px}.billing-toggle input{opacity:0;width:0;height:0}.billing-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,gold,#ff8c00);transition:.4s;border-radius:34px;box-shadow:0 4px 12px #ff8c004d}.billing-slider:before{position:absolute;content:"";height:28px;width:28px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%;box-shadow:0 2px 6px #0003}input:checked+.billing-slider{background:linear-gradient(135deg,indigo,#639)}input:checked+.billing-slider:before{transform:translate(34px)}.savings-badge{position:absolute;top:-25px;right:-15px;background:linear-gradient(135deg,#f44,#c00);color:#fff;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:700;white-space:nowrap;box-shadow:0 2px 8px #f446;transform:scale(0);transition:transform .3s ease}input:checked+.billing-slider+.savings-badge{transform:scale(1)}#currentSubscriptionDetails{background:linear-gradient(135deg,indigo,#639);color:#fff;padding:30px;border-radius:16px;margin-bottom:40px;box-shadow:0 12px 30px #4b00824d}#currentSubscriptionDetails h4{margin:0 0 25px;font-size:26px;font-weight:700;text-align:center}#currentSubscriptionDetails .subscription-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin-top:25px}#currentSubscriptionDetails .subscription-item{text-align:center;background:#ffffff26;padding:20px 15px;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}#currentSubscriptionDetails .subscription-item strong{display:block;font-size:14px;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:10px;opacity:.9;font-weight:600}#currentSubscriptionDetails .subscription-item span{font-size:20px;font-weight:700}#cancellationNotice{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);border:none;padding:25px;border-radius:12px;margin-top:25px;color:#8b0000;box-shadow:0 6px 20px #ff6b6b4d}#cancellationNotice strong{font-size:20px;display:block;margin-bottom:10px}#planChangeOptions{margin-bottom:40px}#planChangeOptions h4{color:indigo;font-size:24px;font-weight:700;margin-bottom:25px;text-align:center}#availablePlans{display:grid;gap:20px;margin-top:15px}.plan-option{padding:25px;border:3px solid #e0e0e0;border-radius:16px;background:#fff;position:relative;transition:all .3s ease;box-shadow:0 4px 16px #00000014}.plan-option:hover{transform:translateY(-4px);box-shadow:0 8px 25px #ff8c0033;border-color:#ff8c00}.plan-option.current-plan{border-color:indigo;background:linear-gradient(135deg,#f8f4ff,#ede4ff);box-shadow:0 8px 25px #4b008233}.plan-option h5{margin:0 0 12px;color:indigo;font-size:22px;font-weight:700}.plan-option .plan-price{margin:0 0 12px;font-size:24px;font-weight:900;background:linear-gradient(135deg,gold,#ff8c00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.plan-option .plan-storage{margin:0 0 5px;font-size:16px;color:#666;font-weight:500}.plan-option .plan-egress{margin:0 0 15px;font-size:16px;color:#666;font-weight:500}.plan-option .current-plan-badge{color:indigo;font-weight:700;font-size:18px;display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,gold,#ff8c00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.plan-option .switch-plan-btn{background:linear-gradient(135deg,gold,#ff8c00);color:indigo;border:none;padding:14px 25px;border-radius:12px;cursor:pointer;font-size:16px;font-weight:700;transition:all .3s ease;width:100%;box-shadow:0 4px 15px #ff8c004d}.plan-option .switch-plan-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff8c0066;background:linear-gradient(135deg,#ff8c00,gold)}.subscription-actions{border-top:3px solid #f0f0f0;margin-top:40px;background:linear-gradient(135deg,#fafafa,#f5f5f5);border-radius:16px;padding:40px 30px 30px}.subscription-actions h4{color:indigo;font-size:24px;font-weight:700;margin-bottom:25px;text-align:center}.subscription-actions .action-buttons{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-bottom:25px}.subscription-actions .action-buttons button{padding:16px 30px;border:none;border-radius:12px;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s ease;min-width:180px;box-shadow:0 4px 15px #0000001a}#cancelSubscriptionBtn{background:linear-gradient(135deg,#ff6b6b,#f44);color:#fff}#cancelSubscriptionBtn:hover{transform:translateY(-3px);box-shadow:0 8px 25px #ff6b6b66}#reactivateSubscriptionBtn{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}#reactivateSubscriptionBtn:hover{transform:translateY(-3px);box-shadow:0 8px 25px #4caf5066}.subscription-actions .action-note{font-size:16px;color:#666;text-align:center;line-height:1.6;margin:0;padding:20px;background:#ffffffb3;border-radius:12px;border-left:4px solid #FFD700}.modal-close-section{text-align:center;padding:25px 40px 35px;border-top:1px solid #e0e0e0;background:linear-gradient(135deg,#fafafa,#f0f0f0)}.modal-close-section button{background:linear-gradient(135deg,indigo,#639);color:#fff;border:none;padding:16px 40px;border-radius:12px;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s ease;min-width:140px;box-shadow:0 4px 15px #4b00824d}.modal-close-section button:hover{transform:translateY(-3px);box-shadow:0 8px 25px #4b008266;background:linear-gradient(135deg,#639,indigo)}#subscriptionManagementError{text-align:center;padding:80px 20px;color:#e74c3c}#subscriptionManagementError p{font-size:20px;margin-bottom:25px;font-weight:500}#subscriptionManagementError button{background:linear-gradient(135deg,gold,#ff8c00);color:indigo;border:none;padding:16px 30px;border-radius:12px;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ff8c004d}#subscriptionManagementError button:hover{transform:translateY(-3px);box-shadow:0 8px 25px #ff8c0066}@media (max-width: 768px){#manageMembershipModal{padding:15px}#manageMembershipModal .modal-content{max-height:95vh;max-width:95vw}#manageMembershipModal .modal-header{padding:25px 20px}#manageMembershipModal .modal-header h2{font-size:26px}#advancedSubscriptionManagement{padding:25px}#currentSubscriptionDetails .subscription-grid{grid-template-columns:1fr;gap:15px}.subscription-actions .action-buttons{flex-direction:column;align-items:center}.subscription-actions .action-buttons button{width:100%;max-width:280px}.billing-toggle-section{flex-direction:column;gap:15px;text-align:center}.billing-toggle{position:relative}}.plans-header{text-align:center;margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e0e0e0}.plans-header h1{font-size:2.2em;color:indigo;margin-bottom:10px}.plans-header p{font-size:1.1em;color:#555;max-width:600px;margin:0 auto}.billing-cycle-toggle{display:flex;justify-content:center;align-items:center;margin-bottom:30px;gap:15px;font-size:1.1em;color:#555}.billing-cycle-toggle .switch{position:relative;display:inline-block;width:60px;height:34px}.billing-cycle-toggle .switch input{opacity:0;width:0;height:0}.billing-cycle-toggle .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;-webkit-transition:.4s;transition:.4s}.billing-cycle-toggle .slider:before{position:absolute;content:"";height:26px;width:26px;left:4px;bottom:4px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.billing-cycle-toggle input:checked+.slider{background-color:#d35400}.billing-cycle-toggle input:checked+.slider:before{-webkit-transform:translateX(26px);-ms-transform:translateX(26px);transform:translate(26px)}.billing-cycle-toggle .slider.round{border-radius:34px}.billing-cycle-toggle .slider.round:before{border-radius:50%}.faq-section{margin-top:50px;padding-top:30px;border-top:1px solid #e0e0e0;text-align:left}.faq-section h2{text-align:center;font-size:1.8em;color:indigo;margin-bottom:25px}.faq-item{margin-bottom:20px}.faq-item h3{font-size:1.2em;color:#d35400;margin-bottom:8px;cursor:pointer;transition:color .2s ease-in-out;position:relative;padding-right:30px}.faq-item h3:after{content:"+";position:absolute;right:0;top:0;font-size:1.2em;font-weight:700;color:#d35400;transition:transform .2s ease-in-out}.faq-item h3.active:after{content:"−";transform:rotate(0)}.faq-item h3:hover{color:#ac4200}.faq-answer{font-size:1em;color:#555;line-height:1.6;margin-left:15px;display:none;padding-top:5px;transition:max-height .3s ease-out,opacity .3s ease-out;overflow:hidden;max-height:0;opacity:0}.membership-options{display:flex;flex-wrap:wrap;gap:30px;justify-content:center;margin-top:30px;margin-bottom:40px}.landing-content-wrapper{max-width:960px;width:100%;padding:30px 20px;text-align:left}.landing-header p{font-size:1.2em;color:#555}.membership-card{background:#fff;border-radius:8px;padding:25px;flex:1;min-width:300px;max-width:450px;box-shadow:0 4px 12px #0000001a;border:1px solid #e0e0e0;display:flex;flex-direction:column}.membership-card h2{font-size:1.8em;color:indigo;margin-top:0;margin-bottom:15px}.membership-card .description{font-size:1em;color:#666;margin-bottom:20px;line-height:1.6}.membership-card .features{list-style:disc;padding-left:20px;margin-bottom:20px;font-size:.95em;color:#444;flex-grow:1}.membership-card .features li{margin-bottom:8px}.membership-card .price{font-size:1.1em;font-weight:700;color:#333;margin-bottom:20px}.membership-card .cta-button{background:linear-gradient(45deg,#f90,#fc0);color:#fff;font-weight:700;padding:12px 20px;border:none;border-radius:5px;cursor:pointer;text-align:center;font-size:1em;transition:background .3s ease;align-self:stretch}.membership-card .cta-button:hover{background:linear-gradient(45deg,#e68a00,#fb0)}.membership-card.recommended-plan{border:2px solid #d35400;box-shadow:0 6px 15px #d3540040;position:relative}.membership-card.recommended-plan:before{content:attr(data-recommended-label);position:absolute;top:-15px;left:50%;transform:translate(-50%);background-color:#d35400;color:#fff;padding:5px 10px;border-radius:4px;font-size:.9em;font-weight:700}.landing-footer{text-align:center;margin-top:30px;padding-top:20px;border-top:1px solid #dcdcdc;font-size:.9em;color:#777}#landingView{background:linear-gradient(to bottom,#fff8f2,#fefcfb);font-family:Arial,sans-serif}#landingView .landing-content-wrapper{padding-top:0;padding-bottom:40px}#landingView .trial-banner{margin:25px auto 35px;padding:24px 28px;border-radius:18px;background:linear-gradient(135deg,#6a0dad,#ff8c00);color:#fff;display:flex;align-items:center;flex-wrap:wrap;gap:24px;max-width:960px;box-shadow:0 18px 35px #6a0dad40;position:relative;overflow:hidden}#landingView .trial-banner:after{content:"";position:absolute;top:-80px;right:-120px;width:260px;height:260px;background:#ffffff2e;border-radius:50%;pointer-events:none}#landingView .trial-banner__badge{background:#ffffff38;padding:8px 16px;border-radius:999px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:.85em}#landingView .trial-banner__content{flex:1 1 260px;min-width:240px;text-align:left}#landingView .trial-banner__title{margin:0 0 6px;font-size:1.45em;font-weight:700;line-height:1.3}#landingView .trial-banner__subtitle{margin:0;font-size:1.05em;line-height:1.6;color:#ffffffeb}#landingView .hero-section-split h1{font-size:2.8em;color:indigo;text-shadow:1px 1px 2px rgba(0,0,0,.1);margin-bottom:15px}#landingView .hero-section-split .sub-headline{font-size:1.2em;color:#5a5a5a;line-height:1.65;margin-bottom:30px}#landingView .hero-columns-container{gap:40px}#landingView .hero-column{padding:30px;border-radius:12px;box-shadow:0 5px 15px #00000014;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column}#landingView .hero-column:hover{transform:translateY(-6px);box-shadow:0 8px 20px #0000001a}#landingView .hero-column h2{font-size:1.3em;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}#landingView .hero-column h3{font-size:1.7em;margin-bottom:15px;line-height:1.3}#landingView .hero-column p{font-size:1em;line-height:1.6;color:#555;flex-grow:1;margin-bottom:20px}#landingView .hero-column.student-column{background-color:#fffaf2;border:1px solid #ffe8cc}#landingView .hero-column.student-column h2{color:#d35400}#landingView .hero-column.student-column h3{color:#c04e00}#landingView .hero-column.teacher-column{background-color:#f8f5fd;border:1px solid #e6d9ff}#landingView .hero-column.teacher-column h2{color:indigo}#landingView .hero-column.teacher-column h3{color:#3a006a}#landingView .hero-column .cta-button{padding:14px 25px;font-size:1.05em;font-weight:700;border:none;border-radius:8px;cursor:pointer;text-align:center;transition:background .3s ease,transform .2s ease,box-shadow .2s ease;color:#fff!important;text-decoration:none;display:inline-block;margin-top:auto}#landingView .hero-column.student-column .cta-button{background:linear-gradient(45deg,#f90,#ffc107);box-shadow:0 2px 4px #ff99004d}#landingView .hero-column.student-column .cta-button:hover{background:linear-gradient(45deg,#e68a00,#fca300);transform:translateY(-2px);box-shadow:0 4px 8px #f906}#landingView .hero-column.teacher-column .cta-button{box-shadow:0 2px 4px #6a0dad4d}#landingView .hero-column.teacher-column .cta-button:hover{background:linear-gradient(45deg,#5e0b9a,#7b1cc0)!important;transform:translateY(-2px);box-shadow:0 4px 8px #6a0dad66}#landingView .existing-account-callout{margin-top:32px;padding:18px 22px;border-radius:12px;background:linear-gradient(135deg,#ff99001f,#6a0dad1f);display:flex;flex-wrap:wrap;align-items:center;gap:16px;box-shadow:0 8px 24px #0000000d}#landingView .existing-account-callout .existing-account-text{margin:0;font-weight:600;color:#3a2b52;flex:1 1 260px;min-width:240px}#landingView .existing-account-callout .existing-account-button{background:linear-gradient(45deg,#f90,#fc0);color:#fff;border:none;border-radius:999px;padding:12px 24px;font-size:1em;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}#landingView .existing-account-callout .existing-account-button:hover{transform:translateY(-1px);box-shadow:0 8px 20px #ff99004d;background:linear-gradient(45deg,#e68a00,#ffb300)}#landingView .existing-account-callout .existing-account-button:focus-visible{outline:3px solid rgba(75,0,130,.4);outline-offset:2px}@media (max-width: 768px){#landingView .trial-banner{padding:22px;gap:16px;text-align:left}#landingView .trial-banner__title{font-size:1.3em}#landingView .trial-banner__subtitle{font-size:.98em}#landingView .existing-account-callout{flex-direction:column;align-items:flex-start;gap:12px}#landingView .existing-account-callout .existing-account-button{width:100%}}.auth-actions{display:flex;align-items:center}.signin-prompt{display:flex;align-items:center;margin-right:8px;color:#333;font-size:.9em;font-weight:500;cursor:default}.signin-prompt-text{color:#666;font-style:italic}.signin-prompt-arrow{margin-left:4px;font-size:1.2em;line-height:1}#landingView .landing-footer{padding-top:30px;margin-top:40px;border-top:1px solid #e0d8cf}.storage-graph-fill{position:relative}.storage-graph-fill:after{content:attr(title);position:absolute;bottom:125%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:8px 12px;border-radius:6px;font-size:.85em;white-space:nowrap;z-index:10;opacity:0;visibility:hidden;transition:opacity .2s ease-in-out,visibility 0s linear .2s;box-shadow:0 2px 5px #0003;pointer-events:none}.storage-graph-fill:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border-width:6px;border-style:solid;border-color:#333 transparent transparent transparent;opacity:0;visibility:hidden;transition:opacity .2s ease-in-out,visibility 0s linear .2s;pointer-events:none}.storage-graph-fill:hover:after,.storage-graph-fill:hover:before{opacity:1;visibility:visible;transition-delay:0s}#landingView .landing-footer p{color:#6c757d;font-size:.95em}#landingView .landing-footer a{color:#d35400;text-decoration:none;font-weight:500;transition:color .2s ease}#landingView .landing-footer a:hover{color:indigo;text-decoration:underline}#landingView .section{padding:0;margin-bottom:0;border-bottom:none}#landingView .final-cta-section{min-height:50px}#plansView{background:linear-gradient(to bottom,#fdfafc,#f8f5fd)}#plansView .landing-content-wrapper{max-width:1200px;padding-top:30px}#plansView .persona-plan-section{padding:30px;border-radius:12px;margin-bottom:50px!important;box-shadow:0 8px 25px #00000012}#plansView .student-plans-section{background-color:#fffaf2;border-top:4px solid #ff9900}#plansView .teacher-plans-section{background-color:#f8f5fd;border-top:4px solid #6A0DAD}#plansView .persona-section-title{font-size:2.4em!important;margin-bottom:15px!important;text-shadow:1px 1px 2px rgba(0,0,0,.1)}#plansView .student-plans-section .persona-section-title{color:#d35400}#plansView .teacher-plans-section .persona-section-title{color:indigo}#plansView .persona-plan-section>h3{font-size:2em!important;margin-bottom:10px!important}#plansView .persona-plan-section>p:first-of-type{font-size:1.15em!important;margin-bottom:40px!important;color:#555}#plansView .persona-plan-section .section{padding:25px 0!important;border-bottom:1px solid rgba(0,0,0,.08)!important}#plansView .persona-plan-section .section:last-of-type{border-bottom:none!important}#plansView .persona-plan-section .section>h3{font-size:1.8em!important;margin-bottom:25px!important}#plansView .student-plans-section .section>h3{color:#c04e00}#plansView .teacher-plans-section .section>h3{color:#3a006a}#plansView .feature-item{background-color:#fff;border:1px solid #e0e0e0;box-shadow:0 4px 10px #0000000d;transition:transform .2s ease,box-shadow .2s ease}#plansView .feature-item:hover{transform:translateY(-4px);box-shadow:0 6px 15px #00000014}#plansView .student-plans-section .feature-item .feature-icon-placeholder{color:#d35400}#plansView .teacher-plans-section .feature-item .feature-icon-placeholder{color:#6a0dad}#plansView .student-plans-section .feature-item h4{color:#d35400}#plansView .teacher-plans-section .feature-item h4{color:indigo}#plansView .key-features-student-section .features-list,#plansView .key-features-teacher-section .features-list{max-width:900px!important;margin-left:auto!important;margin-right:auto!important;flex-direction:column;gap:15px}#plansView .key-features-student-section .feature-item,#plansView .key-features-teacher-section .feature-item{max-width:none;width:100%;display:flex;align-items:center;text-align:left;gap:20px;padding:15px 20px}#plansView .key-features-student-section .feature-item .feature-icon-placeholder,#plansView .key-features-teacher-section .feature-item .feature-icon-placeholder{font-size:2em;margin-bottom:0;flex-shrink:0}#plansView .key-features-student-section .feature-item h4,#plansView .key-features-teacher-section .feature-item h4{margin:0;align-self:center;font-size:1.1em;line-height:1.45}#plansView .benefits-students-section ul li strong,#plansView .benefits-teachers-section ul li strong{font-weight:600}#plansView .student-plans-section .benefits-students-section ul li strong{color:#d35400}#plansView .teacher-plans-section .benefits-teachers-section ul li strong{color:indigo}#plansView .persona-plan-section .faq-landing-section .faq-item h4{font-size:1.25em;margin-bottom:8px}#plansView .student-plans-section .faq-landing-section .faq-item h4{color:#d35400}#plansView .teacher-plans-section .faq-landing-section .faq-item h4{color:indigo}#plansView .plans-header{border-bottom:1px solid rgba(0,0,0,.1)!important;margin-bottom:25px!important;padding-bottom:25px!important}#plansView .plans-header h1{font-size:2em!important;margin-bottom:12px!important}#plansView .student-plans-section .plans-header h1{color:#d35400}#plansView .teacher-plans-section .plans-header h1{color:indigo}#plansView .plans-header p{font-size:1.1em!important;color:#5a5a5a}#plansView .billing-cycle-toggle{margin-bottom:40px!important;font-size:1.05em}#plansView .billing-cycle-toggle input:checked+.slider{background-color:#f90}#plansView .teacher-plans-section .billing-cycle-toggle input:checked+.slider{background-color:#6a0dad}#plansView .trial-note-card{max-width:960px;margin:0 auto 40px;padding:28px 32px;border-radius:16px;background:linear-gradient(135deg,#6a0dad14,#ff8c001f);border:1px solid rgba(106,13,173,.18);box-shadow:0 12px 28px #2d134a14;display:flex;align-items:center;flex-wrap:wrap;gap:22px}#plansView .trial-note-card__badge{background:linear-gradient(135deg,#6a0dad,#ff8c00);color:#fff;padding:6px 14px;border-radius:999px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:.78em}#plansView .trial-note-card__content{flex:1 1 260px;min-width:240px;color:#3a2b52}#plansView .trial-note-card__content h3{margin:0 0 8px;font-size:1.45em;color:indigo}#plansView .trial-note-card__content p{margin:0;font-size:1.05em;line-height:1.65;color:#4a4a4a}#plansView .trial-note-card__cta{margin:0;font-size:1em;font-weight:600;color:indigo;display:flex;align-items:center;gap:8px}#plansView .trial-note-card__cta svg{width:18px;height:18px;fill:currentColor}@media (max-width: 768px){#plansView .trial-note-card{padding:24px;gap:16px;text-align:left}#plansView .trial-note-card__content h3{font-size:1.3em}#plansView .trial-note-card__content p{font-size:1rem}}#plansView .membership-card{box-shadow:0 5px 20px #00000014;border:1px solid #ddd;transition:transform .3s ease,box-shadow .3s ease}#plansView .membership-card:hover{transform:translateY(-8px);box-shadow:0 10px 30px #0000001f}#plansView .membership-card h2{font-size:1.7em!important;margin-bottom:12px!important}#plansView .student-plans-section .membership-card h2{color:#d35400}#plansView .teacher-plans-section .membership-card h2{color:indigo}#plansView .membership-card .description{font-size:.95em;color:#555}#plansView .membership-card .features{font-size:.9em;color:#4a4a4a}#plansView .membership-card .price strong{font-size:1.5em}#plansView .membership-card .cta-button{padding:14px 25px;font-size:1.05em;font-weight:700;color:#fff!important;box-shadow:0 2px 5px #00000026}#plansView .student-plans-section .membership-card .cta-button{background:linear-gradient(45deg,#f90,#ffc107)}#plansView .student-plans-section .membership-card .cta-button:hover{background:linear-gradient(45deg,#e68a00,#fca300)}#plansView .teacher-plans-section .membership-card .cta-button{background:linear-gradient(45deg,#6a0dad,#8a2be2)}#plansView .teacher-plans-section .membership-card .cta-button:hover{background:linear-gradient(45deg,#5e0b9a,#7b1cc0)}#plansView .membership-card.recommended-plan{border-width:3px;transform:scale(1.03)}#plansView .student-plans-section .membership-card.recommended-plan{border-color:#ffc107}#plansView .teacher-plans-section .membership-card.recommended-plan{border-color:#ab6eff}#plansView .membership-card.recommended-plan:before{font-size:.95em;padding:6px 12px;top:-18px}#plansView .student-plans-section .membership-card.recommended-plan:before{background-color:#ffc107;color:#583c00}#plansView .teacher-plans-section .membership-card.recommended-plan:before{background-color:#ab6eff;color:#fff}#plansView .faq-section{margin-top:60px!important;padding:30px;background-color:#fff;border-radius:10px;border-top:none!important;box-shadow:0 6px 20px #0000000f}#plansView .faq-section>h2{color:indigo!important;font-size:2em!important}#plansView .faq-section .faq-item h3{color:#d35400!important;font-size:1.25em!important}#plansView .faq-section .faq-item h3.active{color:#ac4200!important}#plansView .faq-answer{background-color:#f9f9f9;padding:10px 15px;border-radius:5px;margin-left:0;border-left:3px solid #ffcc80}#plansView #backToLandingFromPlansBtn{background:#7f8c8d;color:#fff;padding:12px 25px;font-size:1em;font-weight:700;border-radius:6px;transition:background .3s ease}#plansView #backToLandingFromPlansBtn:hover{background:#6c7a7b}.all-student-lessons-view-active{display:flex;flex-direction:column;padding:25px 30px;background-color:#fff8f0;height:100%;overflow-y:auto;box-sizing:border-box}.all-student-lessons-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding:10px 7px 0;border-bottom:2px solid #ffe0b2}.all-student-lessons-header h2{margin:0;font-size:1.8em;color:indigo;font-weight:700}.back-to-student-mgmt-btn{padding:10px 18px;background:linear-gradient(45deg,#f90,#fc0);color:#000!important;border:none;border-radius:5px;cursor:pointer;font-size:.95em;font-weight:700;transition:background-color .2s ease-in-out}.back-to-student-mgmt-btn:hover{background:linear-gradient(45deg,#e68a00,#fca300)}.all-lessons-list{flex-grow:1;margin-left:13px;margin-right:13px}.loading-message,.no-lessons-message,.error-message{text-align:center;padding:20px;font-size:1.1em;color:#555}.error-message{color:#d9534f}.lesson-item-full-list{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:18px 20px;margin-bottom:10px;background:linear-gradient(to right,#fff,#fffcf7);border:1px solid #ffe8cc;border-radius:6px;box-shadow:0 2px 4px #00000012;transition:box-shadow .2s ease-in-out}.lesson-item-full-list:hover{box-shadow:0 4px 8px #0000001a;border-color:#ffd1a3}.lesson-item-full-list .lesson-name-full{font-weight:600;color:indigo;flex-grow:1;margin-right:15px;font-size:1.1em;overflow-wrap:break-word;word-break:break-word}.lesson-item-full-list .lesson-date-full{font-size:.9em;color:#777;margin-right:15px;flex-shrink:0;white-space:nowrap}.lesson-item-full-list .lesson-actions-full{display:flex;gap:8px;flex-shrink:0}.lesson-item-full-list .open-lesson-btn-full-list{padding:8px 12px;border:1px solid #4B0082;border-radius:5px;cursor:pointer;font-size:13px;text-decoration:none;color:indigo;background-color:#fff;font-weight:700;text-align:center;transition:background-color .3s,color .3s}.lesson-item-full-list .open-lesson-btn-full-list:hover{background-color:#ffe5cc;color:#d35400;border-color:transparent}.lesson-item-full-list .remove-assignment-btn-full-list{background-color:#6c757d;color:#fff;border:none}.lesson-item-full-list .remove-assignment-btn-full-list:hover{background-color:#5a6268}.assign-new-pdf-button{background:linear-gradient(45deg,#f90,#fc0);color:#000!important;font-weight:700;border:none;border-radius:5px;cursor:pointer;padding:8px 12px;font-size:13px;text-align:center;display:block;width:100%;box-sizing:border-box;transition:background .2s ease}.assign-new-pdf-button:hover{background:linear-gradient(45deg,#e68a00,#fca300)}.view-more-lessons-styled-button{background:linear-gradient(45deg,#1b5e20,#388e3c);color:#fff!important;font-weight:700;border:none;border-radius:5px;cursor:pointer;padding:8px 12px;font-size:13px;text-align:center;display:block;width:100%;box-sizing:border-box;transition:background .2s ease}.view-more-lessons-styled-button:hover{background:linear-gradient(45deg,#14461c,#2a6f2e)}@media (max-width: 600px){.lesson-item-full-list{flex-direction:column;align-items:flex-start}.lesson-item-full-list .lesson-name-full,.lesson-item-full-list .lesson-date-full{margin-right:0;margin-bottom:8px}.lesson-item-full-list .lesson-actions-full{width:100%;justify-content:flex-start;margin-top:10px}.lesson-item-full-list .lesson-actions-full .pure-button{flex-grow:1;text-align:center}}.storage-bar .pdf-egress{background:#007bff;height:100%;transition:width .3s ease}.storage-bar .video-egress{background:#28a745;height:100%;transition:width .3s ease}.storage-bar-container{margin:10px 0}.storage-bar{background:#eee;height:20px;border-radius:10px;overflow:hidden;display:flex}.storage-header{display:flex;justify-content:space-between;margin-bottom:5px}.storage-warning{color:#721c24;background-color:#f8d7da;padding:8px;margin-top:8px;border-radius:4px;display:none}.warning .storage-bar{background-color:#fff3cd}.critical .storage-bar{background-color:#f8d7da}.practice-notes-tooltip,#overlayPracticeNotesTooltip,.yearly-calendar-overlay .practice-notes-tooltip{position:fixed!important;background:#1e1e1ef2!important;color:#fff!important;padding:12px!important;border-radius:8px!important;border:1px solid rgba(255,255,255,.2)!important;box-shadow:0 4px 12px #0000004d!important;-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important;max-width:300px!important;min-width:200px!important;font-size:.85rem!important;z-index:2001!important;pointer-events:none!important;opacity:0!important;transform:translateY(10px)!important;transition:opacity .2s ease,transform .2s ease!important;display:none!important}.practice-notes-tooltip.visible,#overlayPracticeNotesTooltip.visible,.yearly-calendar-overlay .practice-notes-tooltip.visible{opacity:1!important;transform:translateY(0)!important;display:block!important}.practice-notes-tooltip-header{font-weight:700;font-size:.9rem;margin-bottom:8px;color:#4caf50;border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:4px}.practice-notes-tooltip-content{line-height:1.4;color:#e0e0e0;white-space:pre-wrap;word-wrap:break-word}.practice-notes-tooltip-empty{color:#999;font-style:italic}.practice-notes-tooltip-loading{color:#4caf50;display:flex;align-items:center;gap:8px}.practice-notes-tooltip-loading:before{content:"";width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #4CAF50;border-radius:50%;animation:spin 1s linear infinite;display:inline-block}@keyframes practiceNotesPulse{0%,to{opacity:.6}50%{opacity:1}}#languageFlagContainer{display:flex;gap:2px;align-items:center;flex-wrap:wrap}.language-flag-btn{background:none!important;border:2px solid transparent!important;border-radius:4px!important;padding:2px 4px!important;cursor:pointer!important;font-size:16px!important;transition:all .2s ease!important;opacity:.6!important;display:flex!important;align-items:center!important;justify-content:center!important;min-width:28px!important;min-height:28px!important;outline:none!important}.language-flag-btn:hover{opacity:1!important;transform:scale(1.1)!important}.language-flag-btn.active{opacity:1!important;border-color:#fff!important;background-color:#fff3!important}#languageMainBtn{font-family:"Noto Color Emoji","Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,Twemoji Mozilla,EmojiOne Mozilla,Symbola,sans-serif;font-size:16px;line-height:1.2;font-variant-emoji:emoji;text-rendering:optimizeQuality;-webkit-font-feature-settings:"liga" on,"calt" on;font-feature-settings:"liga" on,"calt" on;background:linear-gradient(45deg,#8a2be2,#9370db)!important;box-shadow:0 2px 8px #8a2be24d!important;transition:all .3s ease!important}#languageMainBtn:hover{background:linear-gradient(45deg,#9370db,#ba55d3)!important;box-shadow:0 4px 12px #8a2be280!important;transform:translateY(-1px)!important}.language-option{font-family:"Noto Color Emoji","Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,Twemoji Mozilla,EmojiOne Mozilla,Symbola,sans-serif;font-variant-emoji:emoji;text-rendering:optimizeQuality;-webkit-font-feature-settings:"liga" on,"calt" on;font-feature-settings:"liga" on,"calt" on}@-moz-document url-prefix(){#languageMainBtn,.language-option span:first-child{font-family:Twemoji Mozilla,"Noto Color Emoji",EmojiOne Mozilla,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,Symbola,monospace,sans-serif!important;font-weight:400!important;font-style:normal!important;text-rendering:optimizeQuality!important}}#textAnnotationToolbar{background-color:#333;border:1px solid #555;border-radius:6px;box-shadow:0 4px 8px #0000004d;padding:6px;gap:6px}#textAnnotationToolbar input[type=color]{height:28px;width:35px;border:1px solid #666;border-radius:4px;cursor:pointer;padding:2px;background-color:#444}#textAnnotationToolbar input[type=color]::-webkit-color-swatch-wrapper{padding:0}#textAnnotationToolbar input[type=color]::-webkit-color-swatch{border:1px solid #777;border-radius:3px}#textAnnotationToolbar input[type=color]::-moz-color-swatch{border:1px solid #777;border-radius:3px}#textAnnotationToolbar select{background-color:#444;color:#eee;border:1px solid #666;border-radius:4px;padding:4px 8px;font-size:13px;cursor:pointer;outline:none}#textAnnotationToolbar select:hover{border-color:#888}#textAnnotationToolbar button{background-color:#555;color:#eee;border:1px solid #777;border-radius:4px;padding:4px 8px;font-size:14px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease;min-width:30px;text-align:center}#textAnnotationToolbar button:hover{background-color:#666;border-color:#999}#textAnnotationToolbar button[style*="background: rgb(192, 192, 192)"],#textAnnotationToolbar button[style*="background-color: rgb(192, 192, 192)"]{background-color:#007bff!important;color:#fff!important;border-color:#0056b3!important}#textToolbarLink{font-size:16px;padding:4px 6px}#storageAlertBanner{display:none;padding:12px 20px;text-align:center;font-size:.95em;font-weight:500;line-height:1.4;position:fixed;top:0;left:0;width:100%;z-index:2000;box-sizing:border-box;border-bottom:1px solid rgba(0,0,0,.1);box-shadow:0 2px 4px #0000000d;transition:background-color .3s ease,color .3s ease,transform .3s ease}#storageAlertBanner a{color:inherit;font-weight:700;text-decoration:underline}#storageAlertBanner a:hover{text-decoration:none}#uploadProgressBar{background-color:#4caf50;width:0%;height:20px;color:#fff;font-size:10px;font-weight:700;white-space:nowrap;overflow:hidden;border-radius:.3rem;transition:width .3s ease-in-out;box-sizing:border-box;padding:0;display:flex;align-items:center;justify-content:center}.toolbar-icon.color-swatch{width:22px;height:22px;border:1px solid #ccc;padding:0;margin:0 2px;border-radius:3px;cursor:pointer;vertical-align:middle;box-shadow:0 1px 1px #0000001a}.toolbar-icon.color-swatch:hover{border-color:#888;box-shadow:0 1px 3px #0003}.youtubeVideoDotAnnotation{position:absolute;width:24px;height:24px;background-color:red;border:2px solid black;border-radius:50%;cursor:pointer;z-index:190;box-shadow:0 1px 3px #0000004d}.youtubeVideoDotAnnotation.placing{background-color:#ff000080;border:2px dashed black;opacity:.7;z-index:192}.youtubeVideoDotAnnotation.blinking{animation:blink 1s infinite;z-index:198}.settings-panel{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#ffeb3b,#ff9800);z-index:1000;flex-direction:column;align-items:stretch;align-content:flex-start;justify-content:flex-start;padding:0 20px 20px;gap:0px;overflow-y:auto;box-sizing:border-box}.settings-panel.visible{display:flex;flex-direction:column}.settings-panel-close-button{position:absolute;top:20px;right:25px;font-size:1.8em;font-weight:700;color:#555;background:transparent;border:none;cursor:pointer;padding:5px 10px}.settings-panel-close-button:hover{color:#000}.settings-panel-title{width:100%;text-align:center;margin-bottom:0;font-size:1.8em;color:#333;flex-basis:100%;order:-1}.settings-item-container h3{font-size:1.2em;font-weight:700;color:#fff;margin-top:0;margin-bottom:10px;text-align:center}.settings-item-container{width:100%;max-width:310px;margin-left:auto;margin-right:auto;margin-bottom:10px;flex-shrink:0;background-color:indigo;padding:15px;border-radius:8px;box-shadow:0 2px 8px #0003}.settings-item-container label{display:block;margin-bottom:5px;font-size:.9em;font-weight:600;color:#f3e5f5}.settings-item-container input[type=number],.settings-item-container input[type=color],.settings-item-container select,.settings-item-container div[contenteditable=true]{width:100%;padding:8px;margin-bottom:8px;border:1px solid #7B1FA2;border-radius:4px;box-sizing:border-box;background-color:#6a1b9a;color:#f3e5f5}.settings-item-container input[type=color]{height:38px;padding:2px;border:1px solid #7B1FA2}.settings-item-container button{padding:8px 12px;background-color:#8e24aa;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s ease}.settings-item-container button:hover{background-color:#7b1fa2}#specialOffersToolbar button.toolbar-icon{background-color:#9c27b0;color:#fff;border:1px solid #7B1FA2}#specialOffersToolbar button.toolbar-icon:hover{background-color:#7b1fa2}#specialOffersToolbar input[type=color].toolbar-icon{background-color:#6a1b9a;border:1px solid #7B1FA2}#pdfAssignmentPreviewModal{align-items:center;justify-content:center;padding-top:0!important}#pdfAssignmentPreviewModal .modal-content{max-width:700px;max-height:90vh;display:flex;flex-direction:column;padding:0;margin:0!important}#pdfAssignmentPreviewModal .modal-header{padding:10px 15px;background:linear-gradient(90deg,#f90,#fc0);color:#fff;border-top-left-radius:5px;border-top-right-radius:5px}#pdfPreviewModalBody{padding:15px;flex-grow:1;display:flex;flex-direction:column;min-height:0}#pdfPreviewAreaInModal{width:100%;flex-grow:1;border:1px solid #ccc;overflow:auto;margin-bottom:15px;background-color:#e0e0e0;min-height:150px}#pdfPreviewModalFooter{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-top:auto}.pdf-preview-canvas{box-shadow:0 2px 8px #00000026}@media (max-width: 767px){#pdfAssignmentPreviewModal .modal-content{max-width:95vw;margin:2.5vh auto}#pdfPreviewAreaInModal{min-height:100px}}.yearly-calendar-view-active{background:#1a1a1a!important;color:#fff;padding:20px;height:100%;box-sizing:border-box;overflow-y:auto}.yearly-calendar-container{width:100%;max-width:1200px;margin:0 auto}.yearly-calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #444}.yearly-calendar-header h2{margin:0;font-size:1.8rem;color:#fff;flex:1;text-align:center}.close-yearly-calendar-btn{background:#e53e3e;color:#fff;border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:background .2s ease;flex-shrink:0}.close-yearly-calendar-btn:hover{background:#c53030}.calendar-year-selector{display:flex;align-items:center;justify-content:center;gap:15px;margin-bottom:25px}.calendar-year-selector button{background:#3182ce;color:#fff;border:none;border-radius:6px;padding:8px 15px;cursor:pointer;font-size:1rem;transition:background .2s ease}.calendar-year-selector button:hover{background:#2c5aa0}.calendar-year-selector span{color:#fff;font-size:1.4rem;font-weight:700;min-width:80px;text-align:center}.calendar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-bottom:20px}.calendar-month{background:#ffffff1a;border-radius:10px;padding:15px;border:1px solid #444}.calendar-month-header{text-align:center;color:#fff;font-weight:700;font-size:1.1rem;margin-bottom:10px;padding-bottom:5px;border-bottom:1px solid #444}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:5px}.calendar-weekday{text-align:center;color:#ccc;font-size:.8rem;padding:4px;font-weight:700}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day{min-height:35px;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;font-size:.75rem;padding:2px;position:relative;transition:all .2s ease;border:1px solid transparent}.calendar-day:hover{transform:scale(1.05);box-shadow:0 2px 8px #ffffff4d;border-color:#fff}.calendar-day.other-month{opacity:.3;cursor:default}.calendar-day.other-month:hover{transform:none;box-shadow:none;border-color:transparent}.calendar-day.no-practice{background:#4a5568;color:#cbd5e0}.calendar-day.some-practice{background:#d69e2e;color:#fff}.calendar-day.good-practice{background:#38a169;color:#fff}.calendar-day.today{border:2px solid #f7fafc;font-weight:700}.calendar-day-number{font-size:.8rem;line-height:1;font-weight:700}.calendar-day-time{font-size:.6rem;line-height:1;margin-top:1px;opacity:.9}.calendar-legend{display:flex;justify-content:center;gap:25px;margin-top:20px;flex-wrap:wrap;padding:15px;background:#ffffff0d;border-radius:8px}.yearly-summary{display:flex;justify-content:center;gap:30px;margin:15px 0;padding:20px;background:#ffffff14;border-radius:10px;border:1px solid rgba(255,255,255,.1)}.summary-item{text-align:center;color:#fff}.summary-label{display:block;font-size:.8rem;color:#ffffffb3;margin-bottom:5px;font-weight:400}.summary-value{display:block;font-size:1.1rem;font-weight:700;color:#38a169}.calendar-legend-item{display:flex;align-items:center;gap:8px;color:#fff;font-size:.9rem}.calendar-legend-color{width:16px;height:16px;border-radius:3px;border:1px solid rgba(255,255,255,.2)}@media (max-width: 768px){.yearly-calendar-view-active{padding:15px}.calendar-grid{grid-template-columns:1fr;gap:15px}.calendar-day{min-height:30px;font-size:.7rem}.calendar-legend{gap:15px;flex-direction:column;align-items:center}.yearly-summary{flex-direction:column;gap:15px;padding:15px}.summary-item{display:flex;justify-content:space-between;align-items:center;text-align:left}.summary-label{margin-bottom:0}.calendar-legend-item{justify-content:center}.yearly-calendar-header h2{font-size:1.4rem}.calendar-year-selector span{font-size:1.2rem}}@media (max-width: 480px){.calendar-month{padding:10px}.calendar-day{min-height:25px;font-size:.65rem}.calendar-day-time{font-size:.55rem}.calendar-year-selector{gap:10px}.calendar-year-selector button{padding:6px 10px;font-size:.9rem}}.yearly-calendar-overlay{position:fixed;background:#1a1a1af2;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;overflow-y:auto;overflow-x:hidden;padding:20px;box-sizing:border-box;display:none;scrollbar-width:thin;scrollbar-color:rgba(100,100,100,.5) transparent}.yearly-calendar-overlay::-webkit-scrollbar{width:6px}.yearly-calendar-overlay::-webkit-scrollbar-track{background:transparent}.yearly-calendar-overlay::-webkit-scrollbar-thumb{background-color:#64646480;border-radius:3px}.yearly-calendar-overlay::-webkit-scrollbar-thumb:hover{background-color:#646464b3}.yearly-calendar-overlay.active{display:block}.yearly-calendar-overlay-content{max-width:1200px;margin:0 auto;position:relative}#pdfArea{position:relative}@media (max-width: 768px){.yearly-calendar-overlay{padding:10px}}
