code,code .token{margin:0!important;text-shadow:none!important;color:inherit!important}code.language-python{overflow-x:auto}code{display:block;background:#1f1f1f;padding:.5em 1em;border-radius:10px;border:2px solid rgba(212,212,212,.7);white-space:pre;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:1rem!important;text-align:left;line-height:1.35!important}code .token.comment{color:#6a9955!important}code .token.operator{color:#d4d4d4!important}code .token.operator.keyword{color:#569cd6!important}code .token.punctuation{color:#ccc!important}code .token.number{color:#b5cea8!important}code .token.keyword{color:#c586c0!important}code .token.boolean{color:#569cd6!important}code .token.string{color:#ce9178!important}code .token.variable{color:#9cdcfe!important}code .token.constant{color:#4fc1ff!important}code .token.function,code .token.builtin,code .token.function-call{color:#dcdcaa!important}code .token.class-name,code .token.type{color:#4ec9b0!important}code::selection,code .token::selection{background:#667b8f!important}.question-screen{padding:1.5rem;background:#ffffff0d;border-radius:15px;border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(10px);transition:all .3s ease}.question-screen.completed.correct{background:#ffffff40;border-color:#ffffff80;box-shadow:0 0 20px #fff6}.code-block{margin-bottom:.75rem;overflow-x:auto}.question-input,.question-type{font-size:1.1rem;font-weight:600;margin-bottom:.75rem}.question-input code,.input-echo{color:#4ade80!important}.quiz-input.exception,.answer-option.exception,.answer-option.exception.correct{color:#ef4444!important}.answer-options{display:flex;flex-direction:row;flex-wrap:wrap;gap:1rem}.answer-option,.skip-button{background:#1f1f1fb3;border:2px solid transparent;outline:2px solid transparent;border-radius:10px;cursor:pointer;transition:all .3s ease;font-size:1rem;color:#fff;text-align:center;max-width:100%;padding:.25em .75em}.answer-option:hover:not(:disabled){background:#1f1f1f;outline-color:#d4d4d480}.answer-option:disabled,.skip-button:disabled{cursor:default}.answer-option code{font-size:.9rem;height:100%;background:none!important;border:none!important;padding:0!important}.answer-option.correct{background:#2a4f37b3!important;border-color:#4ade80!important;color:#4ade80!important}.answer-option.incorrect{background:#532828b3;border-color:#ef4444;color:#ef4444;animation:shake .5s;animation-iteration-count:1}.skip-button{background:#ff03;outline-color:#ffff00b3;color:#ffff00b3;margin-left:auto;float:right;padding:.1em .75em}.skip-button:hover:not(:disabled){background:#ff06;outline-color:#ff0;color:#ff0}.quiz-input-container{width:100%;text-align:top}.quiz-input{display:inline-block;vertical-align:middle;box-sizing:border-box;width:calc(100% - 7em);padding:.5em 1em;font-size:1em;border:2px solid rgba(212,212,212,.5);border-radius:10px;background:#1f1f1fb3;color:#fff;transition:all .3s ease;min-height:2.25em}input.quiz-input,textarea.quiz-input{font-family:Monaco,Menlo,Ubuntu Mono,monospace}.quiz-input.incorrect{border-color:#ef4444;background:#532828b3;animation:shake .5s;animation-iteration-count:1}.quiz-input.correct{border-color:#4ade80;background:#2a4f37b3}.quiz-input.correct:last-child{margin-top:1em}.quiz-input code{background:none!important;border:none!important;padding:0!important}.quiz-input:focus{outline:none;background:#1f1f1f;border-color:#d4d4d4b3}.quiz-input::placeholder{color:#d4d4d480;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif}.submit-button{display:inline-block;box-sizing:border-box;vertical-align:middle;text-align:center;padding:.5em 1em;background:linear-gradient(135deg,#4ade80,#22c55e);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;backdrop-filter:blur(10px);width:6em;height:2.25em;margin-left:1em}.uses-output .submit-button{vertical-align:top}.submit-button:hover:not(:disabled){background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 4px 15px #4ade804d}.submit-button.incorrect{background:linear-gradient(135deg,#ef4444,#b91c1c);animation:shake .5s;animation-iteration-count:1}.submit-button:disabled{cursor:default}@media (max-width: 768px){.question-screen,.code-block{padding:1rem}.code-block code{font-size:.9rem}.answer-option{padding:.75rem 1rem}.quiz-input{max-width:100%;font-size:1rem}.submit-button{width:100%;max-width:250px}}@keyframes shake{0%{transform:translate(0)}25%{transform:translate(5px)}50%{transform:translate(-5px)}75%{transform:translate(2.5px)}to{transform:translate(0)}}.topic-completion-screen{display:flex;justify-content:center;align-items:center;min-height:400px;padding:2rem}.completion-content{background:#ffffff1a;border-radius:20px;padding:3rem;text-align:center;backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);max-width:500px;width:100%;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.completion-icon{font-size:4rem;margin-bottom:1rem;animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.completion-content h2{color:#4ade80;font-size:2rem;margin:0 0 1rem;font-weight:700}.completion-content p{color:#fff;font-size:1.2rem;margin:0 0 2rem;opacity:.9}.completion-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2rem}.action-button{padding:1rem 2rem;border:none;border-radius:10px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;backdrop-filter:blur(10px);min-width:150px}.restart-button{background:#ffffff1a;color:#fff;border:2px solid rgba(255,255,255,.2)}.restart-button:hover{background:#fff3;border-color:#ffffff4d;transform:translateY(-2px)}.next-button{background:linear-gradient(135deg,#4ade80,#22c55e);color:#fff;border:2px solid #4ade80}.next-button:hover{background:linear-gradient(135deg,#22c55e,#16a34a);transform:translateY(-2px);box-shadow:0 4px 15px #4ade804d}@media (max-width: 768px){.completion-content{padding:2rem;margin:1rem}.completion-actions{flex-direction:column;align-items:center}.action-button{width:100%;max-width:250px}}.locked-topic-screen{display:flex;align-items:center;justify-content:center;width:100%;min-height:calc(100vh - 4.5rem);padding:2rem}.locked-topic-content{max-width:600px;width:100%;background:#ffffff1a;backdrop-filter:blur(10px);border-radius:20px;padding:2rem;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.locked-topic-header{text-align:center;margin-bottom:2rem}.locked-topic-header h2{margin:0 0 1rem;font-size:1.8rem;font-weight:700;color:#fff}.locked-topic-description{margin:0;font-size:1rem;opacity:.9;color:#fff;line-height:1.5}.requirements-section{margin-bottom:2rem}.requirements-section h3{margin:0 0 1.5rem;font-size:1.3rem;font-weight:600;color:#fff;text-align:center}.no-requirements{text-align:center;padding:2rem;background:#ffffff0d;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.no-requirements p{margin:0;color:#fff;opacity:.8}.requirements-list{display:flex;flex-direction:column;gap:1.5rem}.completed-requirements,.remaining-requirements{background:#ffffff0d;border-radius:12px;padding:1.5rem;border:1px solid rgba(255,255,255,.1)}.completed-requirements h4,.remaining-requirements h4{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#fff}.topic-list{display:flex;flex-direction:column;gap:.5rem}.topic-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.topic-item.accessible{cursor:pointer}.topic-item.accessible:hover{background:#ffffff1a;border-color:#fff3}.topic-item.completed{border-color:#4ade80;background:#4ade801a}.topic-item.locked{opacity:.6;cursor:not-allowed}.topic-name{font-weight:500;color:#fff}.status-badge{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem}.status-badge.completed{background:#4ade80;color:#fff}.status-badge.available{background:#fff3;color:#fff}.status-badge.locked{background:#ffffff1a;color:#ffffff80}.progress-summary{text-align:center}.progress-bar{width:100%;height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin-bottom:1rem}.progress-text{margin:0;font-size:.9rem;color:#fff;opacity:.8}@media (max-width: 768px){.locked-topic-screen{padding:1rem}.locked-topic-content{padding:1.5rem}.locked-topic-header h2{font-size:1.5rem}.requirements-list{gap:1rem}.completed-requirements,.remaining-requirements{padding:1rem}}.App{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;overflow:hidden}.App-header{padding:1rem 2rem;background:#0000001a;backdrop-filter:blur(10px);display:flex;justify-content:space-between;align-items:center;height:2.5rem}.App-header img{height:3em;vertical-align:middle;-webkit-filter:drop-shadow(0px 0px 5px rgba(0,0,0,.5));filter:drop-shadow(0px 0px 5px rgba(0,0,0,.5));margin-right:.5em}.App-header table{border-spacing:0;border-collapse:collapse}.App-header h1{margin:0;font-size:2rem;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.3);line-height:1.1}.App-header .subtitle{margin:0;font-size:.75rem}.mode-toggle{display:flex;gap:.5rem;background:#ffffff0d;border-radius:10px;padding:.25rem;border:1px solid rgba(255,255,255,.1)}.toggle-button{padding:.5rem 1rem;border:none;border-radius:8px;background:transparent;color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;backdrop-filter:blur(10px)}.toggle-button:hover{background:#ffffff1a}.toggle-button.active{background:#fff3;box-shadow:0 2px 8px #ffffff1a}.App-main{flex:1;display:flex;width:100%}.sidebar{width:275px;background:#0000001a;backdrop-filter:blur(10px);border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;overflow-y:auto;height:calc(100vh - 4.5rem);transform:scaleX(-1)}.sidebar-content{flex:1;padding:1rem;transform:scaleX(-1)}.sidebar-item{background:#ffffff0d;border-radius:8px;padding:1rem;margin-bottom:.5rem;cursor:pointer;transition:all .3s ease;border:1px solid transparent}.sidebar-item:hover{background:#ffffff1a;border-color:#fff3}.sidebar-item.active{background:#ffffff26;border-color:#ffffff4d;box-shadow:0 0 10px #ffffff80}.sidebar-item.completed{border-color:#4ade80!important;background:#4ade801a}.sidebar-item.in-progress{border-color:#fbbf24!important;background:#fbbf241a}.sidebar-item.locked{border-color:#ffffff1a;opacity:.6;cursor:not-allowed}.sidebar-item.locked:hover{transform:none;border-color:#ffffff1a}.sidebar-item-header{display:flex;justify-content:space-between;align-items:center}.sidebar-item-title{font-weight:500;font-size:.9rem}.status-indicator{width:20px;min-width:20px;height:20px;margin-left:.4rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem}.status-indicator.completed{background:#4ade80;color:#fff}.status-indicator.in-progress{background:#fbbf24;color:#fff}.status-indicator.available{background:#fff3;color:#fff}.status-indicator.locked{background:#ffffff1a;color:#ffffff80}.sidebar-item-progress{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.progress-bar{flex:1;height:4px;background:#fff3;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4ade80,#22c55e);transition:width .3s ease}.progress-text{font-size:.7rem;opacity:.8;min-width:30px;text-align:right}.sidebar-group{margin-bottom:.5rem}.sidebar-group-header{background:#ffffff14;border-radius:8px;padding:.75rem 1rem;cursor:pointer;transition:all .3s ease;border:1px solid transparent;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.9rem;user-select:none}.sidebar-group-header:hover{background:#ffffff1f;border-color:#fff3}.sidebar-group-header.completed{border-color:#4ade80;background:#4ade8026}.sidebar-group-header.in-progress{border-color:#fbbf24;background:#fbbf2426}.sidebar-group-header.available{cursor:pointer}.sidebar-group-title{display:flex;align-items:center;gap:.5rem}.expand-icon{font-size:.7rem;transition:transform .2s ease;color:#ffffffb3}.expand-icon.expanded{transform:rotate(90deg)}.group-status-indicator{width:20px;min-width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem}.group-status-indicator.completed{background:#4ade80;color:#fff}.group-status-indicator.in-progress{background:#fbbf24;color:#fff}.group-status-indicator.available{background:#fff3;color:#fff}.sidebar-group-content{margin-top:.25rem;margin-left:1rem;border-left:2px solid rgba(255,255,255,.1);padding-left:.75rem}.sidebar-group-content .sidebar-item{margin-bottom:.25rem;background:#ffffff08}.sidebar-group-content .sidebar-item:hover{background:#ffffff14}.sidebar-group-content .sidebar-item.active{background:#ffffff1f;border-color:#ffffff40}.content-area{flex:1;display:flex;align-items:flex-start;height:calc(100vh - 4.5rem);overflow-y:auto}.topic-container{width:100%;display:flex;flex-direction:column}.shared-code{max-width:calc(650px + 3rem);padding:2rem;position:sticky;top:0;z-index:100;mask:linear-gradient(to top,transparent,black 1.5rem);backdrop-filter:blur(15px)}.shared-code-header{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.shared-code code{max-height:min(calc(50vh - 8.5rem),250px);overflow-y:auto;font-size:.9rem}.shared-code~.questions-container{padding-top:0}.questions-container{flex:1;width:calc(100% - 4rem);display:flex;flex-direction:column;gap:2rem;padding:2rem}.questions-container>div{max-width:650px}.welcome-screen{text-align:center;max-width:650px;overflow-y:auto;padding:2rem}.welcome-screen h2{margin:0 0 1rem;font-size:2rem;font-weight:700}.welcome-screen p{margin:0 0 2rem;font-size:1.1rem;opacity:.9;line-height:1.6}.stats-overview{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap}.stat-item{text-align:center}.stat-number{display:block;font-size:2rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;-webkit-filter:drop-shadow(0px 0px 5px rgba(255,255,255,.7));filter:drop-shadow(0px 0px 5px rgba(255,255,255,.7))}.stat-label{font-size:.9rem;opacity:.8;text-transform:uppercase;letter-spacing:1px}@media (max-width: 768px){.App-header{flex-direction:column;gap:1rem;text-align:center}.App-header h1{font-size:1.5rem}.App-header p{font-size:.9rem}.App-main{flex-direction:column}.sidebar{width:100%;max-height:200px;border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}.content-area{padding:1rem}.stats-overview{gap:1rem}.stat-number{font-size:1.5rem}}.loading-screen{display:flex;align-items:center;justify-content:center;width:100%;height:calc(100vh - 4.5rem);background:linear-gradient(135deg,#667eea,#764ba2)}.loading-content{text-align:center;background:#ffffff1a;backdrop-filter:blur(10px);border-radius:20px;margin:2rem;padding:3rem;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.loading-content .loading-error p{font-size:1rem;opacity:.8;color:#f55}.loading-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 2rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-content h2{margin:0 0 1rem;font-size:1.5rem;font-weight:700;color:#fff}.loading-content p{margin:0;font-size:1rem;opacity:.8;color:#fff}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;min-height:100vh}
