:root,[data-theme=light]{--bg:#f8fafc;--card:#ffffff;--surface:#f1f5f9;--surface-alt:#e2e8f0;--border:#cbd5e1;--border-light:#e2e8f0;--muted:#64748b;--text:#0f172a;--brand:#0ea5e9;--brand-light:#e0f2fe;--brand-soft:#f0f9ff;--accent:#06b6d4;--accent-soft:#ecfeff;--success:#10b981;--success-soft:#f0fdf4;--warning:#f59e0b;--warning-soft:#fffbeb;--math-primary:#3b82f6;--math-secondary:#dbeafe;--math-bg:rgba(59,130,246,0.06);--data-primary:#06b6d4;--data-secondary:#cffafe;--data-bg:rgba(6,182,212,0.06);--science-primary:#0ea5e9;--science-secondary:#e0f2fe;--science-bg:rgba(14,165,233,0.06);--coding-primary:#64748b;--coding-secondary:#f1f5f9;--coding-bg:rgba(100,116,139,0.06);--header-bg:rgba(255,255,255,0.75);--body-gradient:linear-gradient(180deg,#ffffff,#f7fbff 40%,#f2f6fb);--shadow-color:rgba(0,0,0,0.1)}[data-theme=dark]{--bg:#0f172a;--card:#1e293b;--surface:#1e293b;--surface-alt:#334155;--border:#334155;--border-light:#475569;--muted:#94a3b8;--text:#f1f5f9;--brand:#38bdf8;--brand-light:#0c4a6e;--brand-soft:#0c4a6e33;--accent:#22d3ee;--accent-soft:#164e6333;--success:#34d399;--success-soft:#064e3b33;--warning:#fbbf24;--warning-soft:#78350f33;--math-primary:#60a5fa;--math-secondary:#1e3a5f;--math-bg:rgba(96,165,250,0.08);--data-primary:#22d3ee;--data-secondary:#164e63;--data-bg:rgba(34,211,238,0.08);--science-primary:#38bdf8;--science-secondary:#0c4a6e;--science-bg:rgba(56,189,248,0.08);--coding-primary:#94a3b8;--coding-secondary:#334155;--coding-bg:rgba(148,163,184,0.08);--header-bg:rgba(15,23,42,0.85);--body-gradient:linear-gradient(180deg,#0f172a,#131c31 40%,#111827);--shadow-color:rgba(0,0,0,0.3)}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji;background:var(--body-gradient);color:var(--text);min-height:100vh;transition:background .3s ease,color .3s ease}.container{max-width:960px;margin:0 auto;padding:1rem}.site-header{border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:var(--header-bg);z-index:10;padding:.75rem 0;transition:background .3s ease}.header-content{display:flex;align-items:center;justify-content:space-between;gap:1rem}.header-actions,.profile-key-manager{display:flex;align-items:center;gap:.5rem}.profile-key-manager{position:relative}.profile-key-menu{position:absolute;top:calc(100% + .5rem);right:0;z-index:30;width:220px;border-radius:10px;border:1px solid var(--border);background:var(--card);box-shadow:0 10px 28px var(--shadow-color);padding:.6rem;display:grid;grid-gap:.45rem;gap:.45rem}.profile-key-menu .btn{width:100%;margin-left:0;text-align:left}.profile-key-menu .btn+.btn{margin-left:0}.profile-key-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.profile-key-hint{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.78rem;word-break:break-all}.profile-modal-overlay{position:fixed;inset:0;z-index:120;background:rgba(15,23,42,.55);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:1rem}.profile-modal{width:min(540px,94vw);border:1px solid var(--border);border-radius:12px;background:var(--card);padding:1rem}.profile-input{width:100%;padding:.6rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text)}.profile-error{border:1px solid #ef4444;background:#ef44441a;color:#b91c1c;border-radius:8px;padding:.55rem .65rem;font-size:.9rem}.profile-key-reveal{border:1px dashed var(--border);border-radius:8px;background:var(--surface);padding:.75rem;word-break:break-all;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.brand{color:var(--text);text-decoration:none;font-weight:700;letter-spacing:.5px;flex-shrink:0}.site-footer{border-top:1px solid var(--border);margin-top:3rem;padding:1rem 0;color:var(--muted);font-size:.9rem}h1{font-size:1.8rem;margin:1rem 0}h2{font-size:1.2rem;margin:.5rem 0}p{color:var(--muted);line-height:1.6}.main-page{text-align:center;max-width:1200px;margin:0 auto}.hero{margin-bottom:3rem;padding:2rem 0}.hero h1{font-size:2.5rem;margin-bottom:1rem}.hero h1,.hero p{color:var(--text)}.hero p{font-size:1.1rem;max-width:600px;margin:0 auto;opacity:.9}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1rem;gap:1rem;margin-top:1rem}@media (max-width:640px){.grid{grid-template-columns:1fr;gap:.75rem}.container{padding:.75rem}.hero h1{font-size:2rem}.hero p{font-size:1rem}.card{padding:.75rem}.card[style*=borderLeft]{padding:1rem}.btn{padding:.5rem .75rem;font-size:.9rem}.crumbs{font-size:.85rem;gap:.25rem}.nav{flex-direction:column;gap:.5rem;align-items:stretch}.nav .spacer{display:none}.tags{gap:.25rem}.tag{font-size:.7rem;padding:.15rem .4rem}}.grid>*{animation:fadeInUp .4s ease-out forwards;opacity:0;transform:translateY(10px)}.grid>:first-child{animation-delay:.05s}.grid>:nth-child(2){animation-delay:.1s}.grid>:nth-child(3){animation-delay:.15s}.grid>:nth-child(4){animation-delay:.2s}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.focus-card{position:relative;overflow:hidden}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:1rem}.card.hover{transition:transform .12s ease,border-color .12s ease}.card.hover:hover{transform:translateY(-2px);border-color:var(--brand-light)}[data-theme=math] .card{border-left:4px solid var(--math-primary)}[data-theme=data] .card{border-left:4px solid var(--data-primary)}[data-theme=science] .card{border-left:4px solid var(--science-primary)}[data-theme=coding] .card{border-left:4px solid var(--coding-primary)}[data-theme=robotics] .card{border-left:4px solid #f97316}.card.interactive{cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.card.interactive:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.15)}.card.interactive:active{transform:translateY(0)}.tags{display:flex;gap:.5rem;margin:.5rem 0 .75rem;flex-wrap:wrap}.tag{font-size:.75rem;padding:.2rem .5rem;border-radius:999px;background:var(--brand-soft);color:var(--brand);border:1px solid var(--border);transition:all .2s ease;cursor:default;position:relative}.tag:hover{transform:scale(1.02)}.tags .tag:nth-child(8n+1){background:#e0e7ff;color:#3730a3;border-color:#c7d2fe}.tags .tag:nth-child(8n+2){background:#e9d5ff;color:#6b21a8;border-color:#d8b4fe}.tags .tag:nth-child(8n+3){background:#dbeafe;color:#1d4ed8;border-color:#bfdbfe}.tags .tag:nth-child(8n+4){background:#dcfce7;color:#065f46;border-color:#bbf7d0}.tags .tag:nth-child(8n+5){background:#ffe4e6;color:#9f1239;border-color:#fecdd3}.tags .tag:nth-child(8n+6){background:#ccfbf1;color:#115e59;border-color:#99f6e4}.tags .tag:nth-child(8n+7){background:#fde68a;color:#92400e;border-color:#fcd34d}.tags .tag:nth-child(8n+8){background:#f1f5f9;color:#0f172a;border-color:#e2e8f0}.btn{display:inline-block;padding:.6rem .9rem;border-radius:10px;border:2px solid var(--border);color:var(--text);text-decoration:none;background:var(--surface);cursor:pointer}.btn.primary{background:var(--brand);border-color:var(--brand);color:#ffffff}.btn.success{background:var(--accent);border-color:var(--accent);color:#ffffff}.btn.danger{background:#ef4444;border-color:#ef4444;color:#ffffff}.btn.disabled{opacity:.5;pointer-events:none}.btn+.btn{margin-left:.5rem}.btn{transition:all .2s ease;position:relative;overflow:hidden;font-weight:500}.btn:hover{transform:translateY(-1px);box-shadow:0 2px 10px rgba(15,23,42,.06);border-color:var(--brand)}.btn.danger:hover,.btn.primary:hover,.btn.success:hover{filter:brightness(1.1);border-color:transparent}.btn:active{transform:translateY(0)}[data-theme=math] .btn.primary{background:var(--math-primary);border-color:var(--math-primary);color:#fff}[data-theme=data] .btn.primary{background:var(--data-primary);border-color:var(--data-primary);color:#003}[data-theme=science] .btn.primary{background:var(--science-primary);border-color:var(--science-primary);color:#003}[data-theme=coding] .btn.primary{background:var(--coding-primary);border-color:var(--coding-primary);color:#003}[data-theme=robotics] .btn.primary{background:#f97316;border-color:#f97316;color:#fff}.actions{margin-top:.75rem}.read-aloud-host{position:relative;padding-right:2.6rem}.read-aloud-btn{padding:.2rem .45rem;min-width:2rem;height:2rem;display:inline-flex;align-items:center;justify-content:center;line-height:1;font-size:.95rem}.read-aloud-inline-btn{position:absolute;top:0;right:0}.crumbs{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.95rem}.crumbs a{color:var(--brand);text-decoration:none}.crumbs span{opacity:.7}.lesson{margin-top:.5rem;display:grid;grid-gap:1rem;gap:1rem}.lesson .lede{color:#334155}.lesson-meta{margin-bottom:.85rem;padding:.75rem;border:1px solid var(--border);border-radius:10px;background:var(--surface)}.lesson-meta p{margin:0 0 .35rem}.lesson-meta p:last-child{margin-bottom:0}.progress-container{height:4px;background:#e5e7eb;border-radius:2px;overflow:hidden;margin:1rem 0}.progress-bar{height:100%;background:var(--brand);border-radius:2px;transition:width .5s ease}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.pulse{animation:pulse 1.5s infinite}.color-transition{transition:color .2s ease,background-color .2s ease,border-color .2s ease}.nav{display:flex;align-items:center;margin-top:.5rem}.nav .spacer{flex:1 1}.list{margin:1rem 0;padding-left:1.25rem}.list-item{margin:.4rem 0}.list-item a{color:var(--brand);text-decoration:none}mark{background:var(--brand-light);color:var(--text);padding:0 .2rem;border-radius:4px}.callout{border:1px solid var(--border);border-left-width:4px;padding:.75rem;border-radius:10px;background:var(--surface)}.callout .callout-title{font-weight:700;margin-bottom:.25rem}.callout.info{border-left-color:var(--brand);background:var(--brand-soft)}.callout.success{border-left-color:var(--accent);background:var(--accent-soft)}.callout.warn{border-left-color:var(--warning);background:var(--warning-soft)}.callout.tip{border-left-color:var(--brand);background:var(--brand-light)}.tags .tag:nth-child(5n+1){background:var(--brand-soft);color:var(--brand);border-color:var(--brand-light)}.tags .tag:nth-child(5n+2){background:var(--surface-alt);color:var(--muted);border-color:var(--border)}.tags .tag:nth-child(5n+3){background:var(--accent-soft);color:var(--accent);border-color:var(--accent-soft)}.tags .tag:nth-child(5n+4){background:var(--surface);color:var(--text);border-color:var(--border-light)}.tags .tag:nth-child(5n+5){background:var(--brand-light);color:var(--brand);border-color:var(--brand-soft)}:focus{border-radius:4px}.btn:focus,:focus,button:focus{outline:2px solid var(--brand);outline-offset:2px}.skip-to-content{position:absolute;top:-40px;left:6px;background:var(--brand);color:white;padding:8px;text-decoration:none;border-radius:4px;z-index:1000}.skip-to-content:focus{top:6px}.loading-shimmer{background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 1.5s infinite}.page-transition-enter{opacity:0;transform:translateY(20px)}.page-transition-enter-active{opacity:1;transform:translateY(0);transition:opacity .3s ease,transform .3s ease}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn:disabled:hover{transform:none!important;box-shadow:none!important}.progress-container{position:relative;overflow:visible}.progress-bar:after{content:"";position:absolute;top:0;right:0;width:4px;height:100%;background:var(--brand);border-radius:2px;opacity:.8}html{scroll-behavior:smooth}@media (hover:none) and (pointer:coarse){.card.hover:hover{transform:none}.card.interactive:active{transform:scale(.95);transition:transform .2s}}.flashcard-scene{perspective:1000px;width:100%;cursor:pointer;outline:none}.flashcard-inner{position:relative;width:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.flashcard-inner.is-flipped{transform:rotateY(180deg)}.flashcard-face{position:relative;width:100%;backface-visibility:hidden;-webkit-backface-visibility:hidden;padding:2.5rem 1.5rem!important;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:200px}.flashcard-back{position:absolute;top:0;left:0;height:100%;transform:rotateY(180deg)}.flashcard-content{font-weight:700;font-size:1.25rem;margin-bottom:1rem}.flashcard-hint{color:var(--muted);font-size:.85rem;opacity:.8;margin-top:auto}.search-container{position:relative;width:100%;max-width:400px}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:.5rem 2rem .5rem .75rem;border:1px solid var(--border);border-radius:8px;background:var(--card);color:var(--text);font-size:.9rem;transition:border-color .2s ease,box-shadow .2s ease}.search-input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.search-input::placeholder{color:var(--muted)}.search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;font-size:1.2rem;line-height:1;padding:.25rem;border-radius:4px;transition:color .2s ease,background-color .2s ease}.search-clear:hover{color:var(--text);background:var(--surface)}.search-results{position:absolute;top:100%;left:0;right:0;background:var(--card);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.1);max-height:400px;overflow-y:auto;z-index:1000;margin-top:.25rem}.search-result-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border-bottom:1px solid var(--border);cursor:pointer;transition:background-color .2s ease}.search-result-item:last-child{border-bottom:none}.search-result-item.active,.search-result-item:hover{background:var(--surface)}.search-result-icon{font-size:1.1rem;margin-top:.1rem;flex-shrink:0}.search-result-content{flex:1 1;min-width:0}.search-result-title{font-weight:600;color:var(--text);margin-bottom:.25rem;line-height:1.3}.search-result-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem;font-size:.8rem;color:var(--muted)}.search-result-type{background:var(--brand-soft);color:var(--brand);padding:.1rem .4rem;border-radius:4px;font-weight:500}.search-result-area{color:var(--muted)}.search-result-description{font-size:.85rem;color:var(--muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.search-no-results{padding:1rem;text-align:center}.search-no-results-text{color:var(--muted);margin-bottom:1rem}.search-suggestions-title{font-size:.85rem;color:var(--muted);margin-bottom:.5rem}.search-suggestions-list{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.search-suggestion-item{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.25rem .5rem;border-radius:4px;font-size:.8rem;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.search-suggestion-item:hover{background:var(--brand-soft);border-color:var(--brand);color:var(--brand)}@media (max-width:768px){.header-content{display:grid;grid-template-columns:1fr auto;grid-template-areas:"logo actions" "search search";grid-gap:.75rem;gap:.75rem;align-items:center}.brand{grid-area:logo}.header-actions{grid-area:actions;justify-content:flex-end}.search-container{grid-area:search;width:100%;max-width:none;max-width:100%}.search-input{font-size:16px}.search-results{max-height:300px}.search-result-item{padding:.5rem;gap:.5rem}.search-result-meta{flex-direction:column;align-items:flex-start;gap:.25rem}}.welcome-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:rgba(15,23,42,.55);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:welcomeOverlayIn .35s ease-out}.welcome-overlay.welcome-exit{animation:welcomeOverlayOut .35s ease-in forwards}@keyframes welcomeOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes welcomeOverlayOut{0%{opacity:1}to{opacity:0}}.welcome-modal{background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:0 24px 64px rgba(0,0,0,.18);padding:2.5rem 2rem 2rem;max-width:520px;width:92vw;max-height:90vh;overflow-y:auto;animation:welcomeModalIn .4s cubic-bezier(.16,1,.3,1)}.welcome-modal.welcome-modal-exit{animation:welcomeModalOut .3s ease-in forwards}@keyframes welcomeModalIn{0%{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes welcomeModalOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(16px) scale(.97)}}.welcome-steps{display:flex;justify-content:center;gap:.5rem;margin-bottom:1.75rem}.welcome-step-dot{width:10px;height:10px;border-radius:50%;background:var(--border);transition:all .3s ease}.welcome-step-dot.active{background:var(--brand);transform:scale(1.3)}.welcome-step-dot.done{background:var(--success)}.welcome-content{text-align:center}.welcome-fade-in{animation:welcomeFadeIn .3s ease-out}@keyframes welcomeFadeIn{0%{opacity:0;transform:translateX(12px)}to{opacity:1;transform:translateX(0)}}.welcome-icon{font-size:3rem;margin-bottom:.75rem}.welcome-title{font-size:1.6rem;font-weight:700}.welcome-text,.welcome-title{color:var(--text);margin:0 0 .75rem}.welcome-text{line-height:1.6;font-size:1rem}.welcome-interest-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem;margin:1.25rem 0;text-align:left}.welcome-interest-card{background:var(--surface);border:2px solid var(--border);border-radius:12px;padding:1rem;cursor:pointer;transition:all .2s ease;text-align:left;font-family:inherit;color:inherit}.welcome-interest-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.08)}.welcome-interest-card.selected,.welcome-interest-card:hover{border-color:var(--card-color,var(--brand));background:var(--card)}.welcome-interest-card.selected{box-shadow:0 0 0 3px color-mix(in srgb,var(--card-color,var(--brand)) 20%,transparent)}.welcome-interest-title{font-weight:700;font-size:1rem;margin-bottom:.25rem}.welcome-interest-desc{font-size:.8rem;color:var(--muted);line-height:1.4;margin-bottom:.35rem}.welcome-interest-count{font-size:.75rem;color:var(--muted);opacity:.7}.welcome-level-grid{display:flex;flex-direction:column;gap:.6rem;margin:1.25rem 0;text-align:left}.welcome-level-card{display:flex;align-items:center;gap:.85rem;background:var(--surface);border:2px solid var(--border);border-radius:12px;padding:.85rem 1rem;cursor:pointer;transition:all .2s ease;text-align:left;font-family:inherit;color:inherit}.welcome-level-card:hover{border-color:var(--brand);background:var(--card);transform:translateX(4px)}.welcome-level-card.selected{border-color:var(--brand);background:var(--brand-soft);box-shadow:0 0 0 3px var(--brand-light)}.welcome-level-icon{font-size:1.5rem;flex-shrink:0}.welcome-level-label{font-weight:600;font-size:.95rem;color:var(--text)}.welcome-level-desc{font-size:.8rem;color:var(--muted);line-height:1.3}.welcome-actions{display:flex;flex-direction:column;align-items:center;gap:.6rem;margin-top:1.5rem}.welcome-btn{width:100%;max-width:300px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border-radius:10px}.welcome-btn-secondary{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:.85rem;padding:.4rem .75rem;border-radius:6px;transition:color .2s ease;font-family:inherit}.welcome-btn-secondary:hover{color:var(--text)}.start-here-section{margin-bottom:2rem;animation:fadeInUp .5s ease-out}.start-here-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.start-here-title{font-size:1.2rem;font-weight:700;color:var(--text);margin:0}.start-here-subtitle{font-size:.85rem;color:var(--muted);margin:0}.start-here-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-gap:1rem;gap:1rem}.start-here-card{background:var(--card);border:2px solid var(--border);border-radius:12px;padding:1.25rem;transition:all .2s ease;position:relative;overflow:hidden}.start-here-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--card-color,var(--brand))}.start-here-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.08);border-color:var(--card-color,var(--brand))}.start-here-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:999px;background:var(--brand-soft);color:var(--brand);margin-bottom:.5rem}@media (max-width:640px){.welcome-modal{padding:1.75rem 1.25rem 1.5rem;border-radius:12px}.welcome-title{font-size:1.3rem}.welcome-interest-grid{grid-template-columns:1fr}.welcome-icon{font-size:2.5rem}.start-here-grid{grid-template-columns:1fr}}.reading-progress-track{position:fixed;top:0;left:0;right:0;height:3px;z-index:50;background:transparent}.reading-progress-bar{height:100%;border-radius:0 2px 2px 0;transition:width 80ms linear}.lesson-toc{display:flex;align-items:center;gap:.75rem;margin:.75rem 0 1rem;padding:.65rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow-x:auto;scrollbar-width:thin}.lesson-toc-label{font-size:.8rem;font-weight:600;color:var(--muted);white-space:nowrap;flex-shrink:0}.lesson-toc-links{display:flex;gap:.4rem;flex-wrap:nowrap}.lesson-toc-link{font-size:.8rem;padding:.25rem .6rem;border-radius:999px;background:var(--card);border:1px solid var(--border);color:var(--text);text-decoration:none;white-space:nowrap;transition:all .15s ease}.lesson-toc-link:hover{background:var(--brand-soft);border-color:var(--brand);color:var(--brand)}.lesson-bottom-nav{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}.lesson-complete-continue{display:block;width:100%;text-align:center;padding:.85rem 1.5rem;font-size:1.05rem;font-weight:600;border-radius:10px;margin-bottom:1rem;cursor:pointer;font-family:inherit}.lesson-gate-note{text-align:center;margin:0 0 1rem;color:var(--warning);font-weight:600}.lesson-completed-badge{text-align:center;padding:.6rem;font-size:.95rem;font-weight:600;color:var(--success);background:var(--success-soft);border:1px solid var(--success);border-radius:10px;margin-bottom:1rem}.lesson-celebration{text-align:center;font-size:1.1rem;font-weight:700;color:var(--brand);margin-bottom:.75rem;animation:celebrateIn .5s ease-out}@keyframes celebrateIn{0%{opacity:0;transform:scale(.8) translateY(8px)}60%{opacity:1;transform:scale(1.08) translateY(-2px)}to{opacity:1;transform:scale(1) translateY(0)}}[id^=section-]{scroll-margin-top:5rem}@media (max-width:640px){.lesson-toc{padding:.5rem .75rem;gap:.5rem}.lesson-toc-label{display:none}.lesson-toc-link{font-size:.75rem;padding:.2rem .5rem}.lesson-complete-continue{font-size:1rem;padding:.75rem 1rem}}.vault-list{display:grid;grid-gap:.75rem;gap:.75rem}.vault-item{border:1px solid var(--border);border-radius:10px;background:var(--surface);padding:.75rem;display:flex;justify-content:space-between;align-items:center;gap:.75rem}@media (max-width:640px){.vault-item{flex-direction:column;align-items:flex-start}}.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:all .2s ease;flex-shrink:0}.theme-toggle:hover{background:var(--brand-soft);border-color:var(--brand);color:var(--brand)}[data-theme=dark] .card{box-shadow:0 1px 3px var(--shadow-color)}[data-theme=dark] .search-results{box-shadow:0 4px 16px var(--shadow-color)}[data-theme=dark] .welcome-overlay{background:rgba(0,0,0,.65)}[data-theme=dark] .welcome-modal{box-shadow:0 24px 64px rgba(0,0,0,.4)}[data-theme=dark] .progress-container{background:var(--surface-alt)}[data-theme=dark] .tags .tag:nth-child(8n+1){background:#1e3a5f;color:#93c5fd;border-color:#1e40af}[data-theme=dark] .tags .tag:nth-child(8n+2){background:#3b0764;color:#d8b4fe;border-color:#6b21a8}[data-theme=dark] .tags .tag:nth-child(8n+3){background:#1e3a5f;color:#93c5fd;border-color:#1d4ed8}[data-theme=dark] .tags .tag:nth-child(8n+4){background:#064e3b;color:#6ee7b7;border-color:#065f46}[data-theme=dark] .tags .tag:nth-child(8n+5){background:#4c0519;color:#fda4af;border-color:#9f1239}[data-theme=dark] .tags .tag:nth-child(8n+6){background:#134e4a;color:#5eead4;border-color:#115e59}[data-theme=dark] .tags .tag:nth-child(8n+7){background:#78350f;color:#fcd34d;border-color:#92400e}[data-theme=dark] .tags .tag:nth-child(8n+8){background:#334155;color:#e2e8f0;border-color:#475569}[data-theme=dark] .tags .tag:nth-child(5n+1){background:var(--brand-soft);color:var(--brand);border-color:var(--brand-light)}[data-theme=dark] .tags .tag:nth-child(5n+2){background:var(--surface-alt);color:var(--muted);border-color:var(--border)}[data-theme=dark] .tags .tag:nth-child(5n+3){background:var(--accent-soft);color:var(--accent);border-color:var(--accent-soft)}[data-theme=dark] .tags .tag:nth-child(5n+4){background:var(--surface);color:var(--text);border-color:var(--border-light)}[data-theme=dark] .tags .tag:nth-child(5n+5){background:var(--brand-light);color:var(--brand);border-color:var(--brand-soft)}[data-theme=dark] mark{background:var(--brand-light);color:var(--text)}.lesson-list{display:flex;flex-direction:column;gap:2px;border:1px solid var(--border);border-radius:12px;overflow:hidden}.lesson-list-item{display:flex;align-items:center;gap:.85rem;padding:.75rem 1rem;background:var(--card);text-decoration:none;color:inherit;transition:background .15s ease;border-bottom:1px solid var(--border-light)}.lesson-list-item:last-child{border-bottom:none}.lesson-list-item:hover{background:var(--surface)}.lesson-list-item.done{opacity:.75}.lesson-list-item.done:hover{opacity:1}.lesson-list-item.current{background:var(--brand-soft);border-left:3px solid var(--brand)}.lesson-list-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--surface);font-size:.8rem;font-weight:600;color:var(--muted);flex-shrink:0}.lesson-list-item.done .lesson-list-number{background:var(--success-soft)}.lesson-list-content{flex:1 1;min-width:0}.lesson-list-title{font-weight:500;font-size:.95rem;color:var(--text);line-height:1.3}.lesson-list-summary{font-size:.8rem;color:var(--muted);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lesson-list-badge{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:999px;background:var(--brand-soft);color:var(--brand);white-space:nowrap;flex-shrink:0}@media (max-width:640px){.lesson-list-item{padding:.6rem .75rem;gap:.6rem}.lesson-list-summary{display:none}}.robot-body-map{padding:1.25rem}.robot-body-map-title{margin:0 0 .25rem;font-size:1.1rem;font-weight:600}.robot-body-map-caption{color:var(--muted);font-size:.9rem;margin:0 0 1rem;line-height:1.5}.robot-body-map-layout{display:flex;gap:1.5rem;align-items:flex-start}.robot-body-map-diagram{flex:0 0 200px;text-align:center}.robot-body-map-svg{width:200px;height:auto}.robot-body-map-hint{font-size:.75rem;color:var(--muted);margin:.5rem 0 0}.robot-body-map-details{flex:1 1;min-height:120px;display:flex;align-items:center}.robot-body-map-placeholder{color:var(--muted);font-size:.9rem;line-height:1.6;padding:1rem;background:var(--surface);border-radius:8px;width:100%}.robot-body-map-placeholder p{margin:0}.robot-body-map-detail{border-left:4px solid;padding:1rem 1.25rem;background:var(--surface);border-radius:0 8px 8px 0;width:100%;animation:rbm-fadein .25s ease}@keyframes rbm-fadein{0%{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}.robot-body-map-detail-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.robot-body-map-detail-icon{font-size:1.5rem}.robot-body-map-detail-title{margin:0;font-size:1rem;font-weight:600}.robot-body-map-detail-realname{font-size:.8rem;color:var(--muted)}.robot-body-map-detail-desc{margin:0;font-size:.9rem;line-height:1.6;color:var(--text)}.robot-body-map-detail-zoom{display:inline-block;margin-top:.5rem;font-size:.75rem;color:var(--muted);background:var(--card);padding:.2rem .5rem;border-radius:4px}@media (max-width:640px){.robot-body-map-layout{flex-direction:column;align-items:center}.robot-body-map-diagram{flex:none}}.rb-container{padding:1.25rem}.rb-header{justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap}.rb-header,.rb-title{display:flex;align-items:center;gap:.5rem}.rb-title{margin:0;font-size:1.1rem;font-weight:600}.rb-title-icon{font-size:1.25rem}.rb-toolbar{display:flex;gap:.5rem}.rb-toolbar .btn{font-size:.8rem;padding:.3rem .7rem}.rb-workspace{display:flex;gap:1rem;margin-bottom:1rem}.rb-palette{flex:0 0 110px}.rb-palette-title{margin:0 0 .5rem;font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.rb-palette-items{display:flex;flex-direction:column;gap:.5rem}.rb-palette-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--surface);border:2px solid var(--border);border-radius:8px;cursor:-webkit-grab;cursor:grab;transition:all .15s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.rb-palette-item:hover{border-color:var(--brand);transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.08)}.rb-palette-item:active{cursor:-webkit-grabbing;cursor:grabbing;transform:scale(.97)}.rb-palette-icon{font-size:1.1rem}.rb-palette-label{font-size:.75rem;font-weight:500;color:var(--text);line-height:1.2}.rb-canvas-container{flex:1 1}.rb-canvas-instructions{font-size:.78rem;color:var(--muted);margin-bottom:.4rem;min-height:1.2em}.rb-canvas{width:100%;height:auto;border:2px solid var(--border);aspect-ratio:560/400}.rb-canvas,.rb-preview{border-radius:8px;background:var(--surface)}.rb-preview{justify-content:space-between;gap:1rem;padding:.75rem 1rem;margin-bottom:.75rem;flex-wrap:wrap}.rb-preview,.rb-preview-status{display:flex;align-items:center}.rb-preview-status{gap:.75rem}.rb-progress-ring{position:relative;width:42px;height:42px;flex-shrink:0}.rb-progress-svg{width:100%;height:100%;transform:rotate(-90deg)}.rb-progress-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:var(--text)}.rb-preview-info{display:flex;flex-direction:column;gap:.15rem}.rb-preview-label{font-size:.85rem;font-weight:600;color:var(--text)}.rb-preview-feedback{font-size:.78rem;color:var(--muted);line-height:1.4}.rb-preview-anim{display:flex;align-items:center;gap:.4rem;padding:.35rem .75rem;background:var(--card);border-radius:999px;border:1px solid var(--border)}.rb-preview-icon{font-size:1.3rem}.rb-preview-behavior{font-size:.8rem;font-weight:500;color:var(--text)}@keyframes rb-glow-anim{0%,to{opacity:1}50%{opacity:.5}}@keyframes rb-blink-anim{0%,49%{opacity:1}50%,to{opacity:.2}}@keyframes rb-spin-anim{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes rb-pulse-anim{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}@keyframes rb-bounce-anim{0%,to{transform:translateX(0)}25%{transform:translateX(4px)}75%{transform:translateX(-4px)}}.rb-glow .rb-preview-icon{animation:rb-glow-anim 2s ease infinite}.rb-blink .rb-preview-icon{animation:rb-blink-anim 1s steps(1) infinite}.rb-spin .rb-preview-icon{animation:rb-spin-anim 1.5s linear infinite}.rb-pulse .rb-preview-icon{animation:rb-pulse-anim 1.5s ease infinite}.rb-bounce .rb-preview-icon{animation:rb-bounce-anim 1s ease infinite}.rb-hints{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#fef3c7;border:1px solid #fbbf24;border-radius:8px}[data-theme=dark] .rb-hints{background:#78350f30;border-color:#92400e}.rb-hint-content{display:flex;align-items:flex-start;gap:.5rem;flex:1 1}.rb-hint-icon{font-size:1.1rem;flex-shrink:0;margin-top:.1rem}.rb-hint-text{margin:0;font-size:.85rem;line-height:1.5;color:var(--text)}.rb-hint-next{background:none;border:1px solid #d97706;color:#d97706;font-size:.75rem;padding:.25rem .5rem;border-radius:4px;cursor:pointer;white-space:nowrap;font-weight:500}.rb-hint-next:hover{background:#d9770610}.rb-success{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;animation:rbm-fadein .3s ease}.rb-success-content{background:var(--card);padding:2rem;border-radius:16px;text-align:center;max-width:400px;box-shadow:0 20px 60px rgba(0,0,0,.2)}.rb-success-icon{font-size:3rem;display:block;margin-bottom:.75rem}.rb-success-message{font-size:1rem;line-height:1.6;margin:0 0 1.25rem;color:var(--text)}@media (max-width:640px){.rb-workspace{flex-direction:column}.rb-palette{flex:none}.rb-palette-items{flex-direction:row;flex-wrap:wrap}.rb-palette-item{flex:0 0 auto}}.mission-card{display:flex;flex-direction:column;padding:1.25rem;background:var(--card);border:2px solid var(--border);border-radius:12px;transition:all .2s ease;position:relative}.mission-card:hover{border-color:var(--mission-color,var(--brand));transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.08)}.mission-card-badge-complete{position:absolute;top:.75rem;right:.75rem;background:var(--success,#22c55e);color:white;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.mission-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.mission-card-icon{font-size:1.75rem}.mission-card-difficulty{font-size:.7rem;font-weight:600;padding:.2rem .6rem;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.mission-card-title{margin:0 0 .35rem;font-size:1.05rem;font-weight:600;color:var(--text)}.mission-card-desc{margin:0 0 .75rem;font-size:.85rem;color:var(--muted);line-height:1.5;flex:1 1}.mission-card-components{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.75rem}.mission-card-component-tag{font-size:.7rem;padding:.15rem .45rem;background:var(--surface);border:1px solid var(--border);border-radius:4px;color:var(--muted)}.mission-card-progress{margin-bottom:.75rem}.mission-card-progress-bar-track{width:100%;height:6px;background:var(--surface);border-radius:3px;overflow:hidden;margin-bottom:.25rem}.mission-card-progress-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.mission-card-progress-text{font-size:.75rem;color:var(--muted)}.mission-card-cta{font-size:.9rem;font-weight:600;margin-top:auto}