.navbar{position:fixed;top:0;left:0;right:0;height:60px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:1000;box-shadow:0 2px 8px var(--shadow)}.navbar-content{max-width:100%;height:100%;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between}.navbar-left{display:flex;align-items:center;gap:1rem}.menu-btn{background:transparent;border:none;display:flex;flex-direction:column;gap:4px;padding:8px;cursor:pointer;transition:opacity .3s ease}.menu-btn:hover{opacity:.7}.menu-icon{width:24px;height:3px;background:var(--text-primary);border-radius:2px;transition:all .3s ease}.logo{display:flex;align-items:center;text-decoration:none}.logo-content{display:flex;flex-direction:column;gap:.15rem}.logo-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);line-height:1.2}.logo-subtitle{font-size:.7rem;color:var(--text-secondary);font-weight:400;line-height:1.2}.logo:hover .logo-title{color:var(--accent-primary)}.logo:hover .logo-subtitle{color:var(--text-primary)}.navbar-right{display:flex;align-items:center;gap:1rem}.theme-toggle{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:8px 12px;font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.theme-toggle:hover{background:var(--bg-hover);transform:scale(1.05)}@media (max-width: 768px){.navbar{height:55px}.navbar-content{padding:0 1rem}.logo-title{font-size:.95rem}.logo-subtitle{font-size:.65rem}}.sidebar{position:fixed;top:60px;left:-280px;width:280px;height:calc(100vh - 60px);background:var(--bg-secondary);border-right:1px solid var(--border-color);overflow-y:auto;transition:left .3s ease;z-index:900;display:flex;flex-direction:column}.sidebar.open{left:0}.sidebar-overlay{display:none}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:var(--bg-secondary);z-index:10}.sidebar-header h2{font-size:1.3rem;color:var(--accent-primary);margin:0}.close-btn{display:none;background:transparent;color:var(--text-secondary);font-size:1.5rem;padding:4px 8px;cursor:pointer;transition:color .3s ease}.close-btn:hover{color:var(--text-primary)}.search-container{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.search-input{width:100%;padding:.6rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.9rem;transition:all .3s ease}.search-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #00d9ff1a}.search-input::placeholder{color:var(--text-tertiary)}.progress-container{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.9rem;color:var(--text-secondary);font-weight:500}.progress-bar{width:100%;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-success));transition:width .5s ease;border-radius:4px}.chapter-list{flex:1;padding:.5rem 0;overflow-y:auto}.chapter-item{margin:0}.chapter-header{display:flex;align-items:center;gap:.5rem;padding:.8rem 1.5rem;transition:background .3s ease;position:relative}.chapter-toggle{color:var(--text-tertiary);font-size:.7rem;flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;border-radius:3px}.chapter-toggle:hover{background:var(--bg-tertiary);color:var(--accent-primary);transform:scale(1.1)}.chapter-link{flex:1;color:var(--text-primary);text-decoration:none;display:flex;flex-direction:column;gap:.2rem;min-width:0}.chapter-link:hover{color:var(--accent-primary)}.chapter-link.active{color:var(--accent-primary);font-weight:600}.chapter-number{font-size:.75rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.chapter-title{font-size:.95rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.completed-badge{color:var(--accent-success);font-size:1rem;flex-shrink:0;margin-left:auto}.topic-list{list-style:none;margin:0;padding-left:2.5rem;background:var(--bg-tertiary)}.topic-item{margin:0}.topic-item a,.topic-item .topic-link{display:block;width:100%;padding:.5rem 1.5rem;color:var(--text-secondary);font-size:.85rem;text-decoration:none;text-align:left;background:none;border:none;border-left:2px solid transparent;cursor:pointer;transition:all .3s ease;font-family:inherit}.topic-item a:hover,.topic-item .topic-link:hover{color:var(--accent-primary);background:var(--bg-hover);border-left-color:var(--accent-primary)}@media (max-width: 768px){.sidebar{top:55px;height:calc(100vh - 55px);box-shadow:2px 0 10px var(--shadow)}.sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:800}.close-btn{display:block}}@media (min-width: 769px){.sidebar-overlay{display:none!important}.close-btn{display:none}}.app-container{display:flex;flex-direction:column;min-height:100vh}.main-container{display:flex;flex:1;padding-top:60px}.content-area{flex:1;transition:margin-left .3s ease;margin-left:0}@media (max-width: 768px){.main-container{padding-top:55px}.content-area.sidebar-open{margin-left:0}}.footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:3rem 2rem;margin-top:4rem}.footer-content{max-width:800px;margin:0 auto;text-align:center}.footer-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem;letter-spacing:.5px}.footer-subtitle{font-size:1.1rem;color:var(--text-secondary);margin:0 0 .5rem;font-weight:500}.footer-tagline{font-size:1rem;color:var(--text-tertiary);font-style:italic;margin:0 0 1.5rem}.footer-copyright{font-size:.9rem;color:var(--text-tertiary);margin:0;padding-top:1rem;border-top:1px solid var(--border-color)}@media (max-width: 768px){.footer{padding:2rem 1rem;margin-top:3rem}.footer-title{font-size:1.5rem}.footer-subtitle{font-size:1rem}.footer-tagline{font-size:.9rem}.footer-copyright{font-size:.85rem}}.home-container{max-width:1200px;margin:0 auto;padding:2rem}.hero-section{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-radius:16px;margin-bottom:4rem;box-shadow:0 8px 24px var(--shadow)}.hero-title{font-size:3rem;font-weight:800;color:var(--text-primary);margin-bottom:1.5rem;line-height:1.2}.hero-highlight{background:linear-gradient(90deg,var(--accent-primary),var(--accent-success));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:1.2rem;color:var(--text-secondary);max-width:700px;margin:0 auto 2.5rem;line-height:1.8}.hero-stats{display:flex;justify-content:center;gap:3rem;margin:3rem 0;flex-wrap:wrap}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.stat-number{font-size:3rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary),var(--accent-success));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:.9rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;font-weight:600}.cta-button{display:inline-block;padding:1rem 3rem;background:var(--accent-primary);color:var(--bg-primary);font-size:1.2rem;font-weight:600;border-radius:12px;text-decoration:none;transition:all .3s ease;box-shadow:0 4px 16px #00d9ff4d}.cta-button:hover{background:var(--accent-secondary);transform:translateY(-3px);box-shadow:0 8px 24px #00d9ff66}.features-section{margin-bottom:4rem}.features-section h2{font-size:2.5rem;text-align:center;color:var(--text-primary);margin-bottom:3rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.feature-card{background:var(--bg-secondary);padding:2rem;border-radius:12px;border:1px solid var(--border-color);transition:all .3s ease;text-align:center}.feature-card:hover{transform:translateY(-5px);box-shadow:0 8px 24px var(--shadow);border-color:var(--accent-primary)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{font-size:1.3rem;color:var(--accent-primary);margin-bottom:1rem}.feature-card p{color:var(--text-secondary);line-height:1.6}.chapters-section{margin-bottom:4rem}.chapters-section h2{font-size:2.5rem;text-align:center;color:var(--text-primary);margin-bottom:3rem}.chapters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.chapter-card{background:var(--bg-secondary);padding:1.5rem;border-radius:12px;border:2px solid var(--border-color);text-decoration:none;display:flex;flex-direction:column;transition:all .3s ease;position:relative;overflow:hidden}.chapter-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:0;background:var(--accent-primary);transition:height .3s ease}.chapter-card:hover{transform:translateY(-5px);box-shadow:0 8px 24px var(--shadow);border-color:var(--accent-primary)}.chapter-card:hover:before{height:100%}.chapter-card.completed{border-color:var(--accent-success)}.chapter-card.completed:before{background:var(--accent-success);height:100%}.chapter-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.chapter-num{font-size:.85rem;color:var(--accent-primary);text-transform:uppercase;letter-spacing:1px;font-weight:700}.completed-icon{color:var(--accent-success);font-size:1.5rem;font-weight:700}.chapter-card-title{font-size:1.3rem;color:var(--text-primary);margin-bottom:.8rem;line-height:1.3}.chapter-card-topics{font-size:.9rem;color:var(--text-tertiary);margin-bottom:1rem}.chapter-card-footer{margin-top:auto;padding-top:1rem;border-top:1px solid var(--border-color)}.learn-more{color:var(--accent-primary);font-weight:600;font-size:.95rem;transition:transform .3s ease;display:inline-block}.chapter-card:hover .learn-more{transform:translate(5px)}@media (max-width: 768px){.home-container{padding:1rem}.hero-section{padding:3rem 1.5rem;margin-bottom:3rem}.hero-title{font-size:2rem}.hero-description{font-size:1rem}.hero-stats{gap:2rem}.stat-number{font-size:2.5rem}.cta-button{padding:.8rem 2rem;font-size:1.1rem}.features-section h2,.chapters-section h2{font-size:2rem}.features-grid,.chapters-grid{grid-template-columns:1fr}.feature-card{padding:1.5rem}}.code-block-container{margin:1.5rem 0;border-radius:12px;overflow:hidden;border:1px solid var(--code-border);background:var(--code-bg);box-shadow:0 2px 8px var(--shadow)}[data-theme=light] .code-block-container{box-shadow:0 2px 8px #00000014}[data-theme=light] .code-pre{border:1px solid var(--border-color)}.code-header{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1.2rem;background:var(--bg-tertiary);border-bottom:1px solid var(--code-border)}.code-language{font-size:.85rem;font-weight:600;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.5px}.copy-btn{background:var(--accent-primary);color:var(--bg-primary);padding:.4rem 1rem;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.3rem}.copy-btn:hover{background:var(--accent-secondary);transform:translateY(-2px)}.code-pre{margin:0;padding:0;overflow-x:auto;background:var(--code-bg);border:none}.code-pre pre{margin:0!important;background:var(--code-bg)!important}.code-pre::-webkit-scrollbar{height:8px}.code-pre::-webkit-scrollbar-track{background:var(--bg-tertiary)}.code-pre::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.code-pre::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.code-explanation{padding:1.5rem;background:var(--bg-secondary);border-top:1px solid var(--code-border)}.code-explanation h4{color:var(--accent-primary);margin-bottom:1rem;font-size:1rem;display:flex;align-items:center;gap:.5rem}.code-explanation ul{list-style:none;margin:0;padding:0}.code-explanation li{margin-bottom:.8rem;padding-left:0;color:var(--text-secondary);line-height:1.6}.code-explanation strong{color:var(--accent-primary);font-weight:600}.code-output{padding:1.5rem;background:var(--bg-tertiary);border-top:1px solid var(--code-border)}.code-output h4{color:var(--accent-success);margin-bottom:1rem;font-size:1rem;display:flex;align-items:center;gap:.5rem}.code-output pre{margin:0;padding:1rem;background:var(--code-bg);border:1px solid var(--code-border);border-radius:8px;color:var(--text-primary);font-size:.9rem;line-height:1.6;font-family:Consolas,Monaco,Courier New,monospace}[data-theme=light] .code-output pre{background:var(--bg-tertiary)}@media (max-width: 768px){.code-header{padding:.6rem 1rem}.code-pre pre{font-size:.85rem!important}.code-explanation,.code-output{padding:1rem}.copy-btn{padding:.3rem .8rem;font-size:.75rem}}.quiz-container{margin:2rem 0;padding:2rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);box-shadow:0 4px 12px var(--shadow)}.quiz-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.quiz-header h3{color:var(--accent-primary);font-size:1.5rem;margin:0;display:flex;align-items:center;gap:.5rem}.question-counter{font-size:.9rem;color:var(--text-secondary);background:var(--bg-tertiary);padding:.4rem 1rem;border-radius:20px;font-weight:600}.quiz-progress{width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;margin-bottom:2rem;overflow:hidden}.quiz-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-success));transition:width .5s ease;border-radius:3px}.question-section{margin-bottom:2rem}.question-text{font-size:1.2rem;color:var(--text-primary);margin-bottom:1.5rem;line-height:1.6;font-weight:500}.answers-section{display:flex;flex-direction:column;gap:1rem}.answer-btn{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:10px;text-align:left;cursor:pointer;transition:all .3s ease;position:relative}.answer-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent-primary);transform:translate(4px)}.answer-btn:disabled{cursor:not-allowed}.answer-btn.selected{border-color:var(--accent-primary);background:var(--bg-hover)}.answer-btn.correct{border-color:var(--accent-success);background:#00ff881a}.answer-btn.incorrect{border-color:var(--accent-error);background:#ff44441a}.option-letter{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--accent-primary);color:var(--bg-primary);border-radius:50%;font-weight:700;flex-shrink:0;transition:all .3s ease}.answer-btn.correct .option-letter{background:var(--accent-success)}.answer-btn.incorrect .option-letter{background:var(--accent-error)}.option-text{flex:1;color:var(--text-primary);font-size:1rem;line-height:1.5}.check-icon,.cross-icon{font-size:1.5rem;font-weight:700;flex-shrink:0}.check-icon{color:var(--accent-success)}.cross-icon{color:var(--accent-error)}.explanation{margin-top:1.5rem;padding:1rem 1.5rem;border-radius:8px;border-left:4px solid var(--accent-primary);background:var(--bg-tertiary);animation:slideDown .3s ease}.explanation.correct-exp{border-left-color:var(--accent-success)}.explanation.incorrect-exp{border-left-color:var(--accent-error)}.explanation p{margin:0;color:var(--text-secondary);line-height:1.6}.explanation strong{color:var(--text-primary)}.next-btn{width:100%;padding:1rem;background:var(--accent-primary);color:var(--bg-primary);font-size:1.1rem;font-weight:600;border-radius:10px;cursor:pointer;transition:all .3s ease;margin-top:1.5rem}.next-btn:hover{background:var(--accent-secondary);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.quiz-result{text-align:center;padding:2rem 0}.quiz-result h3{color:var(--accent-primary);font-size:2rem;margin-bottom:2rem}.score-display{display:flex;justify-content:center;margin:2rem 0}.score-circle{width:180px;height:180px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-success));display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 8px 24px var(--shadow);animation:scaleIn .5s ease}.score-number{font-size:4rem;font-weight:700;color:var(--bg-primary);line-height:1}.score-total{font-size:1.5rem;color:var(--bg-primary);opacity:.9}.score-percentage{font-size:1.8rem;font-weight:600;color:var(--text-primary);margin:1rem 0}.score-message{font-size:1.2rem;color:var(--text-secondary);margin-bottom:2rem}.quiz-btn{padding:1rem 3rem;background:var(--accent-primary);color:var(--bg-primary);font-size:1.1rem;font-weight:600;border-radius:10px;cursor:pointer;transition:all .3s ease}.quiz-btn:hover{background:var(--accent-secondary);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.quiz-container{padding:1.5rem}.quiz-header{flex-direction:column;align-items:flex-start;gap:1rem}.quiz-header h3{font-size:1.3rem}.question-text{font-size:1.1rem}.answer-btn{padding:.8rem 1rem;gap:.8rem}.option-text{font-size:.95rem}.score-circle{width:150px;height:150px}.score-number{font-size:3rem}.score-total{font-size:1.2rem}}.practice-container{margin:2rem 0;padding:2rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);box-shadow:0 4px 12px var(--shadow)}.practice-title{color:var(--accent-primary);font-size:1.8rem;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.practice-subtitle{color:var(--text-secondary);font-size:1rem;margin-bottom:2rem}.problems-list{display:flex;flex-direction:column;gap:1.5rem}.problem-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;overflow:hidden;transition:all .3s ease}.problem-card:hover{box-shadow:0 4px 12px var(--shadow);border-color:var(--accent-primary)}.problem-header{padding:1.5rem;cursor:pointer;position:relative;transition:background .3s ease}.problem-header:hover{background:var(--bg-hover)}.problem-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.8rem}.problem-number{font-size:.85rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.difficulty-badge{padding:.3rem .8rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.difficulty-easy{background:#0f83;color:var(--accent-success);border:1px solid var(--accent-success)}.difficulty-medium{background:#fb03;color:var(--accent-warning);border:1px solid var(--accent-warning)}.difficulty-hard{background:#f443;color:var(--accent-error);border:1px solid var(--accent-error)}.problem-title{color:var(--text-primary);font-size:1.2rem;font-weight:600;margin:0;line-height:1.4}.expand-btn{position:absolute;top:1.5rem;right:1.5rem;background:transparent;color:var(--accent-primary);font-size:1.2rem;padding:0;cursor:pointer;transition:transform .3s ease}.problem-content{padding:0 1.5rem 1.5rem;animation:slideDown .3s ease}.problem-description h5,.problem-example h5,.problem-hint h5{color:var(--accent-primary);font-size:1rem;margin-bottom:.8rem;display:flex;align-items:center;gap:.5rem}.problem-description p,.problem-hint p{color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem}.problem-example{margin:1.5rem 0}.problem-example pre{background:var(--code-bg);border:1px solid var(--code-border);padding:1rem;border-radius:8px;color:var(--text-primary);font-size:.9rem;overflow-x:auto}.problem-hint{padding:1rem;background:#ffbb001a;border-left:4px solid var(--accent-warning);border-radius:6px;margin:1.5rem 0}.problem-hint h5{color:var(--accent-warning)}.problem-solution{margin-top:1.5rem;border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.problem-solution summary{padding:1rem;background:var(--bg-hover);cursor:pointer;font-weight:600;color:var(--accent-success);transition:background .3s ease;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:.5rem}.problem-solution summary:hover{background:var(--bg-tertiary)}.problem-solution pre{margin:0;background:var(--code-bg);border:none;border-top:1px solid var(--border-color);padding:1.5rem;color:var(--text-primary);font-size:.9rem;overflow-x:auto}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}@media (max-width: 768px){.practice-container{padding:1.5rem}.practice-title{font-size:1.5rem}.problem-header{padding:1rem}.problem-title{font-size:1.1rem;padding-right:2rem}.expand-btn{top:1rem;right:1rem}.problem-content{padding:0 1rem 1rem}.problem-example pre,.problem-solution pre{font-size:.85rem;padding:1rem}}.problem-actions{margin:1.5rem 0;display:flex;gap:1rem}.try-code-btn{padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-weight:700;font-size:1.05rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 15px #667eea66;position:relative;overflow:hidden}.try-code-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.try-code-btn:hover:before{left:100%}.try-code-btn:hover{transform:translateY(-3px);box-shadow:0 6px 20px #667eea99}.try-code-btn:active{transform:translateY(-1px)}@media (max-width: 768px){.problem-actions{flex-direction:column}.try-code-btn{width:100%;justify-content:center}}.theory-questions-container{margin:3rem 0;padding:2rem;background:var(--card-bg);border-radius:12px;box-shadow:0 4px 20px var(--shadow)}.theory-title{font-size:1.8rem;margin:0 0 .5rem;color:var(--accent-color);display:flex;align-items:center;gap:.5rem}.theory-subtitle{margin:0 0 2rem;color:var(--text-secondary);font-size:1rem;line-height:1.6}.questions-list{display:flex;flex-direction:column;gap:1.5rem}.question-card{background:var(--bg-color);border:2px solid var(--border-color);border-radius:10px;overflow:hidden;transition:all .3s ease}.question-card:hover{border-color:var(--accent-color);box-shadow:0 4px 15px #00d9ff33}.question-card[open]{border-color:var(--accent-color)}.question-header{padding:1.2rem 1.5rem;cursor:pointer;display:flex;align-items:flex-start;gap:1rem;list-style:none;-webkit-user-select:none;user-select:none;font-weight:500;transition:all .3s ease;background:var(--secondary-bg)}.question-header::-webkit-details-marker{display:none}.question-header:hover{background:var(--hover-bg)}.question-card[open] .question-header{background:linear-gradient(135deg,#00d9ff1a,#4361ee1a);border-bottom:2px solid var(--accent-color)}.question-number{flex-shrink:0;font-weight:700;color:var(--accent-color);font-size:1.1rem;min-width:40px}.question-text{flex:1;line-height:1.6;color:var(--text-color);font-size:1.05rem}.expand-icon{flex-shrink:0;color:var(--accent-color);font-size:.8rem;transition:transform .3s ease;margin-left:auto}.question-card[open] .expand-icon{transform:rotate(180deg)}.answer-content{padding:1.5rem;background:var(--bg-color);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.answer-badge{display:inline-block;padding:.4rem 1rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:20px;font-weight:600;font-size:.9rem;margin-bottom:1rem;box-shadow:0 2px 8px #10b9814d}.answer-text{margin:0;padding:1.5rem;background:var(--code-bg);border-radius:8px;border-left:4px solid #10b981;font-family:Segoe UI,Arial,sans-serif;font-size:1rem;line-height:1.8;color:var(--text-color);white-space:pre-wrap;word-wrap:break-word;overflow-x:auto}.answer-text code{background:var(--secondary-bg);padding:.2rem .4rem;border-radius:4px;font-family:Consolas,Monaco,Courier New,monospace;font-size:.95rem}.theory-tip{margin-top:2rem;padding:1.2rem 1.5rem;background:linear-gradient(135deg,#f59e0b1a,#fbbf241a);border-left:4px solid #f59e0b;border-radius:8px;line-height:1.8;color:var(--text-color)}.theory-tip strong{color:#f59e0b;font-size:1.1rem}.answer-text::-webkit-scrollbar{height:8px}.answer-text::-webkit-scrollbar-track{background:var(--secondary-bg);border-radius:4px}.answer-text::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.answer-text::-webkit-scrollbar-thumb:hover{background:var(--accent-color)}@media (max-width: 768px){.theory-questions-container{padding:1.5rem;margin:2rem 0}.theory-title{font-size:1.5rem}.theory-subtitle{font-size:.95rem}.question-header{padding:1rem;gap:.8rem}.question-number{min-width:35px;font-size:1rem}.question-text{font-size:1rem}.answer-content{padding:1rem}.answer-text{padding:1rem;font-size:.95rem;line-height:1.7}.theory-tip{padding:1rem;font-size:.95rem}}@media (max-width: 480px){.theory-questions-container{padding:1rem}.theory-title{font-size:1.3rem}.question-header{padding:.8rem;flex-direction:column;gap:.5rem}.question-number{min-width:auto}.expand-icon{position:absolute;right:.8rem;top:.8rem}.answer-text{font-size:.9rem;padding:.8rem}}.chapter-page{max-width:900px;margin:0 auto;padding:2rem;position:relative}.chapter-header-section{margin-bottom:3rem}.breadcrumb{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:.9rem;color:var(--text-tertiary)}.breadcrumb a{color:var(--accent-primary);text-decoration:none;transition:color .3s ease}.breadcrumb a:hover{color:var(--accent-secondary)}.breadcrumb-separator{color:var(--text-tertiary)}.chapter-main-title{font-size:2.5rem;color:var(--text-primary);margin-bottom:1rem;line-height:1.3;font-weight:700}.chapter-description{font-size:1.1rem;color:var(--text-secondary);line-height:1.7;margin-bottom:1.5rem}.completed-badge-large{display:inline-block;padding:.6rem 1.5rem;background:#0f83;color:var(--accent-success);border:2px solid var(--accent-success);border-radius:8px;font-weight:700;font-size:.95rem;letter-spacing:.5px}.chapter-content{margin-bottom:3rem}.topic-section{margin-bottom:4rem;scroll-margin-top:80px}.topic-title{font-size:2rem;color:var(--text-primary);margin-bottom:1.5rem;display:flex;align-items:center;gap:.8rem;padding-bottom:.8rem;border-bottom:2px solid var(--border-color)}.topic-number{color:var(--accent-primary);font-weight:700}.theory-section{margin:2rem 0}.theory-section h3{font-size:1.3rem;color:var(--accent-primary);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.theory-content{color:var(--text-secondary);line-height:1.8}.theory-content p{margin-bottom:1.2rem}.theory-content ul,.theory-content ol{margin-left:1.5rem;margin-bottom:1.2rem}.theory-content li{margin-bottom:.8rem;line-height:1.7}.theory-content strong{color:var(--text-primary);font-weight:600}.theory-content table{margin:1.5rem 0}.syntax-section{margin:2rem 0}.syntax-section h3{font-size:1.3rem;color:var(--accent-primary);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.syntax-block{background:var(--code-bg);border:2px solid var(--accent-primary);border-radius:8px;padding:1.5rem;color:var(--text-primary);font-family:var(--font-mono);font-size:.95rem;line-height:1.6;overflow-x:auto;margin:0}.example-section{margin:2rem 0}.example-section h3{font-size:1.3rem;color:var(--accent-primary);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.practice-section,.quiz-section{margin-top:4rem;scroll-margin-top:80px}.chapter-not-found{text-align:center;padding:4rem 2rem}.chapter-not-found h2{font-size:2rem;color:var(--text-primary);margin-bottom:1rem}.chapter-not-found a{color:var(--accent-primary);text-decoration:underline}.chapter-navigation{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:4rem;padding-top:2rem;border-top:2px solid var(--border-color);flex-wrap:wrap}.nav-btn{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;text-decoration:none;color:var(--text-primary);transition:all .3s ease;flex:1;min-width:150px;max-width:250px}.nav-btn:hover{border-color:var(--accent-primary);background:var(--bg-hover);transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.prev-btn{justify-content:flex-start}.next-btn{justify-content:flex-end}.nav-arrow{font-size:1.5rem;color:var(--accent-primary);font-weight:700}.nav-text{display:flex;flex-direction:column;gap:.2rem}.nav-label{font-size:.8rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.nav-chapter{font-size:1rem;color:var(--text-primary);font-weight:600}.complete-btn{padding:1rem 2rem;background:var(--accent-success);color:var(--bg-primary);font-size:1rem;font-weight:700;border-radius:10px;cursor:pointer;transition:all .3s ease;border:none;text-transform:uppercase;letter-spacing:.5px}.complete-btn:hover{background:#00cc6a;transform:translateY(-2px);box-shadow:0 4px 12px #00ff884d}.scroll-to-top{position:fixed;bottom:2rem;right:2rem;width:50px;height:50px;background:var(--accent-primary);color:var(--bg-primary);border:none;border-radius:50%;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 12px var(--shadow);transition:all .3s ease;z-index:100;display:flex;align-items:center;justify-content:center;font-weight:700}.scroll-to-top:hover{background:var(--accent-secondary);transform:translateY(-3px);box-shadow:0 6px 16px var(--shadow)}@media (max-width: 768px){.chapter-page{padding:1rem}.chapter-main-title{font-size:1.8rem}.chapter-description{font-size:1rem}.topic-title{font-size:1.5rem}.theory-section h3,.syntax-section h3,.example-section h3{font-size:1.1rem}.chapter-navigation{flex-direction:column;gap:1rem}.nav-btn{width:100%;max-width:100%}.complete-btn{width:100%}.scroll-to-top{bottom:1rem;right:1rem;width:45px;height:45px;font-size:1.3rem}}.code-editor-page{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-color);color:var(--text-color)}.editor-page-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--card-bg);border-bottom:2px solid var(--border-color);box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:100}.header-left{display:flex;align-items:center;gap:1.5rem;flex:1}.back-btn{padding:.5rem 1rem;background:var(--accent-color);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .3s ease}.back-btn:hover{background:var(--accent-hover);transform:translate(-3px)}.problem-info{display:flex;align-items:center;gap:1rem}.problem-info h2{margin:0;font-size:1.3rem;font-weight:600}.difficulty-badge{padding:.3rem .8rem;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:uppercase}.difficulty-badge.easy{background:#10b98144;color:#10b981}.difficulty-badge.medium{background:#f59e0b44;color:#f59e0b}.difficulty-badge.hard{background:#ef444444;color:#ef4444}.header-actions{display:flex;gap:.5rem}.header-actions button{padding:.5rem .8rem;background:var(--secondary-bg);color:var(--text-color);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .3s ease}.header-actions button:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.editor-page-content{display:grid;grid-template-columns:320px 1fr 350px;height:calc(100vh - 70px);overflow:hidden}.problem-panel{background:var(--card-bg);border-right:2px solid var(--border-color);overflow-y:auto;padding:1.5rem}.panel-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.panel-section:last-child{border-bottom:none}.panel-section h3{margin:0 0 1rem;font-size:1.1rem;color:var(--accent-color)}.panel-section p{line-height:1.7;color:var(--text-secondary)}.example-box{background:var(--code-bg);padding:1rem;border-radius:6px;border-left:4px solid var(--accent-color);overflow-x:auto;font-family:Consolas,Monaco,monospace;font-size:.9rem;line-height:1.6}.hint-btn,.solution-btn{width:100%;padding:.7rem;background:var(--secondary-bg);color:var(--text-color);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .3s ease}.hint-btn:hover,.solution-btn:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.hint-box,.solution-box{margin-top:1rem;padding:1rem;background:var(--code-bg);border-radius:6px;border-left:4px solid #f59e0b}.solution-box{border-left-color:#10b981}.solution-box pre{margin:0;overflow-x:auto;font-family:Consolas,Monaco,monospace;font-size:.9rem;line-height:1.6}.editor-panel{display:flex;flex-direction:column;background:var(--bg-color)}.editor-toolbar{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;background:var(--card-bg);border-bottom:1px solid var(--border-color)}.toolbar-title{font-family:Consolas,Monaco,monospace;font-size:.95rem;font-weight:500;color:var(--text-secondary)}.toolbar-actions{display:flex;gap:.5rem}.toolbar-btn{padding:.5rem 1rem;background:var(--secondary-bg);color:var(--text-color);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease}.toolbar-btn:hover{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.toolbar-btn.run-btn{background:#10b981;color:#fff;border-color:#10b981}.toolbar-btn.run-btn:hover{background:#059669;border-color:#059669}.toolbar-btn:disabled{opacity:.6;cursor:not-allowed}.editor-container{display:flex;flex:1;overflow:hidden;background:#1e1e1e;position:relative}.line-numbers{padding:1rem 0;background:#1e1e1e;color:#858585;text-align:right;-webkit-user-select:none;user-select:none;font-family:Consolas,Monaco,Courier New,monospace;border-right:1px solid #2d2d2d;min-width:50px;overflow:hidden;z-index:1}.line-number{padding:0 .8rem;line-height:1.6;height:1.6em}.code-editor-wrapper{flex:1;position:relative;overflow:hidden}.code-highlight{position:absolute;top:0;left:0;right:0;bottom:0;padding:1rem;margin:0;background:#1e1e1e;color:#d4d4d4;font-family:Consolas,Monaco,Courier New,monospace;line-height:1.6;white-space:pre-wrap;word-wrap:break-word;overflow-y:auto;overflow-x:auto;pointer-events:none;tab-size:4;-moz-tab-size:4}.code-textarea{position:absolute;top:0;left:0;right:0;bottom:0;padding:1rem;margin:0;background:transparent;color:transparent;caret-color:#d4d4d4;border:none;outline:none;font-family:Consolas,Monaco,Courier New,monospace;line-height:1.6;resize:none;overflow-y:auto;overflow-x:auto;tab-size:4;-moz-tab-size:4;white-space:pre-wrap;word-wrap:break-word}.code-textarea::placeholder{color:#6a6a6a;opacity:1}.code-textarea::selection{background:#6496ff4d;color:#d4d4d4}.hl-comment{color:#6a9955;font-style:italic}.hl-keyword{color:#c586c0;font-weight:500}.hl-string{color:#ce9178}.hl-number{color:#b5cea8}.hl-function{color:#dcdcaa}.hl-preprocessor{color:#c586c0;font-weight:600}.hl-type{color:#4ec9b0;font-weight:500}.hl-operator{color:#d4d4d4;font-weight:600}.hl-member{color:#9cdcfe;font-style:normal}.code-textarea::-webkit-scrollbar,.code-highlight::-webkit-scrollbar,.problem-panel::-webkit-scrollbar,.output-content::-webkit-scrollbar{width:12px;height:12px}.code-textarea::-webkit-scrollbar-track,.code-highlight::-webkit-scrollbar-track,.problem-panel::-webkit-scrollbar-track,.output-content::-webkit-scrollbar-track{background:#252526}.code-textarea::-webkit-scrollbar-thumb,.code-highlight::-webkit-scrollbar-thumb,.problem-panel::-webkit-scrollbar-thumb,.output-content::-webkit-scrollbar-thumb{background:#3e3e42;border-radius:6px}.code-textarea::-webkit-scrollbar-thumb:hover,.code-highlight::-webkit-scrollbar-thumb:hover,.problem-panel::-webkit-scrollbar-thumb:hover,.output-content::-webkit-scrollbar-thumb:hover{background:#4e4e52}.output-panel{background:var(--card-bg);border-left:2px solid var(--border-color);display:flex;flex-direction:column}.output-header{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;background:var(--secondary-bg);border-bottom:1px solid var(--border-color)}.output-header h3{margin:0;font-size:1rem;font-weight:600}.clear-output-btn{padding:.4rem .8rem;background:transparent;color:var(--accent-color);border:1px solid var(--accent-color);border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .3s ease}.clear-output-btn:hover{background:var(--accent-color);color:#fff}.output-content{flex:1;overflow-y:auto;padding:1rem}.error-output{background:#ef44441a;border-left:4px solid #ef4444;padding:1rem;border-radius:6px}.error-output pre{margin:0;color:#ef4444;font-family:Consolas,Monaco,monospace;font-size:.9rem;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.success-output{background:#10b9811a;border-left:4px solid #10b981;padding:1rem;border-radius:6px}.success-output pre{margin:0;color:var(--text-color);font-family:Consolas,Monaco,monospace;font-size:.9rem;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.empty-output{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);font-style:italic}.editor-page-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.editor-page-error h2{margin-bottom:1rem;color:var(--accent-color)}.editor-page-error button{padding:.8rem 1.5rem;background:var(--accent-color);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:1rem;transition:all .3s ease}.editor-page-error button:hover{background:var(--accent-hover);transform:translateY(-2px)}@media (max-width: 1200px){.editor-page-content{grid-template-columns:280px 1fr 300px}}@media (max-width: 968px){.editor-page-content{grid-template-columns:1fr;grid-template-rows:auto 1fr auto;height:auto}.problem-panel,.output-panel{border:none;border-top:2px solid var(--border-color);max-height:40vh}.editor-panel{order:-1;min-height:50vh}.problem-info{flex-direction:column;align-items:flex-start;gap:.5rem}.problem-info h2{font-size:1.1rem}.header-actions{flex-wrap:wrap}}@media (max-width: 640px){.editor-page-header{flex-direction:column;gap:1rem;align-items:stretch}.header-left{flex-direction:column;gap:.8rem}.back-btn{width:100%}.line-numbers{min-width:40px;font-size:.85rem}.code-textarea{font-size:.85rem}}.app-container{min-height:100vh;display:flex;flex-direction:column}.main-container{display:flex;flex:1;margin-top:60px}.content-area{flex:1;padding:2rem;margin-left:0;transition:margin-left .3s ease;max-width:100%;overflow-x:hidden}.content-area.sidebar-open{margin-left:280px}@media (max-width: 768px){.content-area{padding:1rem;margin-left:0!important}.main-container{margin-top:55px}}:root{--font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;--font-mono: "Courier New", Courier, monospace}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #242424;--bg-tertiary: #2d2d2d;--bg-hover: #3a3a3a;--text-primary: #ffffff;--text-secondary: #b4b4b4;--text-tertiary: #8a8a8a;--accent-primary: #00d9ff;--accent-secondary: #00a8cc;--accent-success: #00ff88;--accent-warning: #ffbb00;--accent-error: #ff4444;--border-color: #3a3a3a;--shadow: rgba(0, 0, 0, .5);--code-bg: #1e1e1e;--code-border: #404040}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #e8e8e8;--bg-hover: #e0e0e0;--text-primary: #1a1a1a;--text-secondary: #4a4a4a;--text-tertiary: #6a6a6a;--accent-primary: #0066cc;--accent-secondary: #0052a3;--accent-success: #00aa55;--accent-warning: #ff9900;--accent-error: #cc0000;--border-color: #d0d0d0;--shadow: rgba(0, 0, 0, .1);--code-bg: #ffffff;--code-border: #d0d0d0}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;transition:background-color .3s ease,color .3s ease}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}::selection{background:var(--accent-primary);color:var(--bg-primary)}a{color:var(--accent-primary);text-decoration:none;transition:color .3s ease}a:hover{color:var(--accent-secondary)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);margin-bottom:.5em}button{font-family:var(--font-family);cursor:pointer;border:none;transition:all .3s ease}button:disabled{opacity:.5;cursor:not-allowed}code{font-family:var(--font-mono);background:var(--code-bg);padding:2px 6px;border-radius:3px;font-size:.9em}pre{font-family:var(--font-mono);background:var(--code-bg);padding:1rem;border-radius:8px;overflow-x:auto;border:1px solid var(--code-border)}table{width:100%;border-collapse:collapse;margin:1rem 0;background:var(--bg-secondary);border-radius:8px;overflow:hidden}th,td{padding:12px;text-align:left;border-bottom:1px solid var(--border-color)}th{background:var(--bg-tertiary);font-weight:600;color:var(--accent-primary)}tr:last-child td{border-bottom:none}ul,ol{margin-left:1.5rem;margin-bottom:1rem}li{margin-bottom:.5rem;color:var(--text-secondary)}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.hidden{display:none}
