.sidebar{width:300px;max-width:100%;height:100%;background:#fff;transition:width .2s ease;position:fixed;left:0;z-index:100;display:flex;flex-direction:column;border-right:1px solid #e5e5e5}.sidebar.collapsed{width:60px;min-width:60px}.sidebar-inner{padding:24px 20px 24px 24px;width:100%;opacity:1;transition:opacity .2s ease;visibility:visible;pointer-events:auto;flex:1 1;overflow-y:auto;overflow-x:hidden;height:calc(100vh - 70px)}.sidebar-inner.collapsed{opacity:0;visibility:hidden;pointer-events:none;width:0}.return-button{text-decoration:none;color:#37352f;opacity:.8;font-size:15px;font-weight:400;margin-bottom:18px;padding:0;background:none;border:none;display:flex;align-items:center;cursor:pointer;transition:opacity .2s ease}.return-button:hover{opacity:1}.return-button-arrow{margin-right:6px;font-size:18px}.contents-heading,.section-header{color:#5a5a5a}.contents-heading{font-size:13px;letter-spacing:.08em;margin-bottom:18px;margin-top:0}.contents-heading,.section-header{text-transform:uppercase;font-weight:500}.section-header{font-size:12px;letter-spacing:.09em;margin:24px 0 10px;padding-left:4px}.sidebar-sections{margin-top:35px}.sidebar-section{margin-bottom:0}.section-header-link{padding:12px 16px;border-radius:8px;transition:all .15s ease;color:#374151;font-size:15px;font-weight:400;border:none;display:flex;align-items:center;background:none;text-decoration:none;margin-bottom:2px;line-height:1.4}.section-header-link:hover{background-color:#f3f4f6;color:#111827;text-decoration:none}.section-header-link.active{background-color:#f3f4f6;color:#111827;font-weight:500}.section-header-link.locked{cursor:not-allowed!important}.section-header-link.locked,.section-header-link.locked:hover{background-color:#f9fafb;color:#9ca3af}.section-header-link.locked .completion-indicator{display:none}.clean-section-title{flex:1 1}.completion-indicator{font-size:14px;color:#10b981;font-weight:600;margin-left:8px}.section-header-link.active .completion-indicator{color:#059669}.collapse-button{position:absolute;top:10px;width:48px;height:48px;border:none;border-radius:4px;background-color:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1000;transition:all .2s ease}.collapse-button i{color:#6b7280;font-weight:400;font-size:22px}.collapse-button:hover{background-color:#f3f4f6}.collapse-button.collapsed{right:auto;left:6px}.collapse-button.expanded{right:0}.collapse-button[data-tooltip]:before{content:attr(data-tooltip);position:absolute;transform:translateY(-50%);right:calc(100% + 8px);background-color:rgba(0,0,0,.8);color:white;padding:4px 8px;border-radius:4px;font-size:12px;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.collapse-button.collapsed[data-tooltip]:before{right:auto;left:calc(100% + 8px)}.collapse-button:hover[data-tooltip]:before{opacity:1;visibility:visible}.sidebar-list-item a{display:block;color:inherit;text-decoration:none;width:100%}.sidebar-collapsed-content{display:flex;flex-direction:column;width:100%;height:calc(100vh - 70px);padding-top:60px;opacity:1;visibility:visible}.collapsed-sections{display:flex;flex-direction:column;gap:8px;padding:16px 8px}.collapsed-section-item{width:44px;height:44px;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:all .2s ease;background-color:transparent;border:1px solid transparent;gap:2px}.collapsed-section-item.active,.collapsed-section-item.active.completed,.collapsed-section-item.completed,.collapsed-section-item:hover{background-color:#f3f4f6;border-color:rgba(0,0,0,.1)}.section-icon{font-size:12px;color:#6b7280;line-height:1}.collapsed-section-item.active .section-icon{color:#2563eb}.collapsed-section-item.completed .section-icon{color:#059669}.lesson-count{font-size:10px;font-weight:600;color:#374151;line-height:1;text-align:center}.completed-count{color:#059669}.total-count{color:#9ca3af}.collapsed-section-item.active .completed-count,.collapsed-section-item.active .lesson-count{color:#2563eb}.collapsed-section-item.active .total-count{color:#93c5fd}.completion-check{position:absolute;top:2px;right:2px;font-size:10px;color:#22c55e}.collapsed-section-item.active .completion-check{color:#2563eb}.collapsed-section-item.locked{cursor:not-allowed!important}.collapsed-section-item.locked,.collapsed-section-item.locked:hover{background-color:#f9fafb;border-color:rgba(0,0,0,.05)}.collapsed-section-item.locked .completed-count,.collapsed-section-item.locked .lesson-count,.collapsed-section-item.locked .section-icon{color:#9ca3af}.collapsed-section-item.locked .total-count{color:#d1d5db}.skeleton{border-radius:4px}.loading-exercise-container{padding:20px;border:1px solid #e0e0e0;border-radius:8px;background:#fff}.loading-exercise-header{margin-bottom:24px}.loading-exercise-title.skeleton{height:24px;width:60%;margin-bottom:12px;border-radius:6px}.loading-exercise-description.skeleton{height:16px;width:100%;margin-bottom:8px;border-radius:4px}.loading-exercise-description.skeleton.short{width:75%}.loading-exercise-editor{margin-bottom:20px}.loading-editor-tabs{display:flex;gap:8px;margin-bottom:12px}.loading-tab.skeleton{height:32px;width:80px;border-radius:6px}.loading-editor-area.skeleton{height:200px;width:100%;border-radius:8px;background:linear-gradient(90deg,#f8f9fa 25%,#e9ecef 50%,#f8f9fa 75%);background-size:200px 100%;animation:skeleton-loading 1.5s infinite}.loading-exercise-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.loading-control-group{display:flex;gap:12px}.loading-run-button.skeleton{height:40px;width:100px;border-radius:8px}.loading-hint-button.skeleton{height:40px;width:120px;border-radius:8px}.loading-reset-button.skeleton{height:40px;width:80px;border-radius:8px}.loading-exercise-output{border-top:1px solid #e0e0e0;padding-top:16px}.loading-output-header.skeleton{height:20px;width:150px;margin-bottom:12px;border-radius:4px}.loading-output-content.skeleton{height:80px;width:100%;border-radius:6px;background:linear-gradient(90deg,#f8f9fa 25%,#e9ecef 50%,#f8f9fa 75%);background-size:200px 100%;animation:skeleton-loading 1.5s infinite}@keyframes gradient{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}@keyframes glow{0%{box-shadow:0 2px 8px rgba(157,78,221,.3)}50%{box-shadow:0 2px 20px rgba(157,78,221,.6)}to{box-shadow:0 2px 8px rgba(157,78,221,.3)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.hint-button{transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.hint-button:hover{transform:translateY(-2px) translateZ(0);animation:glow 2s ease-in-out infinite}.hint-button:active{transform:translateY(0) translateZ(0)}.hint-button:active .ripple-effect{animation:ripple .6s ease-out}.loading-state{display:flex;align-items:center;justify-content:center;width:100%}.pulsing-star{animation:pulse 1.5s ease-in-out infinite;color:#fff;text-shadow:0 0 4px rgba(255,255,255,.6);will-change:transform}.shimmer-text{background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.8) 50%,rgba(255,255,255,0));background-size:200% 100%;animation:shimmer 2s linear infinite;background-clip:text;-webkit-background-clip:text;color:transparent;will-change:background-position}.ripple-effect{position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,.4);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none}@keyframes ripple{0%{width:0;height:0;opacity:.4}to{width:200px;height:200px;opacity:0}}@media (max-width:575.98px){.quiz-option-button{min-height:2.75rem}}.quiz-navigation-container{display:flex;flex-direction:column;justify-content:space-between;align-items:center;gap:.5rem}.quiz-button-group{display:flex;flex-direction:column;gap:.5rem;width:100%}.quiz-button-group,.quiz-button-group.left,.quiz-button-group.right{justify-content:center}.quiz-navigation-button{width:100%;border-radius:.375rem}@media (min-width:768px){.quiz-navigation-container{flex-direction:row}.quiz-button-group{flex-direction:row;width:auto}.quiz-button-group.left{justify-content:flex-start}.quiz-button-group.right{justify-content:flex-end}.quiz-navigation-button{width:auto}}.split-gutter{position:relative;display:flex;align-items:center;justify-content:center;height:100%;background:#e0e0e0;cursor:col-resize;width:2px;gap:2px;transition:opacity .2s;pointer-events:auto}.gutter-arrow{width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent}.gutter-arrow:first-child{border-right:6px solid #666}.gutter-arrow:last-child{border-left:6px solid #666}.split-gutter:hover .gutter-arrow{opacity:1}@keyframes skeleton-loading{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200px 100%;animation:skeleton-loading 1.5s infinite}.loading-sidebar{background:#f8f9fa;border-right:1px solid #e0e0e0;width:300px;height:100vh;position:fixed;left:0;top:0;z-index:1000;padding:20px}.loading-course-title.skeleton{height:32px;width:80%;margin-bottom:24px;border-radius:6px}.loading-sections{display:flex;flex-direction:column;gap:20px}.loading-section-title.skeleton{height:24px;width:70%;margin-bottom:12px;border-radius:4px}.loading-lessons{display:flex;flex-direction:column;gap:8px;padding-left:12px}.loading-lesson.skeleton{height:20px;width:90%;border-radius:4px}.loading-lesson-view{margin-left:300px;height:100vh;display:flex;flex-direction:column;background:#ffffff}.loading-content{flex:1 1;padding:40px;display:flex;flex-direction:column;gap:16px;max-width:800px;margin:0 auto;width:100%}.loading-lesson-title.skeleton{height:40px;width:60%;margin-bottom:24px;border-radius:8px}.loading-lesson-text.skeleton{height:16px;width:100%;border-radius:4px}.loading-lesson-text.skeleton.short{width:75%}.loading-code-block.skeleton{height:120px;width:100%;border-radius:8px;margin:20px 0}.loading-navigation{display:flex;justify-content:space-between;align-items:center;padding:16px 40px;border-top:1px solid #e0e0e0;background:#f8f9fa}.loading-nav-button.skeleton{height:40px;width:120px;border-radius:8px}.loading-nav-count.skeleton{height:24px;width:60px;border-radius:4px}@media (max-width:992px){.loading-sidebar{width:250px}.loading-lesson-view{margin-left:250px}.loading-content{padding:20px}.loading-navigation{padding:12px 20px}}@media (max-width:768px){.loading-sidebar{width:100%;height:60px;position:relative;display:flex;align-items:center;padding:12px 20px}.loading-lesson-view{margin-left:0;height:calc(100vh - 60px)}.loading-sections{display:none}.loading-course-title.skeleton{height:24px;width:200px;margin-bottom:0}}.feedback-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.feedback-modal{background:white;border-radius:12px;box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.feedback-modal-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;border-bottom:1px solid #e6e6e6;padding:1.5rem 1.5rem 1rem}.feedback-modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1f2937;text-align:center;grid-column:1/-1;grid-row:1}.feedback-modal-close{background:none;border:none;color:#6b7280;cursor:pointer;padding:.5rem;border-radius:6px;transition:all .2s;display:flex;align-items:center;justify-content:center;grid-column:3;grid-row:1;justify-self:end;z-index:1}.feedback-modal-close:hover{background-color:#f3f4f6;color:#374151}.feedback-modal-close:disabled{opacity:.5;cursor:not-allowed}.feedback-modal-body{padding:1.5rem}.feedback-rating-section{margin-bottom:1.5rem}.feedback-stars-container{gap:.5rem;margin-bottom:.75rem}.feedback-star,.feedback-stars-container{display:flex;justify-content:center;align-items:center}.feedback-star{background:none;border:none;padding:.25rem;cursor:pointer;transition:all .2s ease;border-radius:4px}.feedback-star:hover{background-color:#f3f4f6;transform:scale(1.1)}.feedback-star:disabled{cursor:not-allowed;opacity:.5}.feedback-star svg{width:28px;height:28px;stroke:#d1d5db;fill:none;transition:all .2s ease}.feedback-star.filled svg{stroke:#fbbf24;fill:#fbbf24}.feedback-star:hover svg{stroke:#f59e0b;fill:#f59e0b}.feedback-rating-text{margin:0;font-size:.875rem;color:#6b7280;text-align:center;font-style:italic}.feedback-text-section{margin-bottom:1rem}.feedback-label{display:block;font-weight:600;color:#1f2937;margin-bottom:.75rem;font-size:.875rem}.feedback-optional{font-weight:400;color:#6b7280;font-size:.8rem}.feedback-textarea{width:100%;padding:.75rem;border:2px solid #e6e6e6;border-radius:8px;font-family:inherit;font-size:.875rem;line-height:1.5;resize:vertical;transition:border-color .2s ease;box-sizing:border-box}.feedback-textarea:focus{outline:none;border-color:#1e88e5;box-shadow:0 0 0 3px rgba(30,136,229,.1)}.feedback-textarea::placeholder{color:#9ca3af}.feedback-character-count{text-align:right;font-size:.75rem;color:#6b7280;margin-top:.5rem;font-style:italic}.feedback-modal-footer{display:flex;gap:.75rem;justify-content:flex-end;border-top:1px solid #e6e6e6;padding:1rem 1.5rem 1.5rem}.feedback-modal-cancel{padding:.75rem 1.5rem;border:2px solid #e6e6e6;background:white;color:#374151;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.875rem}.feedback-modal-cancel:hover{background-color:#f9fafb;border-color:#d1d5db}.feedback-modal-cancel:disabled{opacity:.5;cursor:not-allowed}.feedback-modal-submit{padding:.75rem 1.5rem;border:none;background:#1e88e5;color:white;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.feedback-modal-submit:hover:not(:disabled){background:#1976d2}.feedback-modal-submit:disabled{opacity:.5;cursor:not-allowed;background:#9ca3af}.feedback-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:640px){.feedback-modal{max-width:95vw;margin:0 .5rem}.feedback-modal-body,.feedback-modal-footer,.feedback-modal-header{padding-left:1rem;padding-right:1rem}.feedback-modal-footer{flex-direction:column-reverse}.feedback-modal-cancel,.feedback-modal-submit{width:100%;justify-content:center}}.mobile-notification{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#667eea,#764ba2);color:white;padding:12px 16px;box-shadow:0 4px 12px rgba(0,0,0,.15);animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.mobile-notification-content{display:flex;align-items:center;gap:12px;max-width:100%}.mobile-notification-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:rgba(255,255,255,.2);border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mobile-notification-text{flex:1 1;min-width:0}.mobile-notification-text h4{margin:0 0 4px;font-size:14px;font-weight:600;line-height:1.2;color:white}.mobile-notification-text p{margin:0;font-size:12px;line-height:1.3;color:rgba(255,255,255,.9);opacity:.95}.mobile-notification-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:rgba(255,255,255,.2);border:none;border-radius:6px;color:white;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mobile-notification-close:hover{background:rgba(255,255,255,.3);transform:scale(1.05)}.mobile-notification-close:active{transform:scale(.95)}@media (max-width:480px){.mobile-notification{padding:10px 12px}.mobile-notification-content{gap:10px}.mobile-notification-icon{width:28px;height:28px}.mobile-notification-text h4{font-size:13px}.mobile-notification-text p{font-size:11px}.mobile-notification-close{width:24px;height:24px}}@media (prefers-color-scheme:dark){.mobile-notification{background:linear-gradient(135deg,#4f46e5,#7c3aed)}}@media (prefers-reduced-motion:reduce){.mobile-notification{animation:none}.mobile-notification-close:active,.mobile-notification-close:hover{transform:none}}.lesson-page{display:flex;height:calc(100vh - 30px);overflow:hidden}.lesson-view{flex:1 1;transition:all .3s ease;max-width:100%;margin-left:300px;background-color:#f8f9fa}.content-wrapper,.lesson-view{height:100%;overflow:hidden;display:flex;flex-direction:column}.content-wrapper{position:relative;flex:1 1}.content-wrapper>div:first-child{flex:1 1;overflow-y:auto;padding-bottom:70px}.navigation-wrapper{position:fixed;bottom:0;left:300px;right:0;border-top:1px solid #e6e6e6;z-index:10;height:70px}.lesson-navigation,.navigation-wrapper{background-color:#f8f9fa}.lesson-view.sidebar-collapsed{margin-left:30px}.lesson-view.sidebar-collapsed .navigation-wrapper{left:30px}@media (max-width:992px){.lesson-view{margin-left:0;padding:30px;transition:none}.navigation-wrapper{left:0}}@media (max-width:820px){.lesson-page{flex-direction:column;height:calc(100vh - 120px)}.lesson-view{padding:20px 15px}.lesson-view.sidebar-collapsed{margin-left:60px}.lesson-view.sidebar-collapsed .navigation-wrapper{left:60px}}@media (max-width:480px){.lesson-view{padding:15px 10px}.lesson-view.sidebar-collapsed{margin-left:60px}.lesson-view.sidebar-collapsed .navigation-wrapper{left:60px}}.nav-tooltip-wrapper{position:relative;display:inline-block}.nav-tooltip-wrapper[data-tooltip]:before{content:attr(data-tooltip);position:absolute;transform:translateY(-50%);top:-20px;right:0;background-color:rgba(0,0,0,.8);color:white;padding:8px 12px;border-radius:4px;font-size:12px;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;z-index:1000;pointer-events:none}.nav-tooltip-wrapper:hover[data-tooltip]:before{opacity:1;visibility:visible}