:root,[data-theme=dark]{--bg-primary: #121620;--bg-secondary: #161c28;--bg-card: #1c2433;--bg-code: #0f141c;--bg-input: #141a25;--bg-hover: #252e3c;--bg-elevated: #212a38;--bg-kbd: #252e3c;--border: #2a3445;--border-hover: #3d4b5e;--border-light: #323f51;--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #6b7d93;--text-heading: #f1f5f9;--text-faint: #4a5d73;--text-code: #cbd5e1;--text-on-accent: #fff;--accent-teal: #4C9AFF;--accent-blue: #79b8ff;--accent-orange: #f0932b;--accent-purple: #7c6cf0;--accent-green: #34d882;--accent-red: #ff6b6b;--accent-yellow: #ffd93d;--accent-pink: #e74c3c;--shadow-sm: rgba(0, 0, 0, .15);--shadow-md: rgba(0, 0, 0, .25);--shadow-lg: rgba(0, 0, 0, .4);--shadow-overlay: rgba(0, 0, 0, .5);--card-shadow: 0 1px 3px rgba(0, 0, 0, .12);--gradient-progress: linear-gradient(90deg, var(--accent-teal), var(--accent-purple));--scrollbar-thumb: #2a3445;--ring-bg: #2a3445}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-card: #ffffff;--bg-code: #f1f5f9;--bg-input: #e2e8f0;--bg-hover: #e2e8f0;--bg-elevated: #ffffff;--bg-kbd: #e2e8f0;--border: #cbd5e1;--border-hover: #94a3b8;--border-light: #e2e8f0;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #64748b;--text-heading: #0f172a;--text-faint: #94a3b8;--text-code: #334155;--text-on-accent: #fff;--accent-teal: #0052CC;--accent-blue: #2563eb;--accent-orange: #d97706;--accent-purple: #7c3aed;--accent-green: #16a34a;--accent-red: #dc2626;--accent-yellow: #ca8a04;--accent-pink: #e11d48;--shadow-sm: rgba(0, 0, 0, .04);--shadow-md: rgba(0, 0, 0, .06);--shadow-lg: rgba(0, 0, 0, .1);--shadow-overlay: rgba(0, 0, 0, .25);--card-shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--gradient-progress: linear-gradient(90deg, var(--accent-teal), var(--accent-purple));--scrollbar-thumb: #cbd5e1;--ring-bg: #e2e8f0}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=light]{color-scheme:light}body{margin:0;min-width:320px;min-height:100vh}.sidebar-overlay{position:fixed;inset:0;background:var(--shadow-overlay);z-index:99;display:none}.sidebar{width:280px;min-width:280px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;height:calc(100vh - var(--nav-h, 46px));position:sticky;top:var(--nav-h, 46px);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) transparent}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1rem .5rem;border-bottom:1px solid var(--border)}.sidebar-header-left{display:flex;align-items:center;gap:.5rem;min-width:0}.sidebar-header-left h2{font-size:1rem;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-home-btn{background:none;border:1px solid var(--border-light);color:var(--text-muted);width:26px;height:26px;min-width:26px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all .15s;padding:0}.sidebar-home-btn:hover{border-color:var(--text-muted);color:var(--text-heading);background:var(--bg-card)}.sidebar-close{display:none;background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.sidebar-close:hover{color:var(--text-heading)}.course-progress{padding:.6rem 1rem;border-bottom:1px solid var(--border)}.course-progress-label{display:flex;justify-content:space-between;align-items:center;font-size:.68rem;color:var(--text-muted);margin-bottom:.35rem}.course-progress-pct{font-weight:700;color:var(--text-secondary);font-family:monospace}.course-progress-track{height:4px;background:var(--bg-card);border-radius:2px;overflow:hidden}.course-progress-bar{height:100%;background:var(--gradient-progress);border-radius:2px;transition:width .5s ease}.course-progress-bar.complete{animation:shimmer 2s ease-in-out infinite}@keyframes shimmer{0%,to{filter:brightness(1)}50%{filter:brightness(1.4)}}.sidebar-search{position:relative;padding:.5rem .6rem}.sidebar-search-input{width:100%;padding:.4rem 2rem .4rem .6rem;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.78rem;outline:none;transition:border-color .2s}.sidebar-search-input:focus{border-color:var(--accent-teal)}.sidebar-search-input::placeholder{color:var(--text-faint)}.sidebar-search-clear{position:absolute;right:.8rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:1.1rem;cursor:pointer;padding:0 .2rem;line-height:1}.sidebar-search-clear:hover{color:var(--text-heading)}.sidebar-search-results{display:flex;flex-direction:column;gap:1px;padding:.3rem 0}.sidebar-search-empty{padding:1.5rem;text-align:center;color:var(--text-faint);font-size:.8rem}.sidebar-search-item{padding-left:.8rem!important;gap:.5rem!important}.sidebar-search-tier-badge{font-size:.6rem;font-weight:700;padding:.1rem .35rem;border-radius:3px;white-space:nowrap;flex-shrink:0}.sidebar-demo{margin:.5rem;border-radius:8px;border:1px solid color-mix(in srgb,var(--accent-teal) 27%,transparent)}.sidebar-demo .sidebar-item-icon{margin-right:.4rem}.sidebar-item{display:flex;align-items:center;gap:.4rem;padding:.5rem .8rem;background:var(--bg-card);border:1px solid transparent;border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:.82rem;text-align:left;width:auto;transition:all .15s}.sidebar-item:hover{background:var(--bg-hover);color:var(--text-heading)}.sidebar-item.active{background:color-mix(in srgb,var(--accent-teal) 13%,transparent);color:var(--accent-teal);border-color:color-mix(in srgb,var(--accent-teal) 27%,transparent)}.sidebar-tiers{display:flex;flex-direction:column;gap:.2rem;padding:.4rem 0}.sidebar-tier-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .8rem;background:transparent;border:none;border-left:3px solid var(--border);color:var(--text-code);cursor:pointer;font-size:.8rem;text-align:left;width:100%;transition:all .15s}.sidebar-tier-header:hover{background:var(--bg-card)}.sidebar-tier-info{display:flex;flex-direction:column}.sidebar-tier-title{font-weight:700;font-size:.82rem}.sidebar-tier-sub{font-size:.68rem;color:var(--text-muted)}.sidebar-tier-meta{display:flex;align-items:center;gap:.4rem}.sidebar-tier-arrow{font-size:.7rem;color:var(--text-muted);transition:transform .2s}.sidebar-tier-arrow.expanded{transform:rotate(180deg)}.progress-ring{flex-shrink:0}.sidebar-domain-sep{display:flex;align-items:center;gap:.6rem;padding:.6rem .8rem .3rem;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-faint)}.sidebar-domain-sep:before,.sidebar-domain-sep:after{content:"";flex:1;height:1px;background:var(--border)}.sidebar-chapters{display:flex;flex-direction:column;gap:1px;padding:.2rem 0}.sidebar-chapter{display:flex;align-items:center;gap:.5rem;padding:.35rem .6rem .35rem 1.4rem;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.78rem;text-align:left;width:100%;transition:all .15s}.sidebar-chapter:hover{background:var(--bg-card);color:var(--text-heading)}.sidebar-chapter.active{background:color-mix(in srgb,var(--accent-teal) 8%,transparent);color:var(--accent-teal)}.sidebar-check{width:20px;height:20px;min-width:20px;border-radius:50%;border:1px solid var(--border-hover);display:flex;align-items:center;justify-content:center;font-size:.65rem;color:var(--text-muted);font-weight:700;transition:all .2s}.sidebar-check.done{background:var(--accent-teal);border-color:var(--accent-teal);color:var(--text-on-accent);animation:checkPop .3s ease}@keyframes checkPop{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.sidebar-chapter-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-theme-toggle{background:none;border:1px solid var(--border);border-radius:6px;width:30px;height:30px;min-width:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;transition:all .2s;padding:0;color:var(--text-muted)}.sidebar-theme-toggle:hover{border-color:var(--accent-yellow);color:var(--accent-yellow);background:color-mix(in srgb,var(--accent-yellow) 8%,transparent)}.sidebar-xp{padding:.5rem 1rem;border-bottom:1px solid var(--border)}.sidebar-xp-header{display:flex;justify-content:space-between;align-items:center;font-size:.65rem;margin-bottom:.3rem}.sidebar-xp-level{font-weight:700;color:var(--accent-yellow)}.sidebar-xp-amount{color:var(--text-muted);font-family:monospace}.sidebar-xp-track{height:4px;background:var(--bg-card);border-radius:2px;overflow:hidden}.sidebar-xp-fill{height:100%;background:linear-gradient(90deg,var(--accent-yellow),var(--accent-orange));border-radius:2px;transition:width .5s ease}@media(max-width:768px){.sidebar-overlay{display:block}.sidebar{position:fixed;left:-300px;top:0;z-index:100;transition:left .3s ease;box-shadow:none}.sidebar.open{left:0;box-shadow:4px 0 20px var(--shadow-md)}.sidebar-close{display:block}}.chapter-nav{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-top:2rem;padding:1rem 0;border-top:1px solid var(--border)}.chapter-nav-btn{padding:.5rem 1rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text-secondary);cursor:pointer;font-size:.8rem;transition:all .2s;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chapter-nav-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-heading);border-color:color-mix(in srgb,var(--accent-teal) 27%,transparent)}.chapter-nav-btn:disabled{opacity:.3;cursor:default}.chapter-nav-btn.prev{text-align:left}.chapter-nav-btn.next{text-align:right}.chapter-nav-center{display:flex;flex-direction:column;align-items:center;gap:.5rem}.chapter-nav-complete{padding:.5rem 1.2rem;border:1px solid color-mix(in srgb,var(--accent-teal) 27%,transparent);border-radius:8px;background:var(--bg-card);color:var(--accent-teal);cursor:pointer;font-size:.8rem;font-weight:600;transition:all .2s;white-space:nowrap}.chapter-nav-complete:hover{background:color-mix(in srgb,var(--accent-teal) 13%,transparent)}.chapter-nav-complete.done{background:var(--accent-teal);color:var(--text-on-accent);border-color:var(--accent-teal);animation:completePulse .4s ease}@keyframes completePulse{0%{transform:scale(1)}40%{transform:scale(1.08)}to{transform:scale(1)}}.chapter-nav-continue{padding:.4rem 1rem;border:1px solid color-mix(in srgb,var(--accent-green) 27%,transparent);border-radius:8px;background:color-mix(in srgb,var(--accent-green) 10%,transparent);color:var(--accent-green);cursor:pointer;font-size:.75rem;font-weight:600;white-space:nowrap;animation:slideUp .3s ease;transition:all .2s}.chapter-nav-continue:hover{background:color-mix(in srgb,var(--accent-green) 20%,transparent);border-color:var(--accent-green)}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.chapter-nav{flex-wrap:wrap;justify-content:center}.chapter-nav-btn{max-width:140px;font-size:.75rem}}.hero-anim{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;background:var(--bg-code);border:1px solid var(--border);border-radius:14px;overflow:hidden;animation:heroFadeIn .8s ease-out both;animation-delay:.3s;max-width:520px}@keyframes heroFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.hero-anim-code{flex:1;max-width:260px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow:hidden}.hero-anim-code-header{display:flex;align-items:center;gap:.3rem;padding:.4rem .6rem;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.hero-anim-dot{width:7px;height:7px;border-radius:50%}.hero-anim-dot.red{background:#ff5f57}.hero-anim-dot.yellow{background:#ffbd2e}.hero-anim-dot.green{background:#28c840}.hero-anim-code-title{font-size:.58rem;color:var(--text-faint);margin-left:.3rem;font-weight:500}.hero-anim-code-body{padding:.5rem;font-family:SF Mono,Fira Code,monospace;font-size:.62rem;line-height:1.55;color:var(--text-code)}.hero-anim-line{opacity:0;animation:heroTypeIn .4s ease-out forwards;animation-delay:var(--delay);white-space:nowrap}@keyframes heroTypeIn{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}.hero-anim-kw{color:var(--accent-purple);font-weight:600}.hero-anim-fn{color:var(--accent-blue)}.hero-anim-str{color:var(--accent-green)}.hero-anim-flow{display:flex;align-items:center;position:relative;width:60px;height:20px;color:var(--accent-teal);flex-shrink:0}.hero-anim-arrow{position:relative;z-index:1}.hero-anim-particle{position:absolute;width:4px;height:4px;border-radius:50%;background:var(--accent-teal);animation:heroParticle 2s ease-in-out infinite}.hero-anim-particle.p1{animation-delay:0s}.hero-anim-particle.p2{animation-delay:.6s}.hero-anim-particle.p3{animation-delay:1.2s}@keyframes heroParticle{0%{left:0;opacity:1}80%{left:50px;opacity:1}to{left:60px;opacity:0}}.hero-anim-output{flex:0 0 150px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;overflow:hidden}.hero-anim-output-header{padding:.35rem .6rem;background:var(--bg-secondary);border-bottom:1px solid var(--border)}.hero-anim-output-title{font-size:.58rem;color:var(--text-faint);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.hero-anim-partitions{padding:.6rem;display:flex;flex-direction:column;gap:.35rem}.hero-anim-partition{display:flex;align-items:center;gap:.35rem;opacity:0;animation:heroPartIn .4s ease-out forwards;animation-delay:var(--delay)}@keyframes heroPartIn{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.hero-anim-p-label{font-size:.55rem;color:var(--text-faint);font-weight:700;min-width:18px}.hero-anim-p-blocks{display:flex;gap:2px;flex:1}.hero-anim-p-block{height:14px;flex:1;border-radius:2px;background:var(--color);opacity:0}.hero-anim-p-block.b1{animation:blockFade .3s ease forwards;animation-delay:calc(var(--delay) + .2s)}.hero-anim-p-block.b2{animation:blockFade .3s ease forwards;animation-delay:calc(var(--delay) + .4s)}.hero-anim-p-block.b3{animation:blockFade .3s ease forwards;animation-delay:calc(var(--delay) + .6s)}.hero-anim-p-block.b4{animation:blockFade .3s ease forwards;animation-delay:calc(var(--delay) + .8s)}@keyframes blockFade{0%{opacity:0;transform:scaleX(.3)}to{opacity:.7;transform:scaleX(1)}}.hero-anim-status{display:flex;align-items:center;gap:.3rem;padding:.3rem .6rem;border-top:1px solid var(--border)}.hero-anim-status-dot{width:5px;height:5px;border-radius:50%;background:var(--accent-green);animation:statusPulse 2s ease-in-out infinite}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.4}}.hero-anim-status-text{font-size:.52rem;color:var(--text-faint);font-weight:500}@media(max-width:768px){.hero-anim{flex-direction:column;gap:.8rem;max-width:100%}.hero-anim-code{max-width:100%}.hero-anim-flow{transform:rotate(90deg);margin:.3rem 0}.hero-anim-output{flex:none;width:100%}}.home-page{display:flex;flex-direction:column;width:100%;overflow-x:hidden}.home-section{width:100%;padding:4rem 0}.home-section-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem}.home-section-narrow{max-width:720px}.home-hero{position:relative;overflow:hidden;padding:4rem 1.5rem 3rem}.home-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 20% 80%,color-mix(in srgb,var(--accent-teal) 8%,transparent) 0%,transparent 100%),radial-gradient(ellipse 50% 40% at 80% 20%,color-mix(in srgb,var(--accent-purple) 8%,transparent) 0%,transparent 100%);pointer-events:none}.home-hero-content{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;position:relative}.home-hero-text{display:flex;flex-direction:column;gap:1.2rem}.home-hero-badge-label{display:inline-flex;align-self:flex-start;font-size:.72rem;font-weight:700;color:var(--accent-teal);background:color-mix(in srgb,var(--accent-teal) 10%,transparent);border:1px solid color-mix(in srgb,var(--accent-teal) 25%,transparent);padding:.3rem .8rem;border-radius:20px;letter-spacing:.02em;text-transform:uppercase}.home-hero-title{font-size:2.8rem;font-weight:800;color:var(--text-heading);line-height:1.15;letter-spacing:-1px}.home-hero-accent{background:linear-gradient(135deg,var(--accent-teal),var(--accent-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-hero-sub{font-size:1.05rem;color:var(--text-secondary);line-height:1.7;max-width:480px}.home-hero-actions{display:flex;gap:.8rem;align-items:center;margin-top:.5rem}.home-hero-cta{display:inline-flex;align-items:center;gap:.4rem;padding:.7rem 1.4rem;border-radius:10px;font-weight:700;font-size:.88rem;text-decoration:none;transition:all .2s;cursor:pointer}.home-hero-cta-primary{background:var(--accent-teal);color:var(--text-on-accent);box-shadow:0 4px 14px color-mix(in srgb,var(--accent-teal) 30%,transparent)}.home-hero-cta-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px color-mix(in srgb,var(--accent-teal) 40%,transparent)}.home-hero-cta-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.home-hero-cta-secondary:hover{border-color:var(--accent-teal);background:var(--bg-hover)}.home-hero-trust{display:flex;gap:1.2rem;flex-wrap:wrap;margin-top:.3rem}.home-hero-trust-item{display:flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--text-muted);font-weight:500}.home-hero-visual{display:flex;justify-content:center}.home-stats-bar{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-card)}.home-stats-inner{max-width:1100px;margin:0 auto;padding:1.4rem 1.5rem;display:flex;align-items:center;justify-content:center;gap:2.5rem}.home-stat-item{display:flex;flex-direction:column;align-items:center;gap:.15rem}.home-stat-number{font-size:1.5rem;font-weight:800;color:var(--text-heading);letter-spacing:-.5px}.home-stat-label{font-size:.72rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.home-stat-divider{width:1px;height:36px;background:var(--border)}.home-section-header{text-align:center;margin-bottom:2.5rem}.home-section-tag{display:inline-block;font-size:.7rem;font-weight:700;color:var(--accent-teal);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.6rem}.home-section-title{font-size:2rem;font-weight:800;color:var(--text-heading);letter-spacing:-.5px;margin-bottom:.6rem}.home-section-sub{font-size:.95rem;color:var(--text-muted);max-width:500px;margin:0 auto;line-height:1.6}.home-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}.home-feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:1.5rem;transition:all .25s ease;animation:featureSlideUp .5s ease-out both}@keyframes featureSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.home-feature-card:hover{border-color:color-mix(in srgb,var(--accent-teal) 35%,transparent);transform:translateY(-4px);box-shadow:0 8px 30px var(--shadow-md)}.home-feature-icon{margin-bottom:.8rem;display:flex}.home-feature-card h3{font-size:.95rem;color:var(--text-heading);margin-bottom:.4rem;font-weight:700}.home-feature-card p{font-size:.82rem;color:var(--text-muted);line-height:1.6}.home-how-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;position:relative}.home-how-step{text-align:center;position:relative;padding:0 1rem}.home-how-number{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent-teal),var(--accent-blue));color:var(--text-on-accent);font-size:1.2rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;position:relative;z-index:2}.home-how-connector{position:absolute;top:24px;left:calc(50% + 32px);width:calc(100% - 32px);height:2px;background:linear-gradient(90deg,var(--accent-teal),color-mix(in srgb,var(--accent-teal) 20%,transparent));z-index:1}.home-how-step h3{font-size:1.05rem;color:var(--text-heading);margin-bottom:.4rem;font-weight:700}.home-how-step p{font-size:.85rem;color:var(--text-muted);line-height:1.6}.home-courses-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.home-course-card{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:all .25s ease;--course-color: var(--accent-teal)}.home-course-card[data-course=kafka]{--course-color: var(--accent-teal)}.home-course-card[data-course=python]{--course-color: var(--accent-blue)}.home-course-card:hover{border-color:color-mix(in srgb,var(--course-color) 40%,transparent);box-shadow:0 12px 40px var(--shadow-md);transform:translateY(-3px)}.home-course-top{padding:1.5rem;position:relative;display:flex;flex-direction:column;gap:.8rem}.home-course-top-accent{position:absolute;top:0;left:0;right:0;height:3px;background:var(--course-color)}.home-course-header{display:flex;align-items:center;gap:.8rem}.home-course-icon{flex-shrink:0;color:var(--course-color, var(--accent-teal))}.home-course-info h3{font-size:1.25rem;color:var(--text-heading);font-weight:800;margin-bottom:.1rem}.home-course-sub{font-size:.8rem;color:var(--text-muted)}.home-course-desc{font-size:.85rem;color:var(--text-secondary);line-height:1.6}.home-course-tags{display:flex;gap:.4rem;flex-wrap:wrap}.home-course-tag{font-size:.68rem;color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border);padding:.2rem .5rem;border-radius:6px;font-weight:600}.home-course-meta-bar{display:flex;gap:1rem;flex-wrap:wrap;padding:.8rem 1.5rem;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-secondary)}.home-course-meta-item{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--text-muted);font-weight:600}.home-course-meta-item svg{color:var(--text-faint)}.home-course-highlight-bar{padding:.5rem 1.5rem;font-size:.78rem;font-weight:600;color:var(--course-color);background:color-mix(in srgb,var(--course-color) 6%,transparent);border-bottom:1px solid var(--border)}.home-course-progress{padding:1rem 1.5rem}.home-course-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.home-course-progress-label{font-size:.78rem;color:var(--text-muted);font-weight:600}.home-course-progress-pct{font-size:.82rem;color:var(--text-heading);font-weight:800}.home-progress-track{height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}.home-progress-fill{height:100%;border-radius:3px;transition:width .6s ease;background:var(--course-color, var(--accent-teal))}.home-course-curriculum{padding:0 1.5rem .5rem}.home-curriculum-title{font-size:.78rem;color:var(--text-faint);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem}.home-curriculum-tier{border-bottom:1px solid color-mix(in srgb,var(--border) 50%,transparent)}.home-curriculum-tier:last-child{border-bottom:none}.home-curriculum-tier-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem 0;background:none;border:none;cursor:pointer;color:inherit;font-family:inherit}.home-curriculum-tier-header:hover{background:color-mix(in srgb,var(--bg-hover) 50%,transparent);margin:0 -.3rem;padding-left:.3rem;padding-right:.3rem;border-radius:6px}.home-curriculum-tier-left{display:flex;align-items:center;gap:.5rem}.home-curriculum-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.home-curriculum-tier-name{font-size:.82rem;color:var(--text-primary);font-weight:600}.home-curriculum-tier-count{font-size:.7rem;color:var(--text-faint)}.home-curriculum-tier-right{display:flex;align-items:center;gap:.4rem}.home-curriculum-tier-progress{font-size:.7rem;color:var(--text-faint);font-weight:600}.home-curriculum-chevron{color:var(--text-faint);transition:transform .2s}.home-curriculum-chevron.open{transform:rotate(180deg)}.home-curriculum-chapters{padding:0 0 .4rem 1.4rem}.home-curriculum-chapter{display:flex;align-items:center;gap:.4rem;padding:.2rem 0;font-size:.76rem;color:var(--text-muted)}.home-curriculum-chapter.completed{color:var(--text-secondary)}.home-curriculum-check{display:flex;align-items:center;width:14px;flex-shrink:0}.home-curriculum-circle{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--border);margin-left:2px}.home-curriculum-ch-title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-course-cta-btn{display:flex;align-items:center;justify-content:center;gap:.4rem;margin:.8rem 1.5rem 1.5rem;padding:.7rem;border:none;border-radius:10px;background:var(--course-color, var(--accent-teal));color:var(--text-on-accent);font-size:.88rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit}.home-course-cta-btn:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 6px 20px var(--shadow-md)}.home-faq-list{display:flex;flex-direction:column}.home-faq-item{border-bottom:1px solid var(--border)}.home-faq-q{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1rem 0;background:none;border:none;cursor:pointer;font-family:inherit;font-size:.92rem;font-weight:600;color:var(--text-heading);text-align:left;gap:1rem}.home-faq-q:hover{color:var(--accent-teal)}.home-faq-icon{flex-shrink:0;color:var(--text-faint);transition:transform .25s ease}.home-faq-item.open .home-faq-icon{transform:rotate(180deg)}.home-faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}.home-faq-item.open .home-faq-a{max-height:200px;padding-bottom:1rem}.home-faq-a p{font-size:.85rem;color:var(--text-secondary);line-height:1.7}.home-cta-banner{position:relative;overflow:hidden;border-radius:20px}.home-cta-banner-bg{position:absolute;inset:0;background:linear-gradient(135deg,color-mix(in srgb,var(--accent-teal) 15%,var(--bg-card)),color-mix(in srgb,var(--accent-purple) 12%,var(--bg-card)));border:1px solid color-mix(in srgb,var(--accent-teal) 20%,transparent);border-radius:20px}.home-cta-banner-content{position:relative;text-align:center;padding:3rem 2rem}.home-cta-banner-content h2{font-size:1.8rem;font-weight:800;color:var(--text-heading);margin-bottom:.5rem}.home-cta-banner-content p{font-size:.95rem;color:var(--text-secondary);margin-bottom:1.5rem}.home-cta-banner-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.75rem 2rem;background:var(--accent-teal);color:var(--text-on-accent);border:none;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s;box-shadow:0 4px 14px color-mix(in srgb,var(--accent-teal) 30%,transparent)}.home-cta-banner-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px color-mix(in srgb,var(--accent-teal) 40%,transparent);filter:brightness(1.1)}.home-footer{border-top:1px solid var(--border);background:var(--bg-secondary);margin-top:1rem}.home-footer-inner{max-width:1100px;margin:0 auto;padding:2.5rem 1.5rem 1.5rem}.home-footer-top{display:flex;justify-content:space-between;padding-bottom:2rem;border-bottom:1px solid var(--border);gap:2rem}.home-footer-brand{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:700;color:var(--text-heading)}.home-footer-cols{display:flex;gap:3rem}.home-footer-col h4{font-size:.78rem;color:var(--text-faint);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.6rem}.home-footer-link{display:block;font-size:.82rem;color:var(--text-muted);text-decoration:none;padding:.2rem 0;background:none;border:none;cursor:pointer;font-family:inherit;transition:color .15s;text-align:left}.home-footer-link:hover{color:var(--text-heading)}.home-footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:1.2rem;font-size:.75rem;color:var(--text-faint);font-weight:500}.home-footer-site-link{color:var(--accent-teal);text-decoration:none;font-weight:600;transition:color .15s}.home-footer-site-link:hover{color:var(--text-heading)}.home-scroll-top{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:90;opacity:0;transform:translateY(12px);pointer-events:none;transition:all .3s ease;box-shadow:0 4px 16px var(--shadow-md)}.home-scroll-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}.home-scroll-top:hover{background:var(--accent-teal);border-color:var(--accent-teal);color:var(--text-on-accent);transform:translateY(-2px);box-shadow:0 6px 20px color-mix(in srgb,var(--accent-teal) 30%,transparent)}@media(max-width:900px){.home-hero-content{grid-template-columns:1fr;gap:2rem;text-align:center}.home-hero-text{align-items:center}.home-hero-title{font-size:2rem}.home-hero-sub{max-width:100%}.home-hero-actions,.home-hero-trust{justify-content:center}.home-courses-grid{grid-template-columns:1fr}}@media(max-width:768px){.home-section{padding:2.5rem 0}.home-hero{padding:2.5rem 1rem 2rem}.home-hero-title{font-size:1.7rem}.home-hero-sub{font-size:.92rem}.home-hero-actions{flex-direction:column;width:100%}.home-hero-cta{width:100%;justify-content:center}.home-stats-inner{gap:1.2rem;flex-wrap:wrap}.home-stat-number{font-size:1.2rem}.home-features-grid{grid-template-columns:1fr}.home-how-steps{grid-template-columns:1fr;gap:1.5rem}.home-how-connector{display:none}.home-section-title{font-size:1.5rem}.home-footer-top{flex-direction:column;gap:1.5rem}.home-footer-bottom{flex-direction:column;gap:.3rem;text-align:center}.home-cta-banner-content h2{font-size:1.3rem}.home-course-meta-bar{gap:.6rem}.home-scroll-top{bottom:1.2rem;right:1.2rem;width:40px;height:40px}}@media(max-width:480px){.home-hero-title{font-size:1.4rem}.home-stat-divider{display:none}.home-stats-inner{gap:.5rem}.home-stat-item{min-width:70px}}.badge-popup{position:fixed;bottom:2rem;right:2rem;display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--accent-yellow);border-radius:12px;box-shadow:0 8px 32px var(--shadow-lg);z-index:300;cursor:pointer;animation:badgeSlideIn .4s ease}@keyframes badgeSlideIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.badge-popup-icon{font-size:2rem;line-height:1}.badge-popup-info{display:flex;flex-direction:column;gap:.1rem}.badge-popup-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent-yellow)}.badge-popup-name{font-size:.95rem;font-weight:700;color:var(--text-heading)}.badge-popup-desc{font-size:.72rem;color:var(--text-muted)}@media(max-width:768px){.badge-popup{bottom:1rem;right:1rem;left:1rem}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh}#root{max-width:1500px;margin:0 auto}.app-nav{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--bg-primary) 85%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.app-nav-inner{display:flex;align-items:center;justify-content:space-between;padding:.55rem 1.2rem;gap:1rem;max-width:1500px;margin:0 auto}.app-nav-left{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.app-nav-brand{display:flex;align-items:center;gap:.5rem;background:none;border:none;cursor:pointer;color:inherit;font-family:inherit;padding:.2rem 0}.app-nav-brand:hover .app-nav-title{color:var(--accent-teal)}.app-nav-title{font-size:.92rem;font-weight:700;color:var(--text-heading);letter-spacing:-.3px;transition:color .15s}.app-nav-center{flex:1;min-width:0;display:flex;align-items:center;justify-content:center}.app-nav-right{display:flex;align-items:center;gap:.6rem;flex-shrink:0}.app-nav-links{display:flex;align-items:center;gap:1.5rem}.app-nav-link{font-size:.82rem;color:var(--text-muted);text-decoration:none;font-weight:500;transition:color .15s}.app-nav-link:hover{color:var(--text-heading)}.app-nav-link-btn{background:none;border:none;cursor:pointer;font-family:inherit;padding:0}.app-nav-link-active{color:var(--accent-teal)!important;font-weight:600}.app-nav-theme{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.app-nav-theme:hover{border-color:var(--accent-teal);transform:scale(1.08)}.app-nav-breadcrumb{display:flex;align-items:center;gap:.4rem;font-size:.78rem;min-width:0;overflow:hidden}.app-nav-crumb-link{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.78rem;font-family:inherit;padding:0;transition:color .15s;white-space:nowrap;flex-shrink:0}.app-nav-crumb-link:hover{color:var(--text-heading)}.app-nav-crumb-sep{color:var(--text-faint);font-size:.85rem;flex-shrink:0}.app-nav-crumb-course,.app-nav-crumb-tier{font-weight:600;white-space:nowrap;flex-shrink:0}.app-nav-crumb-chapter{color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-nav-hamburger{display:none;flex-direction:column;gap:3px;background:none;border:1px solid var(--border);border-radius:5px;padding:6px;cursor:pointer;transition:border-color .2s,background .2s}.app-nav-hamburger:hover{border-color:var(--accent-teal);background:color-mix(in srgb,var(--accent-teal) 6%,transparent)}.app-nav-hamburger span{display:block;width:16px;height:2px;background:var(--text-code);border-radius:1px}.app-nav-progress{height:2px;background:transparent}.app-nav-progress-bar{height:100%;background:var(--gradient-progress);transform-origin:left;transition:transform .1s linear;will-change:transform}.app-layout{--nav-h: 46px;display:flex;flex-direction:column;min-height:100vh}.app-body{display:flex;flex:1}.main-content{flex:1;min-width:0;padding:1.5rem;overflow-x:hidden;position:relative;outline:none}.home-main,.portfolio-main{padding:0!important}.chapter-transition{transition:opacity .25s ease,transform .25s ease}.chapter-transition.fade-out{opacity:0;transform:translateY(8px)}.chapter-transition.fade-in{animation:chapterFadeIn .3s ease forwards}@keyframes chapterFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chapter-content{display:flex;flex-direction:column;gap:1.5rem}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:3rem;color:var(--text-muted);font-size:.9rem}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent-teal);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.shortcuts-overlay{position:fixed;inset:0;background:var(--shadow-overlay);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.shortcuts-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;min-width:320px;max-width:400px;box-shadow:0 20px 60px var(--shadow-lg);animation:modalSlideUp .2s ease}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.shortcuts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.shortcuts-header h3{font-size:1rem;color:var(--text-heading)}.shortcuts-close{background:none;border:none;color:var(--text-muted);font-size:1.4rem;cursor:pointer;padding:0;line-height:1}.shortcuts-close:hover{color:var(--text-heading)}.shortcuts-list{display:flex;flex-direction:column;gap:.6rem}.shortcut-row{display:flex;align-items:center;justify-content:space-between;font-size:.85rem;color:var(--text-secondary)}.shortcut-keys{display:flex;align-items:center;gap:.3rem}kbd{display:inline-block;padding:.15rem .5rem;background:var(--bg-kbd);border:1px solid var(--border-light);border-radius:4px;font-family:inherit;font-size:.8rem;color:var(--text-primary);box-shadow:0 1px 0 var(--border-hover)}@media print{.app-nav{display:none!important}.portfolio-main{padding:0!important}#root{max-width:100%}}@media(max-width:768px){.app-nav-hamburger{display:flex}.app-nav-links{gap:.8rem}.app-nav-links .app-nav-link{font-size:.72rem}.app-nav-crumb-course,.app-nav-crumb-tier{display:none}.app-nav-title{font-size:.82rem}.main-content{padding:1rem}}
