*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f17;--bg2: #16161f;--bg3: #1e1e2e;--bg4: #2a2a3e;--bg5: #323248;--border: #2a2a3e;--border2: #3a3a55;--text: #c0c0d8;--muted: #6b6b8a;--bright: #f0f0ff;--accent: #6C63FF;--accent2: #3BC4A5;--red: #ff6b6b;--yellow: #ffd93d;--green: #3BC4A5;--sidebar-w: 270px;--header-h: 48px}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:13px;line-height:1.5}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:99px}.landing{min-height:100vh;display:flex;flex-direction:column;background:var(--bg);overflow-y:auto}.landing-header{position:sticky;top:0;z-index:100;background:#0f0f17f0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 24px}.landing-logo-wrap{display:flex;align-items:center;gap:10px}.landing-logo-text{font-size:16px;font-weight:800;background:linear-gradient(90deg,#6c63ff,#3bc4a5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px}.landing-main{flex:1;display:flex;flex-direction:column;align-items:center;padding:64px 24px 48px}.landing-hero{text-align:center;margin-bottom:48px;max-width:600px}.hero-badge{display:inline-block;background:#6c63ff1f;border:1px solid rgba(108,99,255,.3);color:#a0a0ff;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 14px;border-radius:99px;margin-bottom:20px;text-transform:uppercase}.hero-title{font-size:clamp(26px,5vw,40px);font-weight:800;color:var(--bright);margin-bottom:12px;letter-spacing:-1px;line-height:1.15}.hero-sub{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:28px}.hero-stats{display:flex;align-items:center;justify-content:center}.stat{display:flex;flex-direction:column;align-items:center;padding:0 24px}.stat-num{font-size:22px;font-weight:800;background:linear-gradient(135deg,#6c63ff,#3bc4a5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.stat-divider{width:1px;height:32px;background:var(--border)}.tech-cards{display:flex;gap:20px;flex-wrap:wrap;justify-content:center;width:100%;max-width:960px}.tech-card{width:280px;background:var(--bg2);border:1px solid var(--tc-border, var(--border));border-radius:16px;padding:26px 22px 20px;display:flex;flex-direction:column;align-items:center;gap:9px;position:relative;transition:transform .25s cubic-bezier(.34,1.56,.64,1),border-color .2s,box-shadow .25s;background-color:var(--tc-bg, var(--bg2))}.tc-available{cursor:pointer}.tc-available:hover{transform:translateY(-8px) scale(1.01);border-color:var(--tc);box-shadow:0 16px 48px #00000080,0 0 0 1px var(--tc)}.tc-emoji{font-size:32px;margin-bottom:2px}.tc-icon{font-size:13px;font-weight:800;font-family:monospace;opacity:.7}.tc-label{font-size:19px;font-weight:800;color:var(--bright);letter-spacing:-.5px}.tc-desc{font-size:12px;color:var(--muted);text-align:center;line-height:1.7}.tc-progress{width:100%;display:flex;flex-direction:column;gap:5px;margin-top:4px}.tc-progress-bar{height:4px;background:var(--bg4);border-radius:99px;overflow:hidden}.tc-progress-fill{height:100%;border-radius:99px;transition:width .6s cubic-bezier(.4,0,.2,1)}.tc-progress-text{font-size:11px;color:var(--muted);text-align:right}.tc-pct{color:var(--accent2);font-weight:600}.tc-footer{width:100%;display:flex;justify-content:center;margin-top:6px}.tc-btn{color:#fff;border:none;border-radius:8px;padding:9px 28px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:filter .15s,transform .1s}.tc-btn:hover{filter:brightness(1.2);transform:scale(1.03)}.roadmap-landing-btn{background:linear-gradient(135deg,#6c63ff33,#3bc4a533);border:1px solid rgba(108,99,255,.4);color:#a0a0ff;padding:6px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap}.roadmap-landing-btn:hover{background:#6c63ff4d;color:#c0c0ff}.reset-progress-btn{margin-top:32px;background:none;border:1px solid var(--border);color:var(--muted);padding:6px 16px;border-radius:6px;font-size:11px;cursor:pointer;font-family:inherit;transition:all .15s}.reset-progress-btn:hover{border-color:var(--red);color:var(--red)}.landing-footer{text-align:center;padding:20px;font-size:11px;color:var(--muted);border-top:1px solid var(--border)}.lang-switcher{display:flex;gap:2px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:2px}.lang-btn{background:none;border:none;color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.5px;padding:3px 10px;border-radius:4px;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.lang-btn.active{background:var(--accent);color:#fff}.lang-btn:not(.active):hover{color:var(--bright);background:var(--bg4)}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.header{flex-shrink:0;background:var(--bg2);border-bottom:1px solid var(--border);height:var(--header-h);display:flex;align-items:center;justify-content:space-between;padding:0 10px 0 8px;-webkit-user-select:none;user-select:none;gap:6px}.title-left{display:flex;align-items:center;gap:8px;min-width:0}.header-logo{display:flex;align-items:center;gap:8px}.header-module-info{display:flex;flex-direction:column;line-height:1.2}.header-title{font-size:13px;font-weight:700}.header-sub{font-size:10px;color:var(--muted)}.back-btn{background:none;border:none;color:var(--muted);font-size:12px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:color .15s,background .15s;font-family:inherit;white-space:nowrap;flex-shrink:0}.back-btn:hover{color:var(--bright);background:var(--bg4)}.title-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.reset-mini-btn{background:none;border:1px solid var(--border);color:var(--muted);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .15s}.reset-mini-btn:hover{border-color:var(--red);color:var(--red)}.main{flex:1;display:flex;overflow:hidden;min-height:0}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.diff-selector{display:flex;flex-direction:column;height:100%;overflow-y:auto}.diff-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 8px;font-size:10px;font-weight:700;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;border-bottom:1px solid var(--border);flex-shrink:0}.diff-total-prog{font-size:10px;color:var(--accent2);font-weight:700}.diff-group{border-bottom:1px solid var(--border)}.diff-group-header{width:100%;display:flex;align-items:center;gap:6px;padding:8px 12px;background:none;border:none;cursor:pointer;font-family:inherit;color:var(--text);transition:background .1s;border-left:2px solid transparent}.diff-group.open .diff-group-header{border-left-color:var(--diff-color, var(--accent));background:#ffffff08}.diff-group-header:hover{background:#ffffff0a}.diff-icon{font-size:12px;flex-shrink:0}.diff-label{flex:1;font-size:11px;font-weight:600;text-align:left;color:var(--bright)}.diff-prog{font-size:10px;font-weight:700}.diff-arrow{font-size:10px;color:var(--muted)}.diff-level-list{list-style:none;padding:4px 0}.diff-level-item{display:flex;align-items:center;gap:6px;padding:5px 12px 5px 20px;cursor:pointer;border-left:2px solid transparent;transition:background .1s}.diff-level-item:hover{background:#ffffff0a}.diff-level-item.active{background:#6c63ff14;border-left-color:var(--diff-color, var(--accent))}.diff-level-status{font-size:10px;width:16px;text-align:center;flex-shrink:0;color:var(--muted)}.diff-level-item.done .diff-level-status{color:var(--green)}.diff-level-item.active .diff-level-status{color:var(--diff-color, var(--accent))}.diff-level-title{font-size:11px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.diff-level-item.active .diff-level-title{color:var(--bright);font-weight:600}.diff-level-item.done .diff-level-title{color:var(--green)}.theory-panel{flex-shrink:0;border-bottom:1px solid var(--border)}.theory-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:#6c63ff0d;border:none;color:#9090dd;font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;transition:background .15s}.theory-toggle:hover{background:#6c63ff1a}.theory-arrow{font-size:10px}.theory-content{padding:14px 16px;background:var(--bg2);color:var(--text);font-size:12px;line-height:1.75;border-top:1px solid var(--border);max-height:260px;overflow-y:auto}.theory-content p{margin-bottom:10px}.theory-content p:last-child{margin-bottom:0}.theory-code{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:10px 12px;margin:8px 0;overflow-x:auto;font-size:12px;line-height:1.6}.theory-code code{font-family:Consolas,Courier New,monospace;color:#cdd6f4}.theory-inline-code{background:var(--bg4);border-radius:3px;padding:1px 5px;font-family:monospace;font-size:11px;color:#89dceb}.theory-content strong{color:var(--bright)}.theory-content em{color:var(--yellow)}.editor-preview{display:flex;flex-direction:column;height:100%;overflow:hidden}.level-header-bar{flex-shrink:0;display:flex;align-items:baseline;gap:10px;padding:10px 16px;background:var(--bg2);border-bottom:1px solid var(--border);flex-wrap:wrap}.level-header-title{font-size:13px;font-weight:700;color:var(--bright)}.level-header-desc{font-size:11px;color:var(--muted);flex:1}.ep-split{flex:1;display:flex;overflow:hidden;min-height:0}.editor-pane{display:flex;flex-direction:column;width:50%;flex-shrink:0;border-right:1px solid var(--border);overflow:hidden;background:#1e1e1e}.tab-bar{display:flex;align-items:center;background:var(--bg2);border-bottom:1px solid var(--border);height:35px;flex-shrink:0}.file-tab{display:flex;align-items:center;gap:6px;padding:0 14px;height:100%;font-size:12px;color:var(--text);background:#1e1e1e;border-right:1px solid var(--border);border-top:2px solid var(--accent)}.tab-done-mark{font-size:10px;color:var(--green);margin-left:8px;padding:1px 6px;background:#3bc4a51a;border-radius:3px}.editor-scroll{flex:1;overflow:hidden;min-height:0;display:flex;flex-direction:column}.editor-scroll .cm-editor{height:100%;font-family:Consolas,Courier New,monospace!important;font-size:13px!important}.editor-controls{flex-shrink:0;display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--bg3);border-top:1px solid var(--border);flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:filter .15s,transform .1s}.btn:hover{filter:brightness(1.15);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-run{background:linear-gradient(135deg,#1a6e38,#3bc4a5);color:#fff}.btn-check{background:linear-gradient(135deg,#4a3fc0,#6c63ff);color:#fff}.btn-hint{background:var(--bg4);color:var(--yellow);border:1px solid rgba(255,211,61,.2)}.hint-cost{font-size:10px;opacity:.7}.run-status{font-size:11px;padding:3px 8px;border-radius:4px;font-weight:500}.run-status.ok{color:var(--green);background:#3bc4a51a}.run-status.error{color:var(--red);background:#ff6b6b1a}.hint-box{flex-shrink:0;margin:0 10px 8px;background:#14120acc;border:1px solid rgba(255,211,61,.2);border-left:3px solid var(--yellow);padding:8px 12px;border-radius:6px;font-size:12px;color:var(--yellow);font-family:Consolas,monospace;line-height:1.7;white-space:pre-wrap}.hint-box-label{font-size:10px;font-weight:700;margin-bottom:4px;opacity:.7;font-family:inherit}.console-panel{flex-shrink:0;border-top:1px solid var(--border);display:flex;flex-direction:column;max-height:180px;min-height:80px;background:#0a0a12}.console-header{display:flex;align-items:center;justify-content:space-between;padding:5px 10px;background:var(--bg);border-bottom:1px solid var(--border);flex-shrink:0}.console-title{font-size:10px;color:var(--muted);font-weight:700;letter-spacing:1px;text-transform:uppercase}.console-clear{background:none;border:none;color:var(--muted);font-size:10px;cursor:pointer;font-family:inherit;padding:2px 6px;border-radius:3px;transition:color .15s}.console-clear:hover{color:var(--red)}.console-output{overflow-y:auto;flex:1;padding:4px 0}.console-line{display:flex;align-items:baseline;gap:6px;padding:2px 10px;font-family:Consolas,Courier New,monospace;font-size:12px;color:#cdd6f4;line-height:1.6}.console-line.err{color:var(--red);background:#ff6b6b0f;border-left:2px solid var(--red);padding-left:8px}.console-line.warn{color:var(--yellow)}.console-arrow{color:var(--accent2);flex-shrink:0;font-size:11px}.console-empty{color:var(--muted);font-style:italic;padding:6px 12px;display:block;font-size:11px}.preview-pane{flex:1;display:flex;flex-direction:column;overflow:hidden}.preview-tab-bar{display:flex;align-items:center;background:var(--bg2);border-bottom:1px solid var(--border);height:35px;flex-shrink:0;padding:0 12px;gap:10px}.preview-tab{display:flex;align-items:center;gap:4px}.preview-tab-dot{width:10px;height:10px;border-radius:50%;background:#ff5f56;flex-shrink:0}.preview-tab-dot.orange{background:#ffbd2e}.preview-tab-dot.green{background:#27c93f}.preview-tab-label{font-size:11px;color:var(--muted);margin-left:6px}.preview-scroll{flex:1;overflow:auto}.preview-scroll.dark-mode{background:#0f0f17}.preview-scroll.html-mode{background:#f5f5f5}.preview-root.dark{background:#0f0f17;min-height:100%;padding:20px;color:var(--text)}.preview-root.dark .stage{padding:16px;border:1px dashed rgba(255,255,255,.1);min-height:80px;border-radius:6px;background:#ffffff08}.preview-root.dark .target{display:inline-block}.html-preview-iframe{width:100%;height:100%;border:none;background:#fff;display:block}.score-display{display:flex;align-items:center;gap:5px;background:var(--bg3);padding:4px 10px;border-radius:6px;border:1px solid var(--border)}.score-label{font-size:10px;color:var(--muted)}.score-value{font-weight:800;font-size:13px;background:linear-gradient(135deg,#6c63ff,#3bc4a5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.score-bonus{font-size:11px;background:var(--green);color:#000;padding:1px 6px;border-radius:99px;animation:bonus-pop 1.1s ease forwards}@keyframes bonus-pop{0%{transform:translateY(0) scale(.6);opacity:0}30%{transform:translateY(-6px) scale(1.3);opacity:1}to{transform:translateY(-14px) scale(1);opacity:0}}.progress-wrap{display:flex;align-items:center;gap:6px}.progress-line{width:80px;height:4px;background:var(--bg4);border-radius:99px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .5s;border-radius:99px}.progress-text{font-size:11px;color:var(--muted)}.trophy-bar{display:flex;gap:2px;flex-wrap:wrap;max-width:80px}.trophy{font-size:12px}.trophy.pop{animation:trophy-pop .8s ease forwards}@keyframes trophy-pop{0%{transform:scale(.3) rotate(-20deg);opacity:0}60%{transform:scale(1.5) rotate(10deg);opacity:1}to{transform:scale(1) rotate(0)}}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;background:#3bc4a51f;color:var(--green);border:1px solid rgba(59,196,165,.3)}.toasts-root{position:fixed;right:16px;bottom:24px;display:flex;flex-direction:column;gap:8px;z-index:9999}.toast{background:var(--bg3);color:var(--text);padding:10px 16px;border-radius:8px;font-size:12px;border:1px solid var(--border);border-left:3px solid var(--accent);box-shadow:0 4px 24px #0009;animation:toast-slide .25s ease;max-width:320px}@keyframes toast-slide{0%{transform:translate(30px);opacity:0}to{transform:translate(0);opacity:1}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:16px;animation:overlay-in .2s ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--bg2);border:1px solid var(--border2);border-radius:20px;padding:32px 28px;max-width:420px;width:100%;text-align:center;box-shadow:0 24px 80px #000000b3;animation:modal-in .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modal-in{0%{transform:scale(.85) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.modal-icon{font-size:48px;margin-bottom:12px;animation:icon-bounce .5s cubic-bezier(.34,1.56,.64,1) .1s both}@keyframes icon-bounce{0%{transform:scale(0)}to{transform:scale(1)}}.modal-title{font-size:20px;font-weight:800;margin-bottom:8px}.modal-title.success{background:linear-gradient(135deg,#6c63ff,#3bc4a5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-title.fail{color:var(--yellow)}.modal-level-name{font-size:13px;color:var(--muted);margin-bottom:16px}.modal-xp-badge{display:inline-block;background:linear-gradient(135deg,#6c63ff33,#3bc4a533);border:1px solid rgba(108,99,255,.4);color:#a0c0ff;font-size:16px;font-weight:800;padding:6px 20px;border-radius:99px;margin-bottom:12px}.modal-motivate{font-size:13px;color:var(--muted);margin-bottom:24px;line-height:1.6}.modal-error-block{background:#ff6b6b14;border:1px solid rgba(255,107,107,.2);border-left:3px solid var(--red);border-radius:8px;padding:10px 14px;margin-bottom:14px;text-align:left}.modal-error-label{font-size:11px;color:var(--red);font-weight:700;display:block;margin-bottom:4px}.modal-error-text{font-family:Consolas,monospace;font-size:11px;color:#f99;word-break:break-word;display:block}.modal-tip-block{background:#ffd33d0f;border:1px solid rgba(255,211,61,.15);border-left:3px solid var(--yellow);border-radius:8px;padding:10px 14px;margin-bottom:20px;text-align:left}.modal-tip-label{font-size:11px;color:var(--yellow);font-weight:700;display:block;margin-bottom:4px}.modal-tip-text{font-size:12px;color:var(--text);line-height:1.6}.modal-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.modal-btn{padding:10px 24px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;border:none;transition:filter .15s,transform .1s}.modal-btn:hover{filter:brightness(1.15);transform:translateY(-1px)}.modal-btn.primary{background:linear-gradient(135deg,#5a4fcf,#6c63ff);color:#fff}.modal-btn.secondary{background:var(--bg4);color:var(--text);border:1px solid var(--border2)}.roadmap-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column;overflow-y:auto}.roadmap-content{flex:1;max-width:720px;margin:0 auto;width:100%;padding:32px 24px 60px}.roadmap-hero{margin-bottom:32px}.roadmap-back-btn{background:none;border:1px solid var(--border);color:var(--muted);padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer;font-family:inherit;margin-bottom:20px;transition:all .15s}.roadmap-back-btn:hover{color:var(--bright);border-color:var(--border2)}.roadmap-title{font-size:clamp(24px,4vw,36px);font-weight:800;color:var(--bright);letter-spacing:-.5px;margin-bottom:8px}.roadmap-sub{font-size:14px;color:var(--muted)}.roadmap-legend{display:flex;gap:20px;margin-bottom:32px}.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-dot.covered{background:var(--green)}.legend-dot.soon{background:var(--muted)}.roadmap-timeline{display:flex;flex-direction:column}.roadmap-step{display:flex;gap:16px}.roadmap-connector{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:48px}.roadmap-node{width:44px;height:44px;border-radius:12px;background:#ffffff0d;border:2px solid var(--step-color, var(--border));display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;box-shadow:0 0 12px #6c63ff1a}.roadmap-step.covered .roadmap-node{background:#3bc4a514;border-color:var(--step-color);box-shadow:0 0 16px #3bc4a526}.roadmap-step.final .roadmap-node{background:#ffd33d14;border-color:var(--step-color);animation:pulse-node 2s ease-in-out infinite}@keyframes pulse-node{0%,to{box-shadow:0 0 12px #ffd33d33}50%{box-shadow:0 0 28px #ffd33d80}}.roadmap-line{width:2px;flex:1;background:linear-gradient(to bottom,var(--border),var(--border));margin:4px 0;min-height:24px}.roadmap-step.covered .roadmap-line{background:linear-gradient(to bottom,var(--green),var(--border))}.roadmap-card{flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px 18px;margin-bottom:12px;transition:border-color .2s,box-shadow .2s}.roadmap-step.covered .roadmap-card{border-color:#3bc4a54d;background:#3bc4a508}.roadmap-step.final .roadmap-card{border-color:#ffd33d4d;background:#ffd33d08}.roadmap-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.roadmap-phase{font-size:10px;color:var(--muted);font-weight:600;letter-spacing:.5px;text-transform:uppercase}.roadmap-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px}.covered-badge{background:#3bc4a526;color:var(--green);border:1px solid rgba(59,196,165,.3)}.soon-badge{background:var(--bg4);color:var(--muted)}.final-badge{background:#ffd33d26;color:var(--yellow);border:1px solid rgba(255,211,61,.3)}.roadmap-card-title{font-size:15px;font-weight:700;margin-bottom:10px}.roadmap-items{list-style:none;display:flex;flex-direction:column;gap:5px;margin-bottom:10px}.roadmap-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}.roadmap-item-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.roadmap-time{font-size:11px;color:var(--muted);padding-top:8px;border-top:1px solid var(--border)}.roadmap-footer-note{margin-top:32px;text-align:center}.roadmap-footer-card{background:var(--bg2);border:1px solid rgba(108,99,255,.3);border-radius:16px;padding:24px;display:inline-block;max-width:400px}.roadmap-footer-card p{font-size:14px;color:var(--text);line-height:1.6}@media (max-width: 1024px){:root{--sidebar-w: 240px}}@media (max-width: 768px){:root{--sidebar-w: 200px}.tech-card{width:min(100%,320px)}.hero-title{font-size:26px}.landing-main{padding:48px 16px 32px}.landing-hero{margin-bottom:36px}}@media (max-width: 600px){html,body,#root{height:auto;overflow:visible}.app{height:auto;overflow:visible;min-height:100vh}.main{flex-direction:column;overflow:visible;height:auto}.sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border);max-height:200px;overflow-y:auto}.content{overflow:visible;height:auto}.editor-preview{height:auto;overflow:visible}.ep-split{flex-direction:column;overflow:visible;height:auto}.editor-pane{width:100%;border-right:none;border-bottom:1px solid var(--border);overflow:visible;height:auto}.editor-scroll{height:260px;overflow:hidden}.preview-pane{height:300px;min-height:0}.html-preview-iframe{height:300px}.title-right{gap:4px}.trophy-bar{display:none}.progress-line{width:50px}.header-module-info{display:none}.back-btn{font-size:11px;padding:3px 6px}.landing-main{padding:36px 12px 24px}.hero-title{font-size:22px}.tech-cards{gap:14px}.tech-card{width:100%;max-width:360px}.landing-header{padding:0 14px}.modal-card{padding:24px 18px}.modal-icon{font-size:36px}.modal-title{font-size:17px}.roadmap-content{padding:24px 16px 48px}.roadmap-node{width:36px;height:36px;font-size:16px}.roadmap-connector{width:36px}}@media (max-width: 400px){.progress-wrap,.score-display{display:none}}
