.login-page{align-items:center;background-color:#f5f5f5;display:flex;justify-content:center;min-height:100vh}.login-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;max-width:400px;padding:2rem;width:100%}.login-header{margin-bottom:2rem;text-align:center}.login-header h1{color:#333;margin-bottom:.5rem}.login-header p{color:#666;font-size:.9rem}.error-message{font-size:.9rem;margin-bottom:1rem;padding:.8rem}.form-group{margin-bottom:1.5rem}.login-page label{color:#333;display:block;font-weight:500;margin-bottom:.5rem}.login-page input{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.8rem;width:100%}.login-page input:focus{border-color:#2196f3;box-shadow:0 0 0 2px #2196f333;outline:none}.login-button{background-color:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.8rem;transition:background-color .2s;width:100%}.login-button:hover{background-color:#1976d2}.login-button:disabled{background-color:#90caf9;cursor:not-allowed}.login-footer{margin-top:1.5rem;text-align:center}.login-footer a{color:#2196f3;font-size:.9rem;text-decoration:none}.login-footer a:hover{text-decoration:underline}.admin-dashboard{font-family:Arial,sans-serif;margin:0 auto;max-width:1200px;padding:20px}.admin-dashboard header{border-bottom:1px solid #eee;margin-bottom:20px;padding-bottom:10px}.header-content{justify-content:space-between}.header-content,.user-controls{align-items:center;display:flex}.user-controls{gap:12px}.user-email{color:#555;font-size:14px}.logout-button{background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer;padding:6px 12px}.logout-button:hover{background-color:#e0e0e0}.tabs{border-bottom:1px solid #ddd;display:flex;margin-bottom:20px}.tabs button{background:none;border:none;color:#333;cursor:pointer;font-size:16px;padding:10px 20px}.tabs button:disabled{color:#ccc;cursor:not-allowed}.tabs button.active{border-bottom:3px solid #06c;color:#06c;font-weight:700}.tab-content{padding:20px 0}.learner-dashboard{background-color:#f0f8ff;font-family:Comic Sans MS,Trebuchet MS,cursive,sans-serif;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px}.dashboard-header{background-color:#19a4a0;border-radius:20px;box-shadow:0 8px 32px #0003;color:#fff;margin-bottom:30px;overflow:hidden;padding:25px;position:relative;text-align:center}.dashboard-header:before{animation:sparkle 2s ease-in-out infinite;content:"⭐✨🌟✨⭐";font-size:24px;left:50%;position:absolute;top:10px;transform:translateX(-50%)}@keyframes sparkle{0%,to{opacity:.7;transform:translateX(-50%) scale(.9)}50%{opacity:1;transform:translateX(-50%) scale(1.1)}}.header-content{margin-top:15px}.dashboard-header h1{animation:bounce 2s ease-in-out infinite;font-size:2.5rem;margin-bottom:10px;text-shadow:2px 2px 4px #0000004d}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-5px)}60%{transform:translateY(-3px)}}.welcome-message{font-size:1.3rem;margin-bottom:0;text-shadow:1px 1px 2px #0003}.header-actions{display:flex;gap:10px;position:absolute;right:20px;top:20px}.logout-button,.refresh-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:25px;color:#fff;cursor:pointer;font-weight:700;padding:8px 16px;transition:all .3s ease}.logout-button:hover,.refresh-button:hover{background:#ffffff4d;transform:scale(1.05)}.dashboard-loading{align-items:center;background:#fff;border-radius:20px;box-shadow:0 8px 32px #0000001a;color:#19a4a0;display:flex;flex-direction:column;font-size:1.5rem;justify-content:center;margin:20px;min-height:400px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#19a4a0;height:50px;width:50px}.dashboard-error{background-color:#ffebee;border:3px solid #ff4747;border-radius:20px;box-shadow:0 8px 32px #0000001a;color:#ff4747;font-size:1.2rem;font-weight:700;margin:20px 0;padding:25px;text-align:center}.retry-button{background-color:#19a4a0;border:none;border-radius:25px;box-shadow:0 4px 15px #0003;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;margin-top:15px;padding:12px 24px;transition:all .3s ease}.retry-button:hover{background-color:#158b87;box-shadow:0 6px 20px #0000004d;transform:translateY(-2px) scale(1.05)}.no-catalogs{background-color:#fff8e1;border:3px solid #e8a327;border-radius:20px;box-shadow:0 8px 32px #0000001a;color:#e8a327;margin:20px 0;padding:40px 20px;text-align:center}.empty-state-icon{animation:wiggle 2s ease-in-out infinite;font-size:4rem;margin-bottom:20px}@keyframes wiggle{0%,to{transform:rotate(0deg)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.no-catalogs h3{color:#c7941f;font-size:1.8rem;margin-bottom:15px}.recent-activity{margin-bottom:30px}.recent-activity h2{color:#19a4a0;font-size:2rem;margin-bottom:15px;text-align:center;text-shadow:2px 2px 4px #0000001a}.activity-card{align-items:center;background-color:#fff;border:3px solid #19a4a0;border-radius:20px;box-shadow:0 8px 32px #00000026;cursor:pointer;display:flex;overflow:hidden;padding:25px;position:relative;transition:all .3s ease}.activity-card:before{animation:dance 1s ease-in-out infinite alternate;content:"🎉";font-size:1.5rem;position:absolute;right:10px;top:10px}@keyframes dance{0%{transform:rotate(-10deg) scale(1)}to{transform:rotate(10deg) scale(1.1)}}.activity-card:hover{background-color:#f0f8ff;box-shadow:0 12px 40px #0003;transform:translateY(-5px) scale(1.02)}.activity-icon{align-items:center;animation:pulse 2s ease-in-out infinite;background-color:#e8a327;border-radius:50%;box-shadow:0 4px 15px #0003;display:flex;flex-shrink:0;font-size:2rem;height:60px;justify-content:center;margin-right:20px;width:60px}.activity-details{flex-grow:1}.activity-details h3{color:#19a4a0;font-size:1.4rem;font-weight:700;margin:0 0 5px}.activity-catalog{color:#e8a327;font-size:1.1rem;font-weight:700;margin:0 0 5px}.activity-time{color:#888;font-size:1rem;margin:0}.continue-button{transition:all .3s ease}.continue-button:hover{background-color:#e63939;box-shadow:0 6px 20px #0000004d;transform:translateY(-2px) scale(1.05)}.section-header h2{color:#19a4a0;font-size:2rem;margin-bottom:20px;text-align:center;text-shadow:2px 2px 4px #0000001a}.catalogs-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}.catalog-card{background-color:#fff8e1;border:3px solid #e8a327;border-radius:20px;box-shadow:0 8px 32px #00000026;overflow:hidden;padding:25px;position:relative;transition:all .3s ease}.catalog-card:before{animation:twinkle 2s ease-in-out infinite;content:"🌟";font-size:1.5rem;position:absolute;right:15px;top:15px}@keyframes twinkle{0%,to{opacity:.5;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.catalog-card:hover{border-color:#19a4a0;box-shadow:0 15px 45px #0003;transform:translateY(-8px) scale(1.03)}.catalog-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.catalog-title{color:#19a4a0;flex:1 1;font-size:1.5rem;font-weight:700;margin:0 15px 0 0;text-shadow:1px 1px 2px #0000001a}.progress-circle{align-items:center;animation:rotate 10s linear infinite;background-color:#19a4a0;border-radius:50%;box-shadow:0 4px 15px #0003;color:#fff;display:flex;font-size:.9rem;font-weight:700;height:50px;justify-content:center;width:50px}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.catalog-description{font-size:1.1rem}.progress-container{margin-bottom:20px}.progress-bar{background-color:#fffc;border:2px solid #e8a327;margin-bottom:8px}.progress-text{font-size:1rem}.content-types{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.content-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.9rem;font-weight:700;gap:5px;padding:8px 12px;transition:all .3s ease}.content-badge:hover{transform:scale(1.1)}.content-badge.stories{background-color:#e8a327;border:2px solid #e8a327;color:#fff;text-shadow:1px 1px 2px #0000004d}.content-badge.interactive{background-color:#19a4a0;border:2px solid #19a4a0;color:#fff;text-shadow:1px 1px 2px #0000004d}.content-badge.flipcards{background-color:#ff4747;border:2px solid #ff4747;color:#fff;text-shadow:1px 1px 2px #0000004d}.content-badge.listen-record{background-color:#19a4a0;border:2px solid #19a4a0;color:#fff;text-shadow:1px 1px 2px #0000004d}.catalog-actions{display:flex;flex-direction:column;gap:12px}.primary-button,.secondary-button{border:none;border-radius:25px;cursor:pointer;font-size:1.1rem;font-weight:700;overflow:hidden;padding:15px;position:relative;text-align:center;transition:all .3s ease}.primary-button:before,.secondary-button:before{background:#ffffff4d;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .6s ease;width:0}.primary-button:hover:before,.secondary-button:hover:before{height:300px;width:300px}.primary-button{background-color:#19a4a0;box-shadow:0 6px 20px #0003;color:#fff}.primary-button:hover{background-color:#158b87;box-shadow:0 8px 25px #0000004d;transform:translateY(-3px) scale(1.05)}.secondary-button{background-color:#fff;border:3px solid #e8a327;box-shadow:0 4px 15px #0000001a;color:#19a4a0}.secondary-button:hover{background-color:#f0f8ff;border-color:#19a4a0;box-shadow:0 6px 20px #0003;color:#19a4a0;transform:translateY(-3px) scale(1.05)}.learner-dashboard:before{animation:float 3s ease-in-out infinite;content:"🎈🎨🌈🎵🎪";font-size:1.5rem;pointer-events:none;position:fixed;right:20px;top:20px;z-index:1}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media (max-width:768px){.learner-dashboard{background-color:#f0f8ff;padding:15px}.catalogs-grid{gap:20px;grid-template-columns:1fr}.catalog-card{max-width:100%}.activity-card{flex-direction:column;padding:20px;text-align:center}.activity-icon{margin-bottom:15px;margin-right:0}.continue-button{margin-top:15px}.dashboard-header h1{font-size:2rem}.header-actions{justify-content:center;margin-top:15px;position:relative;right:auto;top:auto}.catalog-header{align-items:center;flex-direction:column;text-align:center}.catalog-title{margin-bottom:10px;margin-right:0}}.continue-button,.primary-button,.retry-button,.secondary-button{position:relative;z-index:1}.continue-button:active,.primary-button:active,.retry-button:active,.secondary-button:active{transform:translateY(1px) scale(.98)}@keyframes sparkleAnimation{0%{opacity:0;transform:scale(0) rotate(0deg)}50%{opacity:1;transform:scale(1) rotate(180deg)}to{opacity:0;transform:scale(0) rotate(1turn)}}.catalog-card:hover:after{animation:sparkleAnimation 1.5s ease-in-out infinite;content:"✨";font-size:1.2rem;left:20%;position:absolute;top:20%}.activity-card:hover:after{animation:sparkleAnimation 1.8s ease-in-out .3s infinite;content:"🌟";font-size:1.2rem;left:70%;position:absolute;top:30%}@media (prefers-reduced-motion:reduce){.activity-card:before,.activity-icon,.catalog-card:before,.dashboard-header h1,.empty-state-icon,.learner-dashboard:before,.progress-circle{animation:none}.activity-card:hover,.catalog-card:hover,.continue-button:hover,.primary-button:hover,.retry-button:hover,.secondary-button:hover{transform:none}}@media (prefers-contrast:high){.learner-dashboard{background-color:#fff}.activity-card,.catalog-card,.dashboard-header,.no-catalogs{border:3px solid #000}.activity-details h3,.catalog-title,.section-header h2{color:#000}}.catalog-view{background-color:#f0f8ff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px}.catalog-header-actions{align-items:center;display:flex;gap:15px;justify-content:space-between;margin-bottom:25px}.back-button{align-items:center;background-color:#fff;border:3px solid #19a4a0;border-radius:25px;box-shadow:0 4px 15px #0000001a;color:#19a4a0;cursor:pointer;display:flex;font-size:1.1rem;font-weight:700;gap:8px;min-height:48px;padding:12px 20px;transition:all .2s ease}@media (hover:hover) and (pointer:fine){.back-button:hover{background-color:#19a4a0;box-shadow:0 6px 20px #0003;color:#fff;transform:translateY(-2px)}}@media (hover:none) and (pointer:coarse){.back-button:active{background-color:#19a4a0;color:#fff;transform:scale(.98)}}.continue-button{align-items:center;background-color:#ff4747;border:none;border-radius:25px;box-shadow:0 4px 15px #0003;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:700;gap:8px;min-height:48px;padding:12px 20px;transition:all .2s ease}@media (hover:hover) and (pointer:fine){.continue-button:hover{background-color:#e63939;box-shadow:0 8px 25px #0000004d;transform:translateY(-2px)}}@media (hover:none) and (pointer:coarse){.continue-button:active{background-color:#e63939;transform:scale(.98)}}.catalog-header{background-color:#fff8dc;border:3px solid #e8a327;border-radius:20px;box-shadow:0 8px 32px #00000026;margin-bottom:30px;overflow:hidden;padding:30px;position:relative}.catalog-header:before{content:"🌟✨🎯✨🌟";font-size:1.2rem;opacity:.8;position:absolute;right:15px;top:15px}.catalog-info h1{color:#19a4a0;font-size:2.5rem;margin-bottom:15px;text-shadow:2px 2px 4px #0000001a}.catalog-description{color:#19a4a0;font-size:1.3rem;font-weight:500;line-height:1.6;margin-bottom:20px}.catalog-meta{margin-top:20px}.catalog-type{border-radius:20px;box-shadow:0 4px 15px #0000001a;display:inline-block;font-size:1rem;font-weight:700;margin-bottom:15px;padding:8px 16px}.language-type{background-color:#19a4a0}.language-type,.program-type{color:#fff;text-shadow:1px 1px 2px #0000004d}.program-type{background-color:#e8a327}.progress-summary{display:flex;flex-wrap:wrap;gap:15px;margin-top:15px}.progress-stat{background-color:#fff;border:2px solid #e8a327;border-radius:20px;box-shadow:0 4px 15px #0000001a;color:#19a4a0;font-size:1rem;font-weight:700;padding:8px 15px;transition:all .2s ease}@media (hover:hover) and (pointer:fine){.progress-stat:hover{background-color:#e8a327;box-shadow:0 6px 20px #0003;color:#fff;transform:translateY(-2px)}}.achievement-message{background-color:#19a4a0;border-radius:20px;box-shadow:0 4px 15px #0003;margin-top:20px;padding:15px 20px;text-align:center}.achievement-message p{color:#fff;font-size:1.2rem;font-weight:700;margin:0;text-shadow:2px 2px 4px #0000004d}.progress-message{margin-top:8px}.progress-message small{color:#19a4a0;font-size:.9rem;font-style:italic;font-weight:700}.lessons-section{margin-bottom:40px}.lessons-section h2{color:#333;font-size:2rem;margin-bottom:25px;position:relative;text-align:center;text-shadow:1px 1px 2px #0000001a}.lessons-section h2:before{content:"🎓";margin-right:10px}.lessons-section h2:after{content:"🎓";margin-left:10px}.no-lessons{background-color:#fff8e1;border:3px solid #e8a327;border-radius:20px;box-shadow:0 8px 32px #0000001a;color:#19a4a0;padding:40px;text-align:center}.no-lessons-icon{font-size:4rem;margin-bottom:20px}.no-lessons p{font-size:1.3rem;font-weight:700}.lessons-grid{display:flex;flex-direction:column;gap:20px}.lesson-card{background-color:#fff;border:3px solid #e8a327;border-radius:20px;box-shadow:0 8px 32px #0000001a;cursor:pointer;overflow:hidden;padding:25px;position:relative;transition:all .2s ease}.lesson-card:before{content:"🎯";font-size:1.5rem;opacity:.7;position:absolute;right:15px;top:15px}@media (hover:hover) and (pointer:fine){.lesson-card:hover{background-color:#f0f8ff;border-color:#19a4a0;box-shadow:0 15px 45px #0003;transform:translateY(-5px)}}@media (hover:none) and (pointer:coarse){.lesson-card:active{background-color:#f0f8ff;border-color:#19a4a0;transform:scale(.98)}}.lesson-card.completed{background-color:#e8f5e8;border-color:#19a4a0}.lesson-card.completed:before{color:#19a4a0;content:"🏆"}.lesson-card.in-progress{background-color:#e0f2f1;border-color:#19a4a0}.lesson-card.in-progress:before{color:#19a4a0;content:"🚀"}.lesson-card.available{background-color:#fff8e1;border-color:#e8a327}.lesson-card.available:before{color:#e8a327;content:"⭐"}.lesson-top-section{align-items:flex-start;display:flex;gap:20px;margin-bottom:15px}.lesson-image{flex-shrink:0}.lesson-image img{border:3px solid #19a4a0;border-radius:15px;box-shadow:0 4px 15px #0003;height:90px!important;object-fit:cover;transition:all .2s ease;width:140px!important}@media (hover:hover) and (pointer:fine){.lesson-card:hover .lesson-image img{border-color:#e8a327;transform:scale(1.05)}}.lesson-summary{flex:1 1;min-width:0}.lesson-title{align-items:center;color:#19a4a0;display:flex;font-size:1.4rem;font-weight:700;gap:10px;margin:0 0 10px;text-shadow:1px 1px 2px #0000001a}.title-icon{font-size:1.2rem}.title-icon.completed,.title-icon.in-progress{color:#19a4a0}.title-icon.available{color:#e8a327}.lesson-meta{align-items:center;display:flex;flex-wrap:wrap;gap:15px;margin-bottom:10px}.estimated-time,.lesson-units{background-color:#e8a327;border-radius:15px;box-shadow:0 2px 8px #0003;color:#fff;font-size:.9rem;font-weight:700;padding:4px 12px;text-shadow:1px 1px 2px #0000004d}.lesson-progress.compact{align-items:center;display:flex;gap:10px;margin-top:10px}.progress-bar{background-color:#f5f5f5;border:2px solid #19a4a0;border-radius:10px;box-shadow:inset 0 2px 4px #0000001a;flex:1 1;height:12px}.progress-fill{background-color:#19a4a0;border-radius:8px;position:relative;transition:width .8s ease}.progress-text{color:#19a4a0;font-size:.9rem;font-weight:700;min-width:35px;text-align:center}.lesson-description-full{border-top:2px dashed #e8a327;margin-top:15px;padding-top:15px}.lesson-description-full p{color:#19a4a0;font-size:1.1rem;line-height:1.6;margin:0}.lesson-objective{background-color:#e8a327;border:2px solid #19a4a0;border-radius:15px;margin-top:12px;padding:12px}.lesson-objective em{color:#fff;font-size:1rem;font-weight:700;text-shadow:1px 1px 2px #0000004d}.loading{align-items:center;background-color:#f0f8ff;color:#333;display:flex;flex-direction:column;font-size:1.5rem;justify-content:center;min-height:400px}.loading-spinner{animation:spin 2s linear infinite;font-size:3rem;margin-bottom:20px}.error-container{align-items:center;background-color:#ffebee;border:3px solid #ff4747;border-radius:20px;box-shadow:0 8px 32px #0000001a;display:flex;flex-direction:column;justify-content:center;min-height:400px;padding:40px;text-align:center}.error-icon{font-size:4rem;margin-bottom:20px}.error-message{color:#ff4747;font-size:1.3rem;font-weight:700;margin-bottom:25px}.progress-bar.completed .progress-fill,.progress-bar.in-progress .progress-fill{background-color:#19a4a0}.progress-bar.not-started .progress-fill{background-color:#e0e0e0}@media (max-width:768px){.catalog-view{background-color:#f0f8ff;padding:15px}.catalog-header-actions{flex-direction:column;gap:12px}.back-button,.continue-button{justify-content:center;padding:16px 20px;width:100%}.catalog-header{background-color:#fff8dc;padding:20px}.catalog-info h1{font-size:2rem;text-align:center}.catalog-description{font-size:1.1rem;text-align:center}.lesson-top-section{flex-direction:column;gap:15px;text-align:center}.lesson-image{align-self:center}.lesson-image img{height:125px!important;width:200px!important}.lesson-title{font-size:1.2rem}.lesson-meta,.lesson-title{justify-content:center}.progress-summary{align-items:center;flex-direction:column}.progress-stat{max-width:300px;text-align:center;width:100%}.lessons-section h2{font-size:1.6rem}.lesson-card{margin-bottom:15px;padding:20px}}@media (max-width:480px){.catalog-view{padding:12px}.catalog-header{padding:16px}.catalog-info h1{font-size:1.6rem}.lesson-card{padding:16px}.lesson-title{font-size:1.1rem}.lesson-image img{height:100px!important;width:160px!important}}@media (prefers-contrast:high){.catalog-view{background-color:#fff}.catalog-header,.error-container,.lesson-card,.no-lessons{border:3px solid #000}.catalog-description,.catalog-info h1,.lesson-title{color:#000}}@media (prefers-reduced-motion:reduce){.back-button,.continue-button,.lesson-card,.lesson-image img,.loading-spinner,.progress-fill,.progress-stat{animation:none;transition:none}.back-button:hover,.continue-button:hover,.lesson-card:hover{transform:none}}.back-button:focus,.continue-button:focus,.lesson-card:focus{outline:3px solid #2196f3;outline-offset:2px}@media (prefers-reduced-motion:reduce){.catalog-header:before,.lesson-card:before{animation:none}}.lesson-view{background:linear-gradient(135deg,#19a4a0,#16a085);display:flex;flex-direction:column;font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;height:100vh}.lesson-header{align-items:center;background:linear-gradient(135deg,#fff,#f8fafc);border-bottom:2px solid #19a4a0;box-shadow:0 2px 8px #0000001a;display:flex;flex-shrink:0;justify-content:space-between;padding:1rem 1.5rem;position:sticky;top:0;z-index:20}.lesson-header .back-button{align-items:center;background:linear-gradient(135deg,#19a4a0,#16a085);border:none;border-radius:12px;box-shadow:0 3px 8px #19a4a04d;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;text-shadow:0 1px 2px #0003;transition:all .3s ease}.lesson-header .back-button:hover{box-shadow:0 4px 12px #19a4a066;filter:brightness(1.05);transform:translateY(-2px)}.lesson-header .lesson-info{flex:1 1;margin:0 1rem;text-align:center}.lesson-header .lesson-info h1{color:#19a4a0;font-size:1.5rem;font-weight:700;margin:0 0 .5rem;text-shadow:1px 1px 2px #0000001a}.lesson-header .lesson-description{color:#19a4a0;font-size:.875rem;font-weight:500;line-height:1.4;margin:0}.lesson-view .loading{color:#fff;font-size:1.25rem;font-weight:600;text-shadow:1px 1px 3px #0000004d}.lesson-view .error-container,.lesson-view .loading{align-items:center;display:flex;flex-direction:column;height:100vh;justify-content:center;text-align:center}.lesson-view .error-container{background:linear-gradient(135deg,#fff,#f0f8ff);color:#19a4a0;padding:2rem}.lesson-view .error-message{color:#ef4444;font-size:1.25rem;font-weight:600;line-height:1.6;margin-bottom:1.5rem;max-width:400px}.lesson-view .error-container .back-button{background:linear-gradient(135deg,#ef4444,#f87171);border:none;border-radius:12px;box-shadow:0 3px 8px #ef44444d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2rem;text-shadow:0 1px 2px #0003;transition:all .3s ease}.lesson-view .error-container .back-button:hover{box-shadow:0 4px 12px #ef444466;filter:brightness(1.05);transform:translateY(-2px)}.lesson-view>:last-child{flex:1 1;min-height:0}@media (max-width:768px){.lesson-view{background:#19a4a0}.lesson-header{background:#fff;border-bottom:2px solid #19a4a0;padding:1rem}.lesson-header .lesson-info h1{font-size:1.25rem}.lesson-header .lesson-description{font-size:.8125rem}.lesson-header .back-button{background:#19a4a0;border-radius:8px;font-size:.8125rem;padding:.625rem 1.25rem}}@media (max-width:640px){.lesson-view{background:#19a4a0}.lesson-header{background:#fff;padding:.75rem 1rem}.lesson-header .lesson-info h1{font-size:1.125rem;text-shadow:none}.lesson-header .lesson-description{font-size:.75rem}.lesson-header .back-button{background:#19a4a0;box-shadow:0 2px 4px #0000001a;font-size:.75rem;padding:.5rem 1rem;text-shadow:none}.lesson-header .back-button span{display:none}}@media (max-width:480px){.lesson-header{padding:.625rem .75rem}.lesson-header .lesson-info{margin:0 .5rem}.lesson-header .lesson-info h1{font-size:1rem}.lesson-header .lesson-description{display:none}.lesson-header .back-button{min-width:40px;padding:.5rem .75rem}}.unit-content br+br{display:none!important}.unit-content p:empty,.unit-content p:has(br:only-child){display:none!important}.unit-content p br:only-child,.unit-content>:empty{display:none!important}.unit-content ol,.unit-content ul{line-height:1.6!important;margin:1rem 0!important;padding-left:2rem!important}.unit-content li{line-height:1.6!important;margin:.5rem 0!important}.unit-content li br{display:none!important}.unit-content li p{display:inline!important;margin:.25rem 0!important}.unit-content li ol,.unit-content li ul{margin:.5rem 0!important;padding-left:1.5rem!important}.unit-viewer{width:100%}@media (min-width:640px){.unit-viewer{margin:0 auto;max-width:800px}}@media (min-width:1024px){.unit-viewer{max-width:900px}}.unit-content table,.unit-content table td,.unit-content table th,.unit-content table tr{border:none!important;border-collapse:collapse!important}.unit-content table *{border:none!important}.unit-viewer{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;height:100vh;overflow:hidden;position:relative}.progress-container{background-color:#fff;border-bottom:1px solid #e5e7eb;padding:1rem;position:sticky;top:0;z-index:20}.progress-info{display:flex;justify-content:center;margin-bottom:.5rem}.progress-text{color:#6b7280;font-family:inherit;font-size:.875rem;font-weight:500}.progress-bar{background-color:#e5e7eb;border-radius:2px;height:4px;overflow:hidden;width:100%}.progress-fill{background-color:#3b82f6;height:100%;transition:width .3s ease}.internal-progress{border-top:1px solid #f3f4f6;margin-top:.5rem;padding-top:.5rem}.internal-progress-text{color:#9ca3af;display:flex;font-family:inherit;font-size:.75rem;justify-content:center;margin-bottom:.25rem}.internal-progress-bar{background-color:#f3f4f6;border-radius:1px;height:2px;overflow:hidden;width:100%}.internal-progress-fill{background-color:#10b981;height:100%;transition:width .3s ease}.main-content{flex:1 1;font-family:inherit;overflow-y:auto;padding:1rem;position:relative;transition:transform .3s ease-out}.content-container{animation:slideIn .3s ease-out;font-family:inherit;max-width:100%}.internal-pagination{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fffffff2;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1.5rem;padding:1rem 0;position:sticky;top:0;z-index:10}.unit-viewer .internal-pagination .page-number{align-items:center;background-color:#fff;border:2px solid #e5e7eb;border-radius:50%;color:#374151;cursor:pointer;display:flex;font-family:inherit;font-size:.75rem;font-weight:600;height:32px;justify-content:center;position:relative;transition:all .2s ease;width:32px}.unit-viewer .internal-pagination .page-number.completed{background-color:#19a4a0!important;border-color:#19a4a0!important;color:#fff!important}.unit-viewer .internal-pagination .page-number.still-learning{background-color:#ff9800!important;border-color:#ff9800!important;color:#fff!important}.unit-viewer .internal-pagination .page-number.visited{background-color:#19a4a0!important;border-color:#19a4a0!important;color:#fff!important}.unit-viewer .internal-pagination .page-number.active{background-color:#dc3545!important;border:3px solid #dc3545!important;box-shadow:0 0 0 1px #dc354533;color:#fff!important}.unit-viewer .internal-pagination .page-number:hover:not(.active){box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.unit-viewer .internal-pagination .page-number.completed:hover{background-color:#158e8a!important;border-color:#158e8a!important}.unit-viewer .internal-pagination .page-number.still-learning:hover{background-color:#e68900!important;border-color:#e68900!important}.unit-viewer .internal-pagination .page-number.visited:hover{background-color:#158e8a!important;border-color:#158e8a!important}.unit-viewer .internal-pagination .page-number.active:hover{box-shadow:0 2px 8px #dc35454d;transform:translateY(-1px)}.unit-content{font-family:inherit;min-height:300px;padding:1rem 0}.unit-title{color:#111827;font-family:inherit;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.unit-navigation{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#f8fafc;border-top:1px solid #e5e7eb;bottom:0;display:flex;justify-content:space-between;padding:1rem 1.5rem;position:sticky}.navigation-center{flex:1 1}.nav-button,.navigation-center{align-items:center;display:flex;justify-content:center}.nav-button{background-color:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;gap:.5rem;min-width:100px;padding:.75rem 1.5rem;transition:all .2s ease}.nav-button:hover:not(:disabled){background-color:#f3f4f6;border-color:#3b82f6;color:#3b82f6;transform:translateY(-1px)}.nav-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.unit-info{align-items:center;display:flex;flex-direction:column;gap:.25rem}.completion-badge{background-color:#d1fae5;border:1px solid #10b981;border-radius:12px;color:#10b981;font-family:inherit;font-size:.6875rem;font-weight:600;padding:.125rem .5rem}.speech-bubble{margin-top:-60px;max-width:80vw;width:280px}.speech-bubble-close{font-size:18px;height:28px;width:28px}.speech-bubble-content p{font-size:15px}.speech-bubble-audio-btn{font-size:14px;padding:8px 14px}.unit-viewer-loading{color:#6b7280}.unit-viewer-error,.unit-viewer-loading{align-items:center;background-color:#fff;display:flex;font-family:inherit;font-size:1.125rem;height:100vh;justify-content:center}.unit-viewer-error{color:#ef4444;padding:2rem;text-align:center}.main-content::-webkit-scrollbar{width:4px}.main-content::-webkit-scrollbar-track{background:#0000}.main-content::-webkit-scrollbar-thumb{background:#9ca3af4d;border-radius:2px}.main-content::-webkit-scrollbar-thumb:hover{background:#9ca3af80}.check-answer-button:focus,.hotspot:focus,.nav-button:focus,.page-number:focus{outline:2px solid #3b82f6;outline-offset:2px}@keyframes slideIn{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes tooltip-appear{0%{opacity:0;transform:translateY(-10px) scale(.9)}to{opacity:1;transform:translateY(-5px) scale(1)}}@media (max-width:639px){.unit-viewer{height:100vh}.main-content{padding:.75rem}.unit-title{font-size:1.25rem;margin-bottom:1rem}.check-answer-button{font-size:1rem;margin:1.5rem auto;padding:.875rem 1.5rem}.feedback-container{margin-top:1.5rem;padding:1.25rem}.feedback-header{font-size:1.125rem}.unit-navigation{padding:.75rem 1rem}.nav-button{font-size:.8125rem;min-width:80px;padding:.625rem 1rem}.nav-button span{display:none}.internal-pagination{gap:.375rem;padding:.75rem 0}.unit-viewer .internal-pagination .page-number{font-size:.6875rem;height:28px;width:28px}.unit-viewer .internal-pagination .page-number.active{border-width:2px}.blank-input-row{align-items:stretch;flex-direction:column;gap:.5rem}.blank-label{min-width:auto}.type-in-input{max-width:none}}@media (max-width:479px){.main-content{padding:.5rem}.unit-title{font-size:1.125rem}.unit-navigation{padding:.625rem .75rem}.nav-button{min-width:70px;padding:.5rem .75rem}.speech-bubble{margin-top:-40px;max-width:95vw;width:200px}.speech-bubble-content{max-height:120px;padding:10px}.speech-bubble-content p{font-size:12px;margin:0 16px 6px 0}}@media (prefers-reduced-motion:reduce){.content-container,.hotspot,.hotspot-indicator,.nav-button{animation:none;transition:none}.story-content table td img,.unit-content table td img{border-radius:6px;box-shadow:0 2px 8px #0000001a;display:block!important;height:auto!important;margin:5px auto!important;margin:10px auto!important;max-width:100%!important;min-width:200px!important;object-fit:none!important;opacity:1!important;visibility:visible!important;width:auto!important}.story-content table td,.unit-content table td{min-width:250px;overflow:visible!important;padding:12px;vertical-align:top}.story-content table img,.unit-content table img{display:block!important;max-width:100%!important;min-width:200px!important;opacity:1!important;visibility:visible!important}.story-tooltip-popup{align-items:center!important;display:flex!important;flex-direction:column!important;justify-content:center!important}.story-tooltip-popup,.story-tooltip-popup *{text-align:center!important}.story-tooltip-popup img{display:block!important;margin:0 auto 8px!important}.story-tooltip-popup .callout-with-image{align-items:center!important;display:flex!important;flex-direction:column!important;justify-content:center!important;text-align:center!important;width:100%!important}.story-tooltip-popup .callout-with-image span{display:block!important;text-align:center!important;width:100%!important}.story-tooltip-popup div{align-items:center!important;display:flex!important;flex-direction:column!important;text-align:center!important;width:100%!important}.story-tooltip-popup span{display:block!important;text-align:center!important;width:100%!important}}.mcq-content{font-family:inherit;margin:0 auto;max-width:600px;padding:1rem 0}.mcq-stem{color:#374151;font-family:inherit;font-size:1.125rem;font-weight:400;line-height:1.6;margin-bottom:2rem;text-align:left}.mcq-stem h1,.mcq-stem h2,.mcq-stem h3,.mcq-stem h4,.mcq-stem h5,.mcq-stem h6{color:#1f2937;font-family:inherit;font-weight:600;margin:1rem 0 .5rem}.mcq-stem h1{font-size:1.5rem}.mcq-stem h2{font-size:1.375rem}.mcq-stem h3{font-size:1.25rem}.mcq-stem h4{font-size:1.125rem}.mcq-stem h5{font-size:1rem}.mcq-stem h6{font-size:.875rem}.mcq-stem p{font-family:inherit;margin:.75rem 0}.mcq-stem b,.mcq-stem strong{font-family:inherit;font-weight:600}.mcq-stem em,.mcq-stem i{font-family:inherit;font-style:italic}.mcq-stem u{font-family:inherit;text-decoration:underline}.mcq-stem img{border-radius:6px;box-shadow:0 2px 8px #0000001a;height:auto;margin:1rem 0;max-width:100%}.mcq-stem hr{background-color:#e5e7eb;border:none;height:1px;margin:1.5rem 0}.mcq-stem ol,.mcq-stem ul{line-height:1.6!important;margin:1rem 0!important;padding-left:2rem!important}.mcq-stem li{line-height:1.6!important;margin:.5rem 0!important}.mcq-stem li br{display:none!important}.mcq-stem li p{display:inline!important;margin:.25rem 0!important}.mcq-stem li ol,.mcq-stem li ul{margin:.5rem 0!important;padding-left:1.5rem!important}.mcq-stem table,.mcq-stem table td,.mcq-stem table th,.mcq-stem table tr,.mcq-stem tbody,.mcq-stem thead{border:none!important;border-collapse:collapse!important}.mcq-stem table *{border:none!important}.mcq-stem table td img{border-radius:6px;box-shadow:0 2px 8px #0000001a;display:block!important;height:auto!important;margin:10px auto!important;max-width:100%!important;min-width:200px!important;object-fit:none!important;opacity:1!important;visibility:visible!important;width:auto!important}.mcq-stem table td{min-width:250px;overflow:visible!important;padding:12px;vertical-align:top}.mcq-stem br+br{display:none!important}.mcq-stem p:empty,.mcq-stem p:has(br:only-child){display:none!important}.mcq-stem p br:only-child,.mcq-stem>:empty{display:none!important}.mcq-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.mcq-option{background-color:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;padding:1.25rem;transition:all .2s ease}.mcq-option:hover:not(.selected):not(.correct):not(.incorrect){background-color:#f9fafb;border-color:#d1d5db;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.mcq-option.selected{background-color:#eff6ff;border-color:#3b82f6;box-shadow:0 2px 8px #3b82f626;transform:translateY(-1px)}.mcq-option.correct{background-color:#d1fae5;border-color:#10b981;color:#065f46}.mcq-option.incorrect{background-color:#fee2e2;border-color:#ef4444;color:#b91c1c}.option-text{font-family:inherit;font-weight:400}.check-answer-button{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.check-answer-button:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 4px 12px #3b82f64d}.multiple-response-content{font-family:inherit;margin:0 auto;max-width:600px;padding:1rem 0}.multiple-response-stem{color:#374151;font-family:inherit;font-size:1.125rem;font-weight:400;line-height:1.6;margin-bottom:2rem;text-align:left}.multiple-response-stem h1,.multiple-response-stem h2,.multiple-response-stem h3,.multiple-response-stem h4,.multiple-response-stem h5,.multiple-response-stem h6{color:#1f2937;font-family:inherit;font-weight:600;margin:1rem 0 .5rem}.multiple-response-stem h1{font-size:1.5rem}.multiple-response-stem h2{font-size:1.375rem}.multiple-response-stem h3{font-size:1.25rem}.multiple-response-stem h4{font-size:1.125rem}.multiple-response-stem h5{font-size:1rem}.multiple-response-stem h6{font-size:.875rem}.multiple-response-stem p{font-family:inherit;margin:.75rem 0}.multiple-response-stem b,.multiple-response-stem strong{font-family:inherit;font-weight:600}.multiple-response-stem em,.multiple-response-stem i{font-family:inherit;font-style:italic}.multiple-response-stem u{font-family:inherit;text-decoration:underline}.multiple-response-stem img{border-radius:6px;box-shadow:0 2px 8px #0000001a;height:auto;margin:1rem 0;max-width:100%}.multiple-response-stem hr{background-color:#e5e7eb;border:none;height:1px;margin:1.5rem 0}.multiple-response-stem ol,.multiple-response-stem ul{line-height:1.6!important;margin:1rem 0!important;padding-left:2rem!important}.multiple-response-stem li{line-height:1.6!important;margin:.5rem 0!important}.multiple-response-stem li br{display:none!important}.multiple-response-stem li p{display:inline!important;margin:.25rem 0!important}.multiple-response-stem li ol,.multiple-response-stem li ul{margin:.5rem 0!important;padding-left:1.5rem!important}.multiple-response-stem table,.multiple-response-stem table td,.multiple-response-stem table th,.multiple-response-stem table tr,.multiple-response-stem tbody,.multiple-response-stem thead{border:none!important;border-collapse:collapse!important}.multiple-response-stem table *{border:none!important}.multiple-response-stem table td img{border-radius:6px;box-shadow:0 2px 8px #0000001a;display:block!important;height:auto!important;margin:10px auto!important;max-width:100%!important;min-width:200px!important;object-fit:none!important;opacity:1!important;visibility:visible!important;width:auto!important}.multiple-response-stem table td{min-width:250px;overflow:visible!important;padding:12px;vertical-align:top}.multiple-response-stem br+br{display:none!important}.multiple-response-stem p:empty,.multiple-response-stem p:has(br:only-child){display:none!important}.multiple-response-stem p br:only-child,.multiple-response-stem>:empty{display:none!important}.multiple-response-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.multiple-response-option{align-items:center;background-color:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;font-family:inherit;gap:1rem;padding:1.25rem;transition:all .2s ease}.multiple-response-option:hover:not(.selected):not(.correct):not(.incorrect){background-color:#f9fafb;border-color:#d1d5db;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.multiple-response-option.selected{background-color:#eff6ff;border-color:#3b82f6}.multiple-response-option.correct{background-color:#d1fae5;border-color:#10b981}.multiple-response-option.incorrect{background-color:#fee2e2;border-color:#ef4444}.checkbox{align-items:center;border:2px solid #d1d5db;border-radius:6px;display:flex;flex-shrink:0;height:24px;justify-content:center;transition:all .2s ease;width:24px}.multiple-response-option.selected .checkbox{background-color:#3b82f6;border-color:#3b82f6}.checkbox-mark{color:#fff;font-family:inherit;font-size:14px;font-weight:700}@media (max-width:640px){.mcq-content{max-width:100%;padding:.75rem 0}.mcq-stem{font-size:1rem;margin-bottom:1.5rem}.mcq-option{font-size:.9375rem;padding:1rem}.check-answer-button{font-size:1rem;margin:1.5rem auto;padding:.875rem 1.5rem}.feedback-container{margin-top:1.5rem;padding:1.25rem}.feedback-header{font-size:1.125rem}}@media (max-width:480px){.mcq-option{padding:.875rem}.mcq-stem table td{min-width:150px;padding:8px}.mcq-stem table td img{min-width:150px!important}}.mcq-option:focus,.multiple-response-option:focus{outline:2px solid #3b82f6;outline-offset:2px}.check-answer-button:focus{outline:2px solid #3b82f6}@media (prefers-reduced-motion:reduce){.check-answer-button,.mcq-option,.multiple-response-option{transform:none!important;transition:none}.check-answer-button:hover:not(:disabled),.mcq-option:hover:not(.selected):not(.correct):not(.incorrect),.multiple-response-option:hover:not(.selected):not(.correct):not(.incorrect){transform:none}}.type-in-content{font-family:inherit;margin:0 auto;max-width:600px;padding:1rem 0}.type-in-question{color:#374151;font-family:inherit;font-size:1.125rem;line-height:1.6;margin-bottom:2rem;text-align:left}.type-in-blank-wrapper{display:inline-block;margin:0 4px}.blank-number{background-color:#19a4a0;border-radius:4px;color:#fff;display:inline-block;font-size:.875rem;font-weight:600;min-width:24px;padding:2px 8px;text-align:center}.fill-blanks-section{background-color:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;margin:2rem 0;padding:1.5rem}.fill-blanks-section h3{color:#374151;font-size:1.125rem;font-weight:600;margin:0 0 1rem}.blanks-inputs{display:flex;flex-direction:column;gap:1rem}.blank-input-row{align-items:center;display:flex;gap:1rem}.blank-label{color:#374151;font-size:.9rem;font-weight:600;min-width:80px}.type-in-input{border:2px solid #e5e7eb;border-radius:6px;flex:1 1;font-family:inherit;font-size:1rem;max-width:300px;padding:8px 12px;transition:all .2s ease}.type-in-input:focus{background-color:#f0fdfa;border-color:#19a4a0;outline:none}.type-in-input:disabled{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.answer-result{border-radius:6px;font-family:inherit;margin:1rem 0;padding:.75rem}.answer-result.correct{background-color:#d1fae5;border:1px solid #10b981;color:#065f46}.answer-result.incorrect{background-color:#fee2e2;border:1px solid #ef4444;color:#b91c1c}.answer-feedback{font-size:.9rem;font-style:italic;margin-top:.5rem}@media (max-width:640px){.type-in-content{max-width:100%;padding:.75rem 0}.type-in-question{font-size:1rem;margin-bottom:1.5rem}.fill-blanks-section{margin:1.5rem 0;padding:1.25rem}.blank-input-row{align-items:stretch;flex-direction:column;gap:.5rem}.blank-label{min-width:auto}.type-in-input{max-width:none}.check-answer-button{font-size:1rem;margin:1.5rem auto;padding:.875rem 1.5rem}.feedback-container{margin-top:1.5rem;padding:1.25rem}.feedback-header{font-size:1.125rem}}@media (max-width:480px){.fill-blanks-section{padding:1rem}.type-in-input{font-size:.9375rem;padding:.75rem 1rem}.blank-number{font-size:.8125rem;padding:1px 6px}}.type-in-input:focus{outline:2px solid #19a4a0;outline-offset:2px}@media (prefers-reduced-motion:reduce){.check-answer-button,.type-in-input{transform:none!important;transition:none}.check-answer-button:hover:not(:disabled){transform:none}}.interactive-image-content{display:flex;flex-direction:column;font-family:inherit;gap:1rem;padding:.75rem;width:100%}@media (min-width:768px){.interactive-image-content{gap:1.25rem;padding:1.25rem}}.main-text-display{background-color:initial;border:none;margin-bottom:.75rem;padding:.75rem 0;text-align:left}@media (min-width:768px){.main-text-display{margin-bottom:.9375rem;padding:.9375rem 0}}.main-text{color:#4a5568;font-family:inherit;font-size:.9375rem;font-weight:400;line-height:1.5;margin:0 0 .75rem}@media (min-width:768px){.main-text{font-size:1rem;margin:0 0 .625rem}}.main-audio-btn{background-color:#19a4a0;border:none;border-radius:6px;color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;min-height:44px;padding:.75rem 1rem;transition:background-color .3s}@media (min-width:768px){.main-audio-btn{font-size:.875rem;padding:.5rem 1rem}}.main-audio-btn:hover{background-color:#158e8a}.main-audio-btn:disabled{background-color:#6c757d;cursor:not-allowed}.image-container{display:flex;justify-content:center;margin:.75rem 0}@media (min-width:768px){.image-container{margin:1.25rem 0}}.interactive-image-wrapper{display:inline-block;max-width:100%;position:relative;width:auto}.interactive-image{border-radius:8px;box-shadow:0 4px 12px #00000026;display:block;height:auto;max-width:100%;width:100%}@media (min-width:768px){.interactive-image{max-width:600px}}@media (min-width:1024px){.interactive-image{max-width:800px}}.hotspot{cursor:pointer;position:absolute;transition:all .3s ease;z-index:15}.hotspot-indicator{align-items:center;animation:subtle-pulse 2s infinite;background-color:#007bff;border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #0000004d;color:#fff;display:flex;font-family:inherit;font-size:16px;font-weight:700;height:44px;justify-content:center;width:44px}@media (min-width:768px){.hotspot-indicator{font-size:14px;height:36px;width:36px}}@media (min-width:1024px){.hotspot-indicator{font-size:14px;height:30px;width:30px}}.hotspot.visited .hotspot-indicator{animation:none;background-color:#28a745}.hotspot.selected .hotspot-indicator{animation:none;background-color:#19a4a0;transform:scale(1.2)}.interactive-progress{background-color:#fff;border:1px solid #e9ecef;border-radius:8px;font-family:inherit;margin-top:1rem;padding:.9375rem}@media (min-width:768px){.interactive-progress{margin-top:1.25rem;padding:.9375rem}}.interactive-progress .progress-stats p{color:#333;font-family:inherit;font-weight:500;margin:0 0 .625rem;text-align:center}@media (min-width:768px){.interactive-progress .progress-stats p{margin:0 0 .625rem}}.interactive-progress .progress-bar{background-color:#e9ecef;border-radius:4px;height:8px;margin-bottom:.625rem;overflow:hidden;width:100%}@media (min-width:768px){.interactive-progress .progress-bar{margin-bottom:.625rem}}.interactive-progress .progress-fill{background-color:#28a745;height:100%;transition:width .5s ease}.interactive-progress .completion-message{background-color:#d4edda;border:1px solid #c3e6cb;border-radius:6px;color:#155724;font-family:inherit;font-weight:500;padding:.625rem;text-align:center}@media (min-width:768px){.interactive-progress .completion-message{padding:.625rem}}.speech-bubble{filter:drop-shadow(0 4px 12px rgba(0,0,0,.2));margin-top:-40px;max-width:320px;pointer-events:auto;position:absolute;width:90vw;z-index:25}@media (min-width:768px){.speech-bubble{margin-top:-60px;max-width:80vw;width:280px}}.speech-bubble-content:after{border-left:15px solid #0000;border-right:15px solid #0000;border-top:15px solid #fffffff2;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));z-index:26}.speech-bubble-content:after,.speech-bubble-content:before{content:"";height:0;left:50%;position:absolute;top:100%;transform:translateX(-50%);width:0}.speech-bubble-content:before{border-left:17px solid #0000;border-right:17px solid #0000;border-top:17px solid #19a4a0cc;z-index:25}.speech-bubble-close{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#f3f4f6e6;border:1px solid #d1d5db99;border-radius:50%;box-shadow:0 2px 8px #0000001a;color:#6b7280;cursor:pointer;display:flex;font-family:inherit;font-size:20px;font-weight:700;height:32px;justify-content:center;position:absolute;right:8px;top:6px;transition:all .3s ease;width:32px;z-index:30}@media (min-width:768px){.speech-bubble-close{font-size:18px;height:28px;width:28px}}.speech-bubble-close:hover{background:#ef4444e6;border-color:#ef4444cc;color:#fff;transform:scale(1.1)}.speech-bubble-content p{font-size:14px;line-height:1.5;margin:0 40px 12px 0}@media (min-width:768px){.speech-bubble-content p{font-size:15px;margin:0 32px 12px 0}}.speech-bubble-audio-btn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#19a4a0e6;border:1px solid #19a4a099;border-radius:8px;box-shadow:0 2px 8px #19a4a04d;color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;margin-top:10px;min-height:44px;padding:.75rem 1rem;transition:all .3s ease}@media (min-width:768px){.speech-bubble-audio-btn{font-size:14px;padding:8px 14px}}.speech-bubble-audio-btn:hover{background:#158e8af2;box-shadow:0 4px 12px #19a4a066;transform:translateY(-1px)}.speech-bubble-audio-btn:disabled{background:#9ca3afb3;box-shadow:none;cursor:not-allowed;transform:none}@keyframes subtle-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.15)}}@keyframes bubble-appear{0%{filter:blur(4px);opacity:0;transform:scale(.7) translateY(20px)}50%{opacity:.8;transform:scale(1.05) translateY(-5px)}to{filter:blur(0);opacity:1;transform:scale(1) translateY(0)}}.hotspot:focus{outline:2px solid #19a4a0;outline-offset:2px}@media (prefers-reduced-motion:reduce){.hotspot,.hotspot-indicator,.speech-bubble-content{animation:none;transition:none}@keyframes subtle-pulse{0%,to{opacity:1;transform:scale(1)}}}.order-content{font-family:inherit;margin:0 auto;max-width:600px;padding:1rem 0}.order-stem{color:#374151;font-family:inherit;font-size:1.125rem;font-weight:400;line-height:1.6;margin-bottom:2rem;text-align:left}.order-stem h1,.order-stem h2,.order-stem h3,.order-stem h4,.order-stem h5,.order-stem h6{color:#1f2937;font-family:inherit;font-weight:600;margin:1rem 0 .5rem}.order-stem h1{font-size:1.5rem}.order-stem h2{font-size:1.375rem}.order-stem h3{font-size:1.25rem}.order-stem h4{font-size:1.125rem}.order-stem h5{font-size:1rem}.order-stem h6{font-size:.875rem}.order-stem p{font-family:inherit;margin:.75rem 0}.order-stem b,.order-stem strong{font-family:inherit;font-weight:600}.order-stem em,.order-stem i{font-family:inherit;font-style:italic}.order-stem u{font-family:inherit;text-decoration:underline}.order-stem img{border-radius:6px;box-shadow:0 2px 8px #0000001a;height:auto;margin:1rem 0;max-width:100%}.order-instructions{background-color:#f0fdfa;border:1px solid #19a4a0;border-radius:8px;color:#065f46;font-size:.9375rem;font-style:italic;margin-bottom:1.5rem;padding:1rem}.order-items{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem;min-height:200px}.order-item{align-items:center;background-color:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:grab;display:flex;font-family:inherit;gap:1rem;padding:1rem 1.25rem;position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none}.order-item:hover{background-color:#f9fafb;border-color:#19a4a0;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.order-item.dragging,.order-item:active{box-shadow:0 4px 12px #00000026;cursor:grabbing;transform:rotate(2deg);z-index:10}.order-item.correct{background-color:#d1fae5;border-color:#10b981;color:#065f46}.order-item.incorrect{background-color:#fee2e2;border-color:#ef4444;color:#b91c1c}.order-item.locked{background-color:#f3f4f6;border-color:#d1d5db;cursor:not-allowed;opacity:.7}.drag-handle{border-radius:4px;cursor:grab;display:flex;flex-direction:column;flex-shrink:0;gap:2px;padding:.25rem;transition:background-color .2s ease}.drag-handle:hover{background-color:#19a4a01a}.drag-handle:after,.drag-handle:before{background-color:#9ca3af;border-radius:1px;content:"";height:2px;transition:background-color .2s ease;width:18px}.order-item:hover .drag-handle:after,.order-item:hover .drag-handle:before,.position-indicator{background-color:#19a4a0}.position-indicator{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;height:32px;justify-content:center;width:32px}.order-item.correct .position-indicator{background-color:#10b981}.order-item.incorrect .position-indicator{background-color:#ef4444}.order-item-content{color:#374151;flex:1 1;font-size:1rem;line-height:1.5}.drop-zone{background-color:#19a4a0;border-radius:2px;height:4px;margin:.25rem 0;opacity:0;transition:opacity .2s ease}.drop-zone.active{animation:pulse-drop 1s infinite;opacity:1}@keyframes pulse-drop{0%,to{opacity:1;transform:scaleY(1)}50%{opacity:.7;transform:scaleY(1.5)}}@media (max-width:640px){.order-content{max-width:100%;padding:.75rem 0}.order-stem{font-size:1rem;margin-bottom:1.5rem}.order-instructions{font-size:.875rem;padding:.875rem}.order-item{gap:.75rem;padding:.875rem 1rem}.order-item-content{font-size:.9375rem}.position-indicator{font-size:.8125rem;height:28px;width:28px}.check-answer-button{font-size:1rem;margin:1.5rem auto;padding:.875rem 1.5rem}.feedback-container{margin-top:1.5rem;padding:1.25rem}.feedback-header{font-size:1.125rem}}@media (max-width:480px){.order-item{flex-direction:column;gap:.5rem;padding:.75rem;text-align:center}.drag-handle,.position-indicator{align-self:center}}@media (hover:none) and (pointer:coarse){.drag-handle,.order-item{cursor:pointer}.order-item:hover{transform:none}.order-item:active{transform:scale(.98)}}.order-item:focus{outline:2px solid #19a4a0;outline-offset:2px}.order-item[tabindex]{position:relative}.order-item[tabindex]:focus:before{background:#1f2937;border-radius:4px;color:#fff;content:"Press Space to select, Arrow keys to move";font-size:.75rem;left:0;padding:.25rem .5rem;position:absolute;top:-2rem;white-space:nowrap;z-index:20}@media (prefers-reduced-motion:reduce){.check-answer-button,.drop-zone,.order-item{animation:none;transform:none!important;transition:none}.order-item.dragging,.order-item:active,.order-item:hover{transform:none!important}.check-answer-button:hover:not(:disabled){transform:none}}.matching-content{font-family:inherit;margin:0 auto;max-width:700px;padding:1rem 0}.matching-stem{color:#374151;font-family:inherit;font-size:1.125rem;font-weight:400;line-height:1.6;margin-bottom:2rem;text-align:left}.matching-stem h1,.matching-stem h2,.matching-stem h3,.matching-stem h4,.matching-stem h5,.matching-stem h6{color:#1f2937;font-family:inherit;font-weight:600;margin:1rem 0 .5rem}.matching-stem h1{font-size:1.5rem}.matching-stem h2{font-size:1.375rem}.matching-stem h3{font-size:1.25rem}.matching-stem h4{font-size:1.125rem}.matching-stem h5{font-size:1rem}.matching-stem h6{font-size:.875rem}.matching-stem p{font-family:inherit;margin:.75rem 0}.matching-stem b,.matching-stem strong{font-family:inherit;font-weight:600}.matching-stem em,.matching-stem i{font-family:inherit;font-style:italic}.matching-stem u{font-family:inherit;text-decoration:underline}.matching-stem img{border-radius:6px;box-shadow:0 2px 8px #0000001a;height:auto;margin:1rem 0;max-width:100%}.matching-instructions{background-color:#f0fdfa;border:1px solid #19a4a0;border-radius:8px;color:#065f46;font-size:.9375rem;font-style:italic;margin-bottom:1.5rem;padding:1rem}.matching-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.matching-left-column{display:flex;flex-direction:column;gap:1rem}.matching-column-header{background-color:#f0fdfa;border:2px solid #19a4a0;border-radius:8px;color:#19a4a0;font-size:1.125rem;font-weight:600;margin-bottom:.5rem;padding:.75rem;text-align:center}.matching-item{background-color:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;font-family:inherit;padding:1rem 1.25rem;position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none}.matching-item:hover:not(.matched){background-color:#f9fafb;border-color:#19a4a0;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.matching-item.selected{background-color:#f0fdfa;border-color:#19a4a0;box-shadow:0 2px 8px #19a4a026;transform:translateY(-1px)}.matching-item.matched{background-color:#d1fae5;border-color:#10b981;color:#065f46;cursor:default}.matching-item.incorrect{background-color:#fee2e2;border-color:#ef4444;color:#b91c1c;cursor:default}.matching-right-column{display:flex;flex-direction:column;gap:1rem}.matching-target{align-items:center;background-color:#f8fafc;border:2px dashed #d1d5db;border-radius:8px;display:flex;font-family:inherit;justify-content:center;min-height:60px;padding:1rem 1.25rem;position:relative;transition:all .2s ease}.matching-target.can-drop,.matching-target:hover{background-color:#f0fdfa;border-color:#19a4a0}.matching-target.can-drop{border-style:solid}.matching-target.occupied{background-color:#fff;border-color:#19a4a0;border-style:solid}.matching-target.correct{background-color:#d1fae5;border-color:#10b981}.matching-target.incorrect{background-color:#fee2e2;border-color:#ef4444}.matching-target-content{color:#6b7280;font-size:.9375rem;font-style:italic;text-align:center}.matching-target.occupied .matching-target-content{color:#374151;font-style:normal;font-weight:500}.matching-pair{align-items:center;background-color:#f8fafc;border-radius:6px;display:flex;gap:1rem;margin-bottom:.5rem;padding:.75rem}.matching-pair.correct{background-color:#d1fae5;border:1px solid #10b981}.matching-pair.incorrect{background-color:#fee2e2;border:1px solid #ef4444}.matching-pair-left,.matching-pair-right{flex:1 1;font-size:.9375rem}.matching-pair-arrow{color:#6b7280;font-weight:700}.matching-pair.correct .matching-pair-arrow{color:#10b981}.matching-pair.incorrect .matching-pair-arrow{color:#ef4444}.matching-connection{pointer-events:none;position:absolute;z-index:5}.matching-connection-line{stroke:#19a4a0;stroke-width:2;fill:none;opacity:.7}.matching-connection-line.correct{stroke:#10b981;opacity:1}.matching-connection-line.incorrect{stroke:#ef4444;opacity:1}.reset-matches-button{background-color:#6c757d;border:none;border-radius:8px;color:#fff;cursor:pointer;display:block;font-family:inherit;font-size:1rem;font-weight:600;margin:1rem auto;padding:.75rem 1.5rem;transition:all .2s ease}.reset-matches-button:hover:not(:disabled){background-color:#5a6268;box-shadow:0 2px 6px #6c757d4d;transform:translateY(-1px)}.reset-matches-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.check-answer-button{background:linear-gradient(135deg,#19a4a0,#158e8a);border:none;border-radius:12px;color:#fff;cursor:pointer;display:block;font-family:inherit;font-size:1.125rem;font-weight:600;margin:2rem auto;min-width:160px;padding:1rem 2rem;transition:all .2s ease}.check-answer-button:hover:not(:disabled){background:linear-gradient(135deg,#158e8a,#127c78);box-shadow:0 4px 12px #19a4a04d;transform:translateY(-2px)}.check-answer-button:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}.feedback-container{border:2px solid;border-radius:12px;font-family:inherit;margin-top:2rem;padding:1.5rem}.feedback-container.correct{background-color:#d1fae5;border-color:#10b981;color:#065f46}.feedback-container.incorrect{background-color:#fee2e2;border-color:#ef4444;color:#b91c1c}.feedback-header{font-family:inherit;font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.feedback-text{font-family:inherit;font-size:1rem;line-height:1.6}.general-feedback{border-top:1px solid #0000001a;font-family:inherit;font-style:italic;margin-top:1rem;padding-top:1rem}.matching-score{background-color:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;margin:1rem 0;padding:1rem;text-align:center}.score-text{color:#374151;font-size:1.125rem;font-weight:600}.score-correct{color:#10b981}.score-total{color:#6b7280}@media (max-width:768px){.matching-content{max-width:100%;padding:.75rem 0}.matching-stem{font-size:1rem;margin-bottom:1.5rem}.matching-instructions{font-size:.875rem;padding:.875rem}.matching-container{gap:1.5rem;grid-template-columns:1fr}.matching-column-header{font-size:1rem;padding:.625rem}.matching-item,.matching-target{font-size:.9375rem;padding:.875rem 1rem}.check-answer-button{font-size:1rem;margin:1.5rem auto;padding:.875rem 1.5rem}.feedback-container{margin-top:1.5rem;padding:1.25rem}.feedback-header{font-size:1.125rem}}@media (max-width:480px){.matching-item,.matching-target{font-size:.875rem;padding:.75rem}.matching-container{gap:1rem}.matching-pair{flex-direction:column;gap:.5rem;text-align:center}.matching-pair-arrow{transform:rotate(90deg)}}.check-answer-button:focus,.matching-item:focus,.matching-target:focus{outline:2px solid #19a4a0;outline-offset:2px}.matching-item[tabindex]{position:relative}.matching-item[tabindex]:focus:before{background:#1f2937;border-radius:4px;color:#fff;content:"Press Enter to select, Tab to navigate";font-size:.75rem;left:0;padding:.25rem .5rem;position:absolute;top:-2.5rem;white-space:nowrap;z-index:20}@media (prefers-reduced-motion:reduce){.check-answer-button,.matching-item,.matching-target,.reset-matches-button{transform:none!important;transition:none}.matching-item:hover:not(.matched),.matching-target:hover{transform:none!important}.check-answer-button:hover:not(:disabled){transform:none}}.flipcard-viewer{font-family:Segoe UI,system-ui,sans-serif;justify-content:center;min-height:auto;padding:20px 20px 40px}.card-wrapper,.flipcard-viewer{align-items:center;display:flex;flex-direction:column}.card-wrapper{gap:20px;max-width:400px;perspective:1000px;width:100%}.flipcard{-webkit-tap-highlight-color:transparent;border-radius:16px;box-shadow:0 12px 32px #00000026;cursor:pointer;height:480px;position:relative;transform-style:preserve-3d;transition:transform .7s ease-in-out;-webkit-user-select:none;user-select:none;width:320px}.flipcard:hover{box-shadow:0 16px 40px #0003}.flipcard:focus{outline:3px solid #19a4a0;outline-offset:4px}.flipcard.flipped{transform:rotateY(180deg)}.card-side{backface-visibility:hidden;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e9ecef;border-radius:16px;display:flex;flex-direction:column;height:100%;overflow:hidden;position:absolute;width:100%}.card-back{background:linear-gradient(135deg,#f8f9fa,#fff);transform:rotateY(180deg)}.card-content{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:16px;height:100%;justify-content:center;padding:10px;text-align:center}@media (max-width:480px){.card-content{gap:8px;padding:5px}}.card-image-container{align-items:center;display:flex;flex:1 1;justify-content:center;width:100%}.card-image{border-radius:12px;box-shadow:0 4px 12px #0000001a;max-height:100%;max-width:100%;object-fit:contain;transition:transform .3s ease}.flipcard:hover .card-image{transform:scale(1.02)}.card-text{word-wrap:break-word;color:#333;flex:1 1;font-size:18px;-webkit-hyphens:auto;hyphens:auto;justify-content:center;line-height:1.5}.card-text,.flip-hint{align-items:center;display:flex}.flip-hint{animation:pulse-hint 2s infinite;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000c;border-radius:20px;bottom:16px;color:#fff;font-size:14px;gap:6px;left:50%;padding:8px 16px;position:absolute;transform:translateX(-50%)}.flip-icon{animation:spin-hint 3s ease-in-out infinite;font-size:16px}@keyframes pulse-hint{0%,to{opacity:.8;transform:translateX(-50%) scale(1)}50%{opacity:1;transform:translateX(-50%) scale(1.05)}}@keyframes spin-hint{0%,to{transform:rotate(0deg)}25%{transform:rotate(90deg)}75%{transform:rotate(-90deg)}}.side-indicator{border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;position:absolute;right:12px;text-transform:uppercase;top:12px}.front-indicator{background:#007bff1a;border:1px solid #007bff4d;color:#007bff}.back-indicator{background:#dc35451a;border:1px solid #dc35454d;color:#dc3545}.progress-indicator{align-items:center;display:flex;gap:12px}.progress-dot{filter:grayscale(100%);font-size:20px;opacity:.3;transition:all .3s ease}.progress-dot.viewed{filter:grayscale(0);opacity:1;transform:scale(1.2)}.learning-actions{animation:slideUp .5s ease-out;background:#fff;border:2px solid #e9ecef;border-radius:16px;box-shadow:0 8px 24px #0000001a;max-width:350px;padding:20px;width:100%}.learning-prompt{color:#333;font-size:16px;font-weight:600;margin-bottom:16px;text-align:center}.action-buttons{display:flex;gap:12px}.action-btn{align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;flex:1 1;font-size:14px;font-weight:600;gap:6px;justify-content:center;padding:12px 16px;transition:all .3s ease}.learnt-btn{background:linear-gradient(135deg,#28a745,#20c997);box-shadow:0 4px 12px #28a7454d;color:#fff}.learnt-btn:hover{box-shadow:0 6px 16px #28a74566;transform:translateY(-2px)}.dunno-btn{background:linear-gradient(135deg,#ffc107,#fd7e14);box-shadow:0 4px 12px #ffc1074d;color:#333}.dunno-btn:hover{box-shadow:0 6px 16px #ffc10766;transform:translateY(-2px)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.flipcard-viewer{min-height:auto;padding:16px}.flipcard{height:min(480px,70vh);width:min(320px,90vw)}.card-content{gap:12px;padding:10px}.card-text{font-size:16px;line-height:1.4}.card-image{max-height:160px}.flip-hint{bottom:12px;font-size:13px;padding:6px 12px}.learning-actions{max-width:95vw;padding:16px}.action-buttons{flex-direction:column;gap:10px}.action-btn{font-size:15px;padding:14px}}@media (prefers-reduced-motion:reduce){.flipcard{transition:transform .3s ease}.flip-hint,.flip-icon{animation:none}}.lrc-container{background-color:#fff;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;margin:0 auto;max-width:2xl;padding:1.5rem}.lrc-section{border:2px solid;border-radius:.75rem;margin-bottom:2rem;padding:1.5rem;position:relative}.lrc-section h3{align-items:center;display:flex;font-size:1.125rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.lrc-section.listen{background:linear-gradient(135deg,#f0fdfa,#ccfbf1);border-color:#19a4a0}.lrc-section.listen h3{color:#19a4a0}.lrc-section.practice{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#e8a327}.lrc-section.practice h3{color:#d97706}.lrc-section.learn{background:linear-gradient(135deg,#fef2f2,#fecaca);border-color:#ff4747}.lrc-section.learn h3{color:#dc2626}.lrc-question-text{color:#374151;font-size:1.125rem;margin-bottom:1rem;text-align:center}.lrc-question-image{border-radius:.5rem;box-shadow:0 4px 6px -1px #0000001a;display:block;height:12rem;margin:0 auto 1rem;max-width:100%;object-fit:cover}.lrc-instructions{color:#6b7280;font-style:italic;margin-bottom:1.5rem;text-align:center}.lrc-audio-container{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#ffffff80;border-radius:.5rem;display:flex;flex-direction:column;gap:.75rem;padding:1rem}.lrc-audio-label{color:#4b5563;margin:0}.lrc-audio-label,.lrc-button{font-size:.875rem;font-weight:600}.lrc-button{align-items:center;background-image:none;border:none;border-radius:.5rem;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:inline-flex;font-family:inherit;gap:.5rem;justify-content:center;min-width:7.5rem;padding:.75rem 1.25rem;text-decoration:none;text-shadow:none;transition:all .2s ease}.lrc-button:hover:not(:disabled){box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.lrc-button:disabled{background-color:#9ca3af!important;color:#fff!important;cursor:not-allowed;opacity:.6;transform:none}.lrc-button.record{background-color:#ff4747;color:#fff}.lrc-button.record:hover:not(:disabled){background-color:#f33}.lrc-button.stop{animation:pulse 2s infinite;background-color:#e63946;color:#fff}.lrc-button.stop:hover{background-color:#d62828}.lrc-button.reset{background-color:#6c757d;color:#fff}.lrc-button.reset:hover:not(:disabled){background-color:#5a6268}.lrc-button.play-user{background-color:#19a4a0;color:#fff}.lrc-button.play-user:hover:not(:disabled){background-color:#158e8a}.lrc-button.audio-play{background-color:#19a4a0;color:#fff}.lrc-button.audio-play:hover:not(:disabled){background-color:#158e8a}.lrc-button.audio-pause{background-color:#e8a327;color:#fff}.lrc-button.audio-pause:hover:not(:disabled){background-color:#d39425}.lrc-button.audio-loading{background-color:#6c757d;color:#fff;cursor:not-allowed}.lrc-button.audio-error{background-color:#ff4747;color:#fff}.lrc-recording-controls{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-bottom:1rem}.lrc-recording-status{margin:1rem 0;text-align:center}.lrc-recording-note{color:#6b7280;font-size:.875rem;font-style:italic;margin-top:.5rem;text-align:center}.lrc-feedback{margin-top:2rem;text-align:center}.lrc-feedback-buttons{display:flex;gap:.75rem;justify-content:center;margin-top:1rem}.lrc-feedback-button{align-items:center;background-image:none;border:none;border-radius:.5rem;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.25rem;text-decoration:none;text-shadow:none;transition:all .2s ease}.lrc-feedback-button.know-this{background-color:#19a4a0;color:#fff}.lrc-feedback-button.know-this:hover{background-color:#158e8a;box-shadow:0 4px 8px #19a4a04d;transform:translateY(-1px)}.lrc-feedback-button.still-learning{background-color:#e8a327;color:#fff}.lrc-feedback-button.still-learning:hover{background-color:#d39425;box-shadow:0 4px 8px #e8a3274d;transform:translateY(-1px)}.lrc-status-message{border-radius:.5rem;font-family:inherit;font-size:.875rem;font-weight:600;margin-top:1rem;padding:.75rem 1.25rem;text-align:center}.lrc-status-message.completed{background-color:#19a4a0;color:#fff}.lrc-status-message.still-learning{background-color:#e8a327;color:#fff}.lrc-error{background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#ef4444;margin:1rem 0;padding:1.5rem;text-align:center}.lrc-no-content{color:#6b7280;font-style:italic;padding:2rem;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.lrc-container{animation:fadeIn .3s ease-out}@media (max-width:768px){.lrc-container{margin:.5rem;padding:1rem}.lrc-section{margin-bottom:1.5rem;padding:1rem}.lrc-question-text,.lrc-section h3{font-size:1rem}.lrc-feedback-buttons,.lrc-recording-controls{align-items:center;flex-direction:column}.lrc-feedback-buttons{gap:.5rem}.lrc-feedback-button{width:12rem}}@media (max-width:480px){.lrc-container{margin:.25rem;padding:.75rem}.lrc-section{padding:.75rem}.lrc-section h3{font-size:.875rem}.lrc-button,.lrc-feedback-button{font-size:.8125rem;min-width:6rem;padding:.625rem 1rem}}.story-editor{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000000d;display:flex;flex-direction:column;margin:0 auto;padding:25px;width:100%}.story-editor .status-message{align-items:center;animation:pulse 2s infinite;background-color:#e3f2fd;border-left:4px solid #2196f3;border-radius:4px;color:#0d47a1;display:flex;font-weight:500;justify-content:center;margin-bottom:20px;padding:12px 16px}@keyframes pulse{0%{opacity:.8}50%{opacity:1}to{opacity:.8}}.story-editor .title-container{margin-bottom:20px;position:relative}.story-editor .title-container label{color:#2e7d32;display:block;font-size:16px;font-weight:600;letter-spacing:.5px;margin-bottom:10px}.story-editor .title-container input{background-color:#f9f9f9;border:2px solid #e0e0e0;border-radius:6px;box-shadow:inset 0 1px 3px #0000000d;color:#333;font-size:18px;font-weight:500;padding:14px 16px;transition:all .3s ease;width:100%}.story-editor .title-container input:focus{background-color:#fff;border-color:#4caf50;box-shadow:0 0 0 3px #4caf5033;outline:none}.story-editor .title-container input:hover:not(:focus):not(:disabled){border-color:#9e9e9e}.story-editor .title-container input:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.7}.story-editor .editor-mode-toggle{border-bottom:1px solid #e0e0e0;margin-bottom:20px;padding:15px 0}.story-editor .mode-toggle-container{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.story-editor .mode-toggle-label{color:#2e7d32;font-size:14px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.story-editor .mode-toggle-buttons{background-color:#f9f9f9;border:2px solid #e0e0e0;border-radius:6px;display:flex;overflow:hidden}.story-editor .mode-toggle-button{align-items:center;background-color:initial;border:none;border-right:1px solid #e0e0e0;color:#666;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .3s ease}.story-editor .mode-toggle-button:last-child{border-right:none}.story-editor .mode-toggle-button.active{background-color:#4caf50;color:#fff;font-weight:600}.story-editor .mode-toggle-button:hover:not(.active){background-color:#f0f0f0;color:#333}.story-editor .mode-description{background-color:#f3f9f9;border:1px solid #19a4a0;border-radius:6px;color:#2e7d32;font-size:13px;font-style:italic;margin-left:20px;padding:10px 15px}.story-editor .pages-navigation{background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;display:flex;flex-direction:column;gap:10px;margin-bottom:20px;padding:15px}.story-editor .page-tabs{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.story-editor .page-actions{align-items:center;border-top:1px solid #e0e0e0;display:flex!important;gap:8px;justify-content:flex-end;margin-top:10px;padding:8px 0}.story-editor .page-tab{background-color:#fff;border:2px solid #e0e0e0;border-radius:6px;color:#666;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .3s ease}.story-editor .page-tab.active{background-color:#4caf50;border-color:#4caf50;color:#fff;font-weight:600}.story-editor .page-tab:hover:not(.active){background-color:#f3f9f9;border-color:#19a4a0;color:#19a4a0}.story-editor .add-page-button{align-items:center;background-color:initial;border:2px dashed #19a4a0;border-radius:6px;color:#19a4a0;cursor:pointer;display:flex;font-size:18px;font-weight:700;justify-content:center;min-width:40px;padding:8px 12px;transition:all .3s ease}.story-editor .add-page-button:hover{background-color:#19a4a0;color:#fff}.story-editor .page-action-button{align-items:center;background-color:#fff;border:2px solid #e0e0e0;border-radius:6px;color:#666;cursor:pointer;display:inline-flex!important;font-size:14px;font-weight:500;height:36px;justify-content:center;min-width:40px;padding:8px 12px;transition:all .3s ease}.story-editor .page-action-button:hover:not(:disabled){background-color:#f3f9f9;border-color:#19a4a0;color:#19a4a0;transform:translateY(-1px)}.story-editor .page-action-button:disabled{background-color:#f8f8f8;border-color:#f0f0f0;color:#ccc;cursor:not-allowed;opacity:.5}.story-editor .page-action-button.delete-button{background-color:#fff5f5;border-color:#f44336;color:#f44336}.story-editor .page-action-button.delete-button:hover:not(:disabled){background-color:#f44336;border-color:#d32f2f;color:#fff;transform:translateY(-1px)}.story-editor .page-action-button.delete-button:disabled{background-color:#f8f8f8;border-color:#ffcdd2;color:#ffcdd2}.story-editor .page-action-button[title]:after{background:#333;border-radius:3px;bottom:-25px;color:#fff;content:attr(title);font-size:11px;left:50%;opacity:0;padding:2px 6px;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .2s;white-space:nowrap;z-index:1000}.story-editor .page-action-button:hover:after{opacity:1}.story-editor .html-editor-container{background-color:#fff;border:2px solid #e0e0e0;border-radius:6px;overflow:hidden}.story-editor .html-editor-content{display:flex;min-height:450px}.story-editor .html-editor-textarea{background-color:#fafafa;border:none;color:#333;flex:1 1;font-family:Courier New,monospace;font-size:14px;line-height:1.5;outline:none;padding:15px;resize:none}.story-editor .html-editor-preview{background-color:#fff;border-left:1px solid #e0e0e0;flex:1 1;overflow:auto;padding:15px}.story-editor .quill{display:flex;flex-direction:column;height:450px}.story-editor .ql-toolbar.ql-snow{background-color:#f8f8f8;border:1px solid #ccc;border-top-left-radius:4px;border-top-right-radius:4px;box-shadow:0 1px 3px #0000000d;display:flex!important;flex-wrap:wrap;padding:8px}.story-editor .ql-container.ql-snow{border:1px solid #ccc;border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-top:0;flex:1 1;overflow:auto}.story-editor .ql-editor{font-size:16px;line-height:1.5;min-height:100%}.story-editor .callouts-section h3:before{content:"💬";font-size:18px}.story-editor .no-callouts-message{color:#666;font-style:italic;padding:20px;text-align:center}.story-editor .callouts-list{display:flex;flex-direction:column;gap:15px}.story-editor .page-callouts h4{border-bottom:1px solid #e0e0e0;color:#19a4a0;font-size:14px;font-weight:600;margin:0 0 10px;padding-bottom:5px}.story-editor .callout-item{background:#fff;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:8px;padding:12px}.story-editor .callout-text{color:#333;font-style:italic;font-weight:600;margin-bottom:5px}.story-editor .callout-content{color:#666;font-size:14px;margin-bottom:8px}.story-editor .remove-callout-btn{background-color:#f44336;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:12px;padding:4px 8px;transition:all .2s ease}.story-editor .remove-callout-btn:hover:not(:disabled){background-color:#d32f2f}.story-editor .remove-callout-btn:disabled{cursor:not-allowed;opacity:.5}.story-editor .save-button{align-items:center;background:linear-gradient(135deg,#4caf50,#2e7d32);border:none;border-radius:4px;box-shadow:0 2px 6px #0003;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;letter-spacing:.5px;min-width:150px;padding:12px 24px;text-transform:uppercase;transition:all .3s ease}.story-editor .save-button:hover{background:linear-gradient(135deg,#43a047,#255d28);box-shadow:0 4px 8px #0000004d;transform:translateY(-2px)}.story-editor .save-button:disabled{background:linear-gradient(135deg,#9e9e9e,#757575);box-shadow:none;cursor:not-allowed;opacity:.7;transform:none}.story-editor .save-spinner{animation:spin 1s ease-in-out infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:18px;width:18px}@keyframes spin{to{transform:rotate(1turn)}}.story-editor .action-buttons{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;margin-top:25px;padding:10px 0}.story-editor .modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.story-editor .modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden}.story-viewer{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;margin:0 auto;max-width:800px;padding:20px}.story-error,.story-loading{font-size:18px;padding:40px 20px;text-align:center}.story-error{color:#d32f2f}.story-content{background:#fff;border-radius:5px;box-shadow:0 2px 4px #0000000d;color:#374151;font-size:1.1rem;line-height:1.7;margin:0 auto;max-width:700px;padding:2rem 1rem}.story-content h1,.story-content h2,.story-content h3,.story-content h4,.story-content h5,.story-content h6{color:#1f2937;font-weight:600;margin-bottom:1rem;margin-top:2rem}.story-content h1{border-bottom:2px solid #e5e7eb;font-size:2rem;padding-bottom:1rem;text-align:center}.story-content h2{font-size:1.5rem}.story-content h3{font-size:1.25rem}.story-content p{margin-bottom:1.5rem;text-align:justify}.story-content blockquote{background-color:#f8fafc;border-left:4px solid #3b82f6;border-radius:0 8px 8px 0;color:#4b5563;font-style:italic;margin:2rem 0;padding:1rem 1.5rem}.story-content img{border-radius:8px;box-shadow:0 4px 12px #0000001a;display:block;height:auto;margin:1.5rem auto;max-width:100%}.story-content audio{border-radius:8px;margin:1.5rem 0;width:100%}.story-content ol,.story-content ul{margin-bottom:16px;padding-left:24px}.story-content li{margin-bottom:8px}.story-content table{border-collapse:collapse;margin:15px 0;width:100%}.story-content td,.story-content th{background-color:#f5f5f5;border:1px solid #ddd;padding:8px}.speech-bubble-content{animation:bubble-appear .4s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #19a4a0cc;border-radius:16px;box-shadow:0 8px 32px #0000001f;font-family:inherit;max-height:200px;overflow-y:auto;padding:16px;position:relative}.speech-bubble-content p{color:#1f2937;font-family:inherit;font-weight:500;margin:0 32px 12px 0;text-align:center!important;text-shadow:0 1px 2px #fffc}.story-unit-manager{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;display:flex;height:calc(100vh - 120px);overflow:hidden}.units-sidebar{background-color:#f9f9f9;border-right:1px solid #eee;display:flex;flex-direction:column;width:300px}.units-header{border-bottom:1px solid #eee;padding:16px}.units-header h2{color:#333;font-size:18px;margin:0 0 16px}.create-unit-form{display:flex;gap:8px}.create-unit-form input{border:1px solid #ddd;border-radius:4px;flex:1 1;font-size:14px;padding:8px}.create-unit-form button{background-color:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 12px}.empty-units{color:#666;padding:20px;text-align:center}.units-list{flex-grow:1;list-style:none;margin:0;overflow-y:auto;padding:0}.units-list li{align-items:center;border-bottom:1px solid #eee;cursor:pointer;display:flex;justify-content:space-between;padding:12px 16px}.units-list li:hover{background-color:#f0f0f0}.units-list li.active{background-color:#e3f2fd;border-left:4px solid #2196f3;padding-left:12px}.unit-title{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.delete-unit-button{background:none;border:none;cursor:pointer;font-size:16px;opacity:.5;transition:opacity .2s}.delete-unit-button:hover{opacity:1}.unit-content{flex:1 1;overflow-y:auto}.unit-container,.unit-content{display:flex;flex-direction:column}.unit-container{height:100%}.unit-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:16px 24px}.unit-header h1{color:#333;font-size:24px;margin:0}.unit-actions button{background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;padding:8px 16px}.unit-actions button:hover{background-color:#e0e0e0}.unit-body{flex:1 1;overflow-y:auto;padding:20px 24px}.callout-tooltip{word-wrap:break-word;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#fffffff2;border:1px solid #ccc;border-radius:8px;box-shadow:0 4px 12px #00000026;max-width:300px;min-width:120px;padding:12px;text-align:center;z-index:1000}.callout-tooltip:after{border-left:6px solid #0000;border-right:6px solid #0000;border-top:6px solid #fff;bottom:-6px;content:"";height:0;left:50%;position:absolute;transform:translateX(-50%);width:0}.callout-with-image.horizontal{align-items:center;flex-direction:row;gap:10px;justify-content:center;text-align:left}.callout-tooltip img{border-radius:6px;display:block;height:auto;margin:0 auto;max-height:80px;max-width:80px;object-fit:cover;width:auto}.callout-with-image.horizontal img{flex-shrink:0;margin:0}.callout-content{gap:8px;line-height:1.4}.callout-content,.callout-html-content{align-items:center;display:flex;flex-direction:column;text-align:center}.callout-html-content{width:100%}.loading-indicator{background:#e3f2fd;color:#1565c0;text-align:center}.error-message,.loading-indicator{border-radius:4px;margin-bottom:15px;padding:10px}.error-message{background-color:#ffebee;color:#d32f2f}.loading,.no-selection,.no-unit-selected,.no-units-message{align-items:center;color:#757575;display:flex;font-style:italic;height:300px;justify-content:center}@media (max-width:768px){.story-editor{padding:15px}.story-editor .mode-toggle-container{align-items:flex-start;flex-direction:column;gap:10px}.story-editor .mode-description{margin-left:0;margin-top:10px}.story-editor .html-editor-content{flex-direction:column}.story-editor .ql-toolbar.ql-snow .ql-audio,.story-editor .ql-toolbar.ql-snow .ql-callout{align-items:center;background-color:#fff;border:1px solid #ccc;border-radius:3px;cursor:pointer;display:inline-flex;height:28px;justify-content:center;padding:0;position:relative;width:28px}.story-editor .ql-toolbar.ql-snow .ql-audio:before{content:"🔊";font-size:16px;left:50%;line-height:1;position:absolute;top:50%;transform:translate(-50%,-50%)}.story-editor .ql-toolbar.ql-snow .ql-audio:hover,.story-editor .ql-toolbar.ql-snow .ql-callout:hover{background-color:#f0f0f0;border-color:#ccc}.story-editor .ql-toolbar.ql-snow .ql-audio.ql-active,.story-editor .ql-toolbar.ql-snow .ql-callout.ql-active{background-color:#e6e6e6;border-color:#999;color:#06c}.story-editor .ql-toolbar.ql-snow .ql-formats .ql-background,.story-editor .ql-toolbar.ql-snow .ql-formats .ql-bold,.story-editor .ql-toolbar.ql-snow .ql-formats .ql-clean,.story-editor .ql-toolbar.ql-snow .ql-formats .ql-color,.story-editor .ql-toolbar.ql-snow .ql-formats .ql-header,.story-editor .ql-toolbar.ql-snow .ql-formats .ql-image,.story-editor .ql-toolbar.ql-snow .ql-formats .ql-italic,.story-editor .ql-toolbar.ql-snow .ql-formats .ql-link,.story-editor .ql-toolbar.ql-snow .ql-formats .ql-list,.story-editor .ql-toolbar.ql-snow .ql-formats .ql-script,.story-editor .ql-toolbar.ql-snow .ql-formats .ql-strike,.story-editor .ql-toolbar.ql-snow .ql-formats .ql-underline{align-items:center;background-color:#fff;border:1px solid #ddd;border-radius:3px;display:inline-flex;height:28px;justify-content:center;margin:0 2px;padding:0;width:28px}.story-editor .ql-toolbar.ql-snow .ql-header:after{content:"H";font-size:14px;font-weight:700}.story-editor .ql-toolbar.ql-snow .ql-bold:after{content:"B";font-size:14px;font-weight:700}.story-editor .ql-toolbar.ql-snow .ql-italic:after{content:"I";font-size:14px;font-style:italic}.story-editor .ql-toolbar.ql-snow .ql-underline:after{content:"U";font-size:14px;text-decoration:underline}.story-editor .ql-toolbar.ql-snow .ql-strike:after{content:"S";font-size:14px;text-decoration:line-through}.story-editor .ql-toolbar.ql-snow .ql-list[value=ordered]:after{content:"1.";font-size:12px}.story-editor .ql-toolbar.ql-snow .ql-list[value=bullet]:after{content:"•";font-size:16px}.story-editor .ql-toolbar.ql-snow .ql-script[value=sub]:after{content:"x₂";font-size:12px}.story-editor .ql-toolbar.ql-snow .ql-script[value=super]:after{content:"x²";font-size:12px}.story-editor .ql-toolbar.ql-snow .ql-color:after{color:#e60000;content:"A";font-size:14px;font-weight:700}.story-editor .ql-toolbar.ql-snow .ql-background:after{content:"⬛";font-size:14px}.story-editor .ql-toolbar.ql-snow .ql-link:after{content:"🔗";font-size:14px}.story-editor .ql-toolbar.ql-snow .ql-image:after{content:"🖼️";font-size:14px}.story-editor .ql-toolbar.ql-snow .ql-clean:after{content:"🧹";font-size:14px}.story-editor .ql-toolbar.ql-snow button svg{display:block;height:18px;width:18px}.story-editor .ql-toolbar.ql-snow button:not(.ql-audio):not(.ql-callout){position:relative}.story-editor .ql-toolbar.ql-snow button svg+:after{display:none}.story-editor .ql-toolbar.ql-snow .ql-formats{margin-bottom:5px;margin-right:15px}.story-editor .ql-toolbar.ql-snow .ql-picker{color:#444;font-size:14px;font-weight:500;position:relative}.story-editor .ql-toolbar.ql-snow .ql-picker-label{align-items:center;background-color:#fff;border:1px solid #ddd;border-radius:3px;cursor:pointer;display:flex;height:28px;min-width:60px;padding:0 8px}.story-editor .ql-toolbar.ql-snow .ql-picker-label:hover{background-color:#f0f0f0;border-color:#ccc}.story-editor .ql-toolbar.ql-snow .ql-background .ql-picker-label,.story-editor .ql-toolbar.ql-snow .ql-color-picker .ql-picker-label{justify-content:center;padding:0;width:28px}@media (max-width:768px){.story-editor .ql-toolbar.ql-snow{padding:6px}.story-editor .ql-toolbar.ql-snow .ql-formats{margin-bottom:8px;margin-right:10px}.story-editor .ql-toolbar.ql-snow button{height:32px;width:32px}.story-editor .pages-navigation{padding:10px}.story-editor .page-actions{flex-wrap:wrap;gap:6px;justify-content:center}.story-editor .page-action-button{font-size:12px;height:32px;min-width:36px;padding:6px 10px}}.story-editor .ql-editor p{margin-bottom:.5em!important}.story-editor .ql-editor p:last-child{margin-bottom:0!important}.story-editor .ql-editor br+br+br,.story-editor .ql-editor p:empty{display:none!important}.page-tab.empty-page{background-color:#fff3cd;border-color:#ffeaa7;color:#856404;font-style:italic}.page-tab.empty-page:hover{background-color:#ffeaa7}.page-tab.empty-page.active{background-color:#fd7e14;border-color:#fd7e14;color:#fff}.empty-indicator{color:#dc3545;font-size:12px;font-weight:700;margin-left:5px}.page-tab.empty-page.active .empty-indicator{color:#ffeb3b}table td img{display:block!important;height:auto!important;margin:5px 0!important;max-width:100%!important;min-width:200px!important;object-fit:none!important;width:auto!important}.story-editor .ql-table{border:1px solid #ddd!important;border-collapse:collapse!important;margin:10px 0!important;width:100%!important}.story-editor .ql-table td{border:1px solid #ddd!important;min-width:100px!important;padding:8px!important;position:relative!important;vertical-align:top!important}.story-editor .ql-table td:hover{background-color:#f5f5f5!important}.ql-table-menu{background:#fff!important;border:1px solid #ccc!important;border-radius:4px!important;box-shadow:0 2px 8px #0000001a!important;min-width:150px!important;overflow:hidden!important;position:absolute!important;z-index:1000!important}.ql-table-menu div{background:#fff!important;border-bottom:1px solid #eee!important;color:#333!important;cursor:pointer!important;font-size:14px!important;padding:8px 12px!important;transition:background-color .2s ease!important}.ql-table-menu div:hover{background-color:#f0f0f0!important;color:#000!important}.ql-table-menu div:last-child{border-bottom:none!important}.story-editor .ql-toolbar .ql-table{align-items:center!important;background-color:#fff!important;border:1px solid #ccc!important;border-radius:3px!important;cursor:pointer!important;display:inline-flex!important;height:28px!important;justify-content:center!important;padding:0!important;position:relative!important;width:28px!important}.story-editor .ql-toolbar .ql-table:before{color:#444!important;content:"⊞"!important;font-size:16px!important;font-weight:700!important;left:50%!important;line-height:1!important;position:absolute!important;top:50%!important;transform:translate(-50%,-50%)!important}.story-editor .ql-toolbar .ql-table:hover{background-color:#f0f0f0!important;border-color:#999!important}.story-editor .ql-toolbar .ql-table:hover:before{color:#000!important}.story-content .ql-table,.story-viewer .ql-table{border:1px solid #ddd!important;border-collapse:collapse!important;margin:15px 0!important;width:100%!important}.story-content .ql-table td,.story-viewer .ql-table td{border:1px solid #ddd!important;padding:8px!important;vertical-align:top!important}.story-content .ql-table th,.story-viewer .ql-table th{background-color:#f5f5f5!important;border:1px solid #ddd!important;font-weight:700!important;padding:8px!important}.story-content .ql-table td img,.story-editor .ql-table td img,.story-viewer .ql-table td img{display:block!important;height:auto!important;margin:5px auto!important;max-width:100%!important;width:auto!important}@media (max-width:768px){.story-content .ql-table,.story-editor .ql-table,.story-viewer .ql-table{font-size:14px!important}.story-content .ql-table td,.story-editor .ql-table td,.story-viewer .ql-table td{min-width:80px!important;padding:6px!important}}.has-callout{background-color:#19a4a026!important;border-bottom:2px dotted #19a4a0!important;border-radius:4px!important;color:#157a77!important;cursor:help!important;display:inline!important;font-family:inherit!important;font-weight:500!important;padding:2px 6px!important;position:relative!important;text-decoration:none!important;transition:all .2s ease!important}.has-callout:hover{background-color:#19a4a040!important;border-bottom-style:solid!important;color:#0f5d5a!important;transform:translateY(-1px)!important}.callout-with-image{align-items:center!important;display:flex!important;flex-direction:column!important;gap:8px!important;justify-content:center!important}.callout-with-image,.callout-with-image span{text-align:center!important;width:100%!important}.callout-with-image span{color:inherit!important;display:block!important;font-size:inherit!important;line-height:inherit!important}.callout-with-image img{border-radius:6px!important;display:block!important;flex-shrink:0!important;height:auto!important;margin:0 auto!important;max-height:80px!important;max-width:80px!important;object-fit:cover!important;width:auto!important}.callout-html-content{align-items:center!important;color:inherit!important;display:flex!important;flex-direction:column!important;font-size:inherit!important;line-height:inherit!important;text-align:center!important;width:100%!important}@keyframes callout-appear{0%{opacity:0!important;transform:translateY(-10px) scale(.9)!important}to{opacity:1!important;transform:translateY(-5px) scale(1)!important}}.story-editor .callouts-section{background-color:#f8f9fa!important;border:1px solid #e0e0e0!important;border-radius:6px!important;margin-top:30px!important;padding:20px!important}.story-editor .callouts-section h3{align-items:center!important;color:#2e7d32!important;display:flex!important;font-size:16px!important;font-weight:600!important;gap:8px!important;margin:0 0 15px!important}.story-editor .callouts-section h3:before{content:"💬"!important;font-size:18px!important}.story-editor .no-callouts-message{color:#666!important;font-style:italic!important;padding:20px!important;text-align:center!important}.story-editor .callouts-list{display:flex!important;flex-direction:column!important;gap:15px!important}.story-editor .page-callouts h4{border-bottom:1px solid #e0e0e0!important;color:#19a4a0!important;font-size:14px!important;font-weight:600!important;margin:0 0 10px!important;padding-bottom:5px!important}.story-editor .callout-item{background:#fff!important;border:1px solid #e0e0e0!important;border-radius:6px!important;margin-bottom:8px!important;padding:12px!important}.story-editor .callout-text{color:#333!important;font-style:italic!important;font-weight:600!important;margin-bottom:5px!important}.story-editor .callout-content{color:#666!important;font-size:14px!important;margin-bottom:8px!important;text-align:center!important}.story-editor .remove-callout-btn{background-color:#f44336!important;border:none!important;border-radius:3px!important;color:#fff!important;cursor:pointer!important;font-size:12px!important;padding:4px 8px!important;transition:all .2s ease!important}.story-editor .remove-callout-btn:hover:not(:disabled){background-color:#d32f2f!important}.story-editor .remove-callout-btn:disabled{cursor:not-allowed!important;opacity:.5!important}.callout-text[data-callout],.has-callout[data-callout]{position:relative!important}.has-callout:hover .callout-tooltip,.story-tooltip:hover .story-tooltip-popup{display:block!important;opacity:1!important;pointer-events:auto!important}.callout-tooltip:not(.speech-bubble),.story-tooltip-popup:not(.speech-bubble){background:#fffffffa!important;border:2px solid #19a4a0!important;color:#1f2937!important}.speech-bubble{background:#fffffff2!important;border:2px solid #19a4a0cc!important}.callout-text:focus,.has-callout:focus{outline:2px solid #19a4a0!important;outline-offset:2px!important}@media (prefers-reduced-motion:reduce){.callout-text,.has-callout,.story-tooltip-popup{animation:none!important;transform:none!important;transition:none!important}}@media print{.story-tooltip-popup{display:none!important}.callout-text:after,.has-callout:after,.story-tooltip:after{color:#666!important;content:" [" attr(data-callout) "]"!important;font-size:.8em!important}}}.story-content .callout-text,.story-content .has-callout,.story-content .story-tooltip{background-color:#e8a32733!important;border-bottom:2px dotted #e8a327!important;border-radius:4px!important;color:#b8732a!important;cursor:help!important;display:inline!important;font-family:inherit!important;font-weight:500!important;padding:2px 6px!important;position:relative!important;text-decoration:none!important;transition:all .2s ease!important}.story-content .callout-text:hover,.story-content .has-callout:hover,.story-content .story-tooltip:hover{background-color:#e8a3274d!important;border-bottom-style:solid!important;box-shadow:0 2px 4px #e8a3274d!important;color:#a06424!important;transform:translateY(-1px)!important}.callout-tooltip,.story-tooltip-popup{word-wrap:break-word!important;animation:callout-appear .3s ease-out!important;background:#19a4a0!important;border:2px solid #157a77!important;border-radius:8px!important;box-shadow:0 8px 24px #19a4a066!important;color:#fff!important;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif!important;font-size:16px!important;font-weight:400!important;line-height:1.5!important;max-width:300px!important;min-width:150px!important;opacity:1!important;padding:12px 16px!important;pointer-events:auto!important;position:fixed!important;text-align:center!important;z-index:1000!important}.story-content .callout-tooltip:after,.story-content .story-tooltip-popup:after{border-left:10px solid #0000!important;border-right:10px solid #0000!important;border-top:10px solid #19a4a0!important;content:""!important;filter:drop-shadow(0 2px 4px rgba(25,164,160,.3))!important;height:0!important;left:50%!important;position:absolute!important;top:100%!important;transform:translateX(-50%)!important;width:0!important}.story-content .callout-tooltip.below:after,.story-content .story-tooltip-popup.below:after{border-bottom:10px solid #19a4a0!important;border-top:none!important;top:-10px!important}.story-content .callout-tooltip span,.story-content .story-tooltip-popup span{color:#fff!important;display:block!important;font-size:inherit!important;font-weight:400!important;line-height:1.4!important;text-align:center!important;width:100%!important}.story-content .callout-with-image{align-items:center!important;display:flex!important;flex-direction:column!important;gap:8px!important;justify-content:center!important;text-align:center!important;width:100%!important}.story-content .callout-with-image span{color:#fff!important;display:block!important;font-size:inherit!important;line-height:inherit!important;margin-top:6px!important;text-align:center!important;width:100%!important}.story-content .callout-tooltip img,.story-content .callout-with-image img,.story-content .story-tooltip-popup img{border:2px solid #fff3!important;border-radius:6px!important;display:block!important;flex-shrink:0!important;height:auto!important;margin:0 auto!important;max-height:80px!important;max-width:80px!important;object-fit:cover!important;width:auto!important}.story-content .callout-html-content{align-items:center!important;color:#fff!important;display:flex!important;flex-direction:column!important;font-size:inherit!important;line-height:inherit!important;text-align:center!important;width:100%!important}@keyframes callout-appear{0%{filter:blur(2px)!important;opacity:0!important;transform:translateY(-10px) scale(.9)!important}to{filter:blur(0)!important;opacity:1!important;transform:translateY(0) scale(1)!important}}.story-editor .callouts-section{background-color:#f8f9fa!important;border:1px solid #e0e0e0!important;border-radius:6px!important;margin-top:30px!important;padding:20px!important}.story-editor .callouts-section h3{align-items:center!important;color:#2e7d32!important;display:flex!important;font-size:16px!important;font-weight:600!important;gap:8px!important;margin:0 0 15px!important}.story-editor .callouts-section h3:before{content:"💬"!important;font-size:18px!important}.story-editor .no-callouts-message{color:#666!important;font-style:italic!important;padding:20px!important;text-align:center!important}.story-editor .callouts-list{display:flex!important;flex-direction:column!important;gap:15px!important}.story-editor .page-callouts h4{border-bottom:1px solid #e0e0e0!important;color:#19a4a0!important;font-size:14px!important;font-weight:600!important;margin:0 0 10px!important;padding-bottom:5px!important}.story-editor .callout-item{background:#fff!important;border:1px solid #e0e0e0!important;border-radius:6px!important;margin-bottom:8px!important;padding:12px!important}.story-editor .callout-text{background:none!important;border:none!important;color:#333!important;font-style:italic!important;font-weight:600!important;margin-bottom:5px!important;padding:0!important}.story-editor .callout-content{color:#666!important;font-size:14px!important;margin-bottom:8px!important;text-align:center!important}.story-editor .remove-callout-btn{background-color:#f44336!important;border:none!important;border-radius:3px!important;color:#fff!important;cursor:pointer!important;font-size:12px!important;padding:4px 8px!important;transition:all .2s ease!important}.story-editor .remove-callout-btn:hover:not(:disabled){background-color:#d32f2f!important}.story-editor .remove-callout-btn:disabled{cursor:not-allowed!important;opacity:.5!important}.story-content .has-callout[data-callout]:hover .callout-tooltip,.story-content .story-tooltip[data-callout]:hover .story-tooltip-popup{display:block!important;opacity:1!important;pointer-events:auto!important}.interactive-image-content .hotspot{cursor:pointer!important;position:absolute!important;z-index:15!important}.interactive-image-content .hotspot-indicator{align-items:center!important;background-color:#007bff!important;border:3px solid #fff!important;border-radius:50%!important;color:#fff!important;display:flex!important;height:30px!important;justify-content:center!important;width:30px!important}.speech-bubble-content{animation:bubble-appear .4s cubic-bezier(.4,0,.2,1)!important;-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important;background:#fffffff2!important;border:2px solid #19a4a0cc!important;border-radius:16px!important;box-shadow:0 8px 32px #0000001f!important;color:#1f2937!important;font-family:inherit!important;font-size:inherit!important;line-height:inherit!important;max-height:200px!important;overflow-y:auto!important;padding:16px!important;position:relative!important;text-align:center!important}@media (max-width:768px){.story-content .callout-tooltip,.story-content .story-tooltip-popup{font-size:15px!important;max-width:280px!important;padding:10px 14px!important}.story-content .callout-tooltip img,.story-content .callout-with-image img,.story-content .story-tooltip-popup img{max-height:60px!important;max-width:60px!important}}@media (max-width:480px){.story-content .callout-tooltip,.story-content .story-tooltip-popup{font-size:14px!important;max-width:250px!important;padding:8px 12px!important}.story-content .callout-tooltip img,.story-content .callout-with-image img,.story-content .story-tooltip-popup img{max-height:50px!important;max-width:50px!important}}.story-content .callout-text:focus,.story-content .has-callout:focus,.story-content .story-tooltip:focus{outline:2px solid #e8a327!important;outline-offset:2px!important}@media (prefers-contrast:high){.story-content .callout-text,.story-content .has-callout,.story-content .story-tooltip{background-color:#ff0!important;border-bottom-color:#000!important;color:#000!important}.story-content .callout-tooltip,.story-content .story-tooltip-popup{background:#000!important;border-color:#fff!important;color:#fff!important}}@media (prefers-reduced-motion:reduce){.story-content .callout-text,.story-content .callout-tooltip,.story-content .has-callout,.story-content .story-tooltip,.story-content .story-tooltip-popup{animation:none!important;transform:none!important;transition:none!important}.story-content .callout-text:hover,.story-content .has-callout:hover,.story-content .story-tooltip:hover{transform:none!important}}@media print{.story-content .callout-tooltip,.story-content .story-tooltip-popup{display:none!important}.story-content .callout-text:after,.story-content .has-callout:after,.story-content .story-tooltip:after{background:none!important;border:none!important;color:#666!important;content:" [" attr(data-callout) "]"!important;font-size:.8em!important;padding:0!important}}
/*# sourceMappingURL=main.2338b9a5.css.map*/