:root{--bg: #f0f4f8;--card: #ffffff;--primary: #4f46e5;--secondary: #10b981;--accent: #f59e0b;--text: #1f2937;--text-light: #6b7280;--border: #e5e7eb;--editor-bg: #1e293b;--editor-text: #f8fafc;--hint-bg: #fffbeb;--hint-text: #92400e;--hint-border: #fde68a;--radius: 12px;--font-stack: "Helvetica Neue", Arial, sans-serif}*{box-sizing:border-box;margin:0;padding:0}*:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}body{font-family:var(--font-stack);background-color:var(--bg);color:var(--text);line-height:1.6}#app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{height:70px;background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 32px;flex-shrink:0}.course-selector{background:var(--bg);border:2px solid var(--border);border-radius:8px;padding:6px 12px;font-size:16px;font-weight:700;color:var(--text);cursor:pointer;font-family:inherit;outline:none;transition:all .2s ease}.course-selector:hover{border-color:var(--primary)}.app-title-text{display:none}@media(min-width:600px){.app-title-text{display:inline}}.app-nav{display:flex;gap:12px}.nav-btn{background:transparent;border:none;padding:8px 16px;font-size:15px;font-weight:700;color:var(--text-light);cursor:pointer;border-radius:8px;transition:all .2s;font-family:inherit}.nav-btn:hover{background:var(--bg);color:var(--text)}.nav-btn.active{background:var(--primary);color:#fff}.app-header h1{font-weight:800;font-size:24px;color:var(--primary);display:flex;align-items:center;gap:10px}.xp-badge{background:#e0e7ff;color:var(--primary);padding:6px 16px;border-radius:999px;font-weight:700;font-size:14px}.app-main{display:flex;flex:1;overflow:hidden}.sidebar{width:280px;background:var(--card);border-right:1px solid var(--border);padding:24px;display:flex;flex-direction:column;gap:20px;overflow-y:auto}.sidebar h2{font-size:14px;color:var(--text-light);margin-bottom:12px;text-transform:uppercase;letter-spacing:.05em;font-weight:700}.level-list{list-style:none;display:flex;flex-direction:column;gap:12px}.level-item{padding:12px;border-radius:12px;border:1px solid var(--border);display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .2s;background:var(--card);font-weight:600;font-size:14px}.level-item:not(.locked):not(.active){border-color:var(--secondary);background:#f0fdf4}.level-item.active{border-color:var(--primary);background:#eef2ff;box-shadow:0 0 0 2px var(--primary)}.level-item.locked{opacity:.5;background:#f9fafb;cursor:not-allowed}.level-item .icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;background:#e2e8f0}.level-item:not(.locked):not(.active) .icon{background:var(--secondary)}.level-item.active .icon{background:var(--primary)}.content{flex:1;padding:32px;display:grid;grid-template-rows:auto 1fr;gap:24px;overflow-y:auto}.level-header{display:flex;align-items:center;gap:1rem;margin-bottom:8px}.level-header h2{font-size:28px}.badge{background:#e0e7ff;color:var(--primary);padding:6px 16px;border-radius:9999px;font-size:14px;font-weight:700}.level-card{display:flex;flex-direction:column;gap:24px;min-height:0}.explanation{color:var(--text-light);line-height:1.5;font-size:16px}.explanation code,.task-box code{background-color:#f1f5f9;padding:2px 6px;border-radius:4px;font-family:Courier New,Courier,monospace;color:var(--primary)}.task-box{background:var(--card);border-radius:16px;border:1px solid var(--border);padding:20px;box-shadow:0 4px 6px -1px #0000000d;font-size:16px;line-height:1.5}.task-box strong{color:var(--primary);display:block;margin-bottom:8px;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.editor-container{background:var(--card);border-radius:16px;border:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 4px 6px -1px #0000000d}.editor-split{display:flex;flex-direction:column;gap:16px}@media(min-width:900px){.editor-split{flex-direction:row;align-items:stretch}.editor-split .editor-container{flex:1}.editor-split .output-container{flex:.8}}.output-container{background:#0f172a;border-radius:16px;border:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;color:#f8fafc}.output-container:before{content:"Console Output";padding:12px 20px;background:#1e293b;border-bottom:1px solid #334155;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8}#console-output{padding:20px;font-family:Courier New,Courier,monospace;font-size:14px;line-height:1.6;overflow-y:auto;min-height:200px}.log-line{border-bottom:1px solid #1e293b;padding-bottom:4px;margin-bottom:4px}.log-error{color:#f87171}.editor-container:before{content:"Code Editor";padding:12px 20px;background:#f8fafb;border-bottom:1px solid var(--border);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light)}#code-editor,#practice-editor{width:100%;min-height:400px;background:var(--editor-bg);color:var(--editor-text);padding:20px;font-family:Courier New,Courier,monospace;font-size:14px;line-height:1.6;border:none;resize:vertical}#code-editor:focus,#practice-editor:focus{outline:none;box-shadow:inset 0 0 0 2px var(--primary)}.course-card:hover{transform:translateY(-4px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.hint-btn{align-self:flex-start;padding:8px 16px;border-radius:10px;font-weight:600;font-size:14px;background:var(--hint-bg);color:var(--hint-text);border:1px solid var(--hint-border);cursor:pointer;transition:opacity .2s}.hint-btn:hover{opacity:.8}.hint-text{background:var(--hint-bg);color:var(--hint-text);padding:16px;border-radius:12px;border:1px solid var(--hint-border);font-family:Courier New,Courier,monospace;font-size:14px;line-height:1.5}.hint-text pre{margin:0}.hidden{display:none!important}.action-bar{display:flex;gap:16px;align-items:center}.site-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:24px;padding:32px 24px;margin-top:auto;border-top:1px solid var(--border);background:var(--card)}.footer-link{color:var(--text-light);font-size:14px;font-weight:500;cursor:pointer;background:none;border:none;padding:0;text-decoration:underline;text-decoration-color:transparent;transition:all .2s}.footer-link:hover{color:var(--text);text-decoration-color:var(--text)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal-content{background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:32px;width:100%;max-width:800px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-close{float:right;background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-light)}.modal-close:hover{color:var(--text)}button.primary-btn,button.secondary-btn{padding:12px 24px;border-radius:10px;font-weight:600;cursor:pointer;border:none;font-size:15px;display:flex;align-items:center;gap:8px;transition:opacity .2s}button.primary-btn:hover,button.secondary-btn:hover{opacity:.9}.primary-btn{background:var(--primary);color:#fff}.secondary-btn{background:var(--secondary);color:#fff}.feedback-box{padding:16px 20px;border-radius:12px;font-family:Courier New,Courier,monospace;font-size:14px;display:flex;align-items:flex-start;gap:12px;background:#f8fafc;border:1px solid var(--border)}.feedback-box.success{background:#f0fdf4;color:var(--secondary);border-color:#bbf7d0}.feedback-box.error{background:#fef2f2;color:#ef4444;border-color:#fecaca}.feedback-box strong{font-size:18px}.markdown-body{font-family:inherit}.markdown-body p{margin-bottom:12px}.markdown-body code{background:#f1f5f9;padding:2px 4px;border-radius:4px;font-family:monospace;color:#db2777}.markdown-body pre{background:#1e293b;padding:12px;border-radius:8px;color:#f8fafc;font-family:monospace;margin-bottom:12px;overflow-x:auto}.markdown-body pre code{background:transparent;padding:0;color:inherit;border:none}.pulse{animation:pulse 1.5s infinite}@keyframes pulse{0%{opacity:.4}50%{opacity:1}to{opacity:.4}}@media(max-width:768px){.app-main{flex-direction:column}.sidebar{width:100%;max-height:200px;border-right:none;border-bottom:1px solid var(--border)}.content{padding:20px}.action-bar{flex-direction:column;align-items:stretch}}
