:root{--bg:#f4f1ea;--bg-elevated:#faf8f4;--bg-surface:#faf8f4;--bg-surface-hover:#f0ece4;--bg-glass:#ffffffe0;--border:#1c19171a;--border-hover:#1c19172e;--border-active:#1c191747;--border-subtle:#1c19170f;--text:#1c1917;--text-secondary:#57534e;--text-muted:#a8a29e;--text-on-accent:#faf8f4;--accent:#1c1917;--accent-light:#44403c;--accent-dark:#0c0a09;--accent-glow:#1c19170f;--accent-warm:#b45309;--accent-soft:#1c191714;--success:#15803d;--success-soft:#15803d14;--warning:#b45309;--danger:#b91c1c;--danger-soft:#b91c1c14;--danger-border:#b91c1c1f;--code-bg:#f1f5f9;--code-text:#334155;--overlay:#0009;--radius:4px;--radius-sm:4px;--radius-xs:3px;--shadow-sm:0 1px 0 #1c19170a;--shadow:0 1px 3px #1c19170f;--shadow-lg:0 8px 30px #1c191712;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-serif:"Source Serif 4", Georgia, "Times New Roman", serif;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}[data-theme=dark]{--bg:#141210;--bg-elevated:#1c1917;--bg-surface:#1c1917;--bg-surface-hover:#292524;--bg-glass:#141210eb;--border:#faf8f41a;--border-hover:#faf8f42e;--border-active:#faf8f447;--border-subtle:#faf8f40a;--text:#faf8f4;--text-secondary:#a8a29e;--text-muted:#78716c;--text-on-accent:#141210;--accent:#faf8f4;--accent-light:#e7e5e4;--accent-dark:#fff;--accent-glow:#faf8f40f;--accent-warm:#fbbf24;--accent-soft:#faf8f414;--success:#4ade80;--success-soft:#4ade801a;--warning:#fbbf24;--danger:#f87171;--danger-soft:#f871711a;--danger-border:#f871712e;--code-bg:#0c0a09;--code-text:#cbd5e1;--overlay:#000000bf;--shadow-sm:0 1px 0 #00000059;--shadow:0 1px 3px #00000073;--shadow-lg:0 8px 30px #0000008c;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;overflow-x:clip}body{font-family:var(--font);background:var(--bg);color:var(--text);scrollbar-gutter:stable;width:100%;min-height:100vh;line-height:1.6;overflow:clip auto}#app{width:100%;min-height:100vh}body:before{display:none}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes slideLeft{0%{transform:translate(100%)}to{transform:translate(0)}}.app{z-index:1;flex-direction:column;width:100%;min-width:0;max-width:100%;min-height:100vh;display:flex;position:relative}.app>.login-screen,.main-unlock{flex:1;width:100%;min-width:0}.glass{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.glow-dot{display:none}.sidebar{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--border);z-index:2;flex-direction:column;flex-shrink:0;width:260px;display:flex;position:relative}.sidebar-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:20px;display:flex}.logo{font-family:var(--font-serif);color:var(--text);letter-spacing:-.02em;font-size:15px;font-weight:700;text-decoration:none}.logo:hover{text-underline-offset:3px;text-decoration:underline}.back-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-xs);background:0 0;border:none;padding:4px 8px;font-size:18px;transition:all .2s}.back-btn:hover{color:var(--text);background:var(--accent-glow)}.sidebar-header h2{font-family:var(--font-serif);color:var(--text);font-size:15px;font-weight:600;line-height:1.3}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex;overflow-y:auto}.nav-item{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:10px 12px;font-size:13px;transition:all .25s;display:flex;position:relative}.nav-item:hover{background:var(--accent-glow);color:var(--text)}.nav-item.active{background:var(--bg-surface-hover);color:var(--text);border:1px solid var(--border-hover);box-shadow:none}.nav-item.done .nav-icon{color:var(--success)}.nav-icon{text-align:center;width:24px;font-size:14px}.nav-label{flex:1}.nav-dot{background:var(--text-secondary);border-radius:50%;width:4px;height:4px}.sidebar-footer{border-top:1px solid var(--border);padding:16px}.progress-bar{background:#0ea5e91f;border-radius:2px;height:4px;margin-bottom:8px;overflow:hidden}.progress-fill{background:var(--accent-warm);border-radius:2px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.progress-text{color:var(--text-secondary);font-size:11px;font-weight:500}.main{z-index:1;flex-direction:column;flex:1;width:100%;min-width:0;max-width:100%;display:flex;position:relative;overflow:clip auto}.main-header{border-bottom:1px solid var(--border);background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:16px 32px;display:flex}.header-title-row{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.mobile-back-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-xs);background:0 0;flex-shrink:0;padding:4px 10px;font-size:16px;transition:all .2s;display:none}.mobile-back-btn:hover{color:var(--text);border-color:var(--accent)}.main-header h1{color:var(--text);text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:20px;font-weight:700;overflow:hidden}.header-actions{align-items:center;gap:8px;display:flex}.chat-toggle{color:var(--accent-dark);border-radius:var(--radius-sm);cursor:pointer;background:#0ea5e914;border:1px solid #0ea5e940;padding:8px 16px;font-size:13px;font-weight:500;transition:all .25s}.chat-toggle:hover{border-color:var(--accent);background:#0ea5e924}.content{flex:1;padding:32px;animation:.4s fadeUp;overflow-y:auto}.main-footer{border-top:1px solid var(--border);background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);flex-shrink:0;justify-content:space-between;padding:16px 32px;display:flex}.btn{border-radius:var(--radius-xs);cursor:pointer;border:none;padding:10px 20px;font-size:13px;font-weight:600;transition:all .2s}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:var(--text-on-accent)}.btn-primary:hover:not(:disabled){background:var(--accent-light);color:var(--text-on-accent);box-shadow:none}.btn-secondary{background:var(--bg-surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-surface-hover);border-color:var(--border-hover)}.btn-large{padding:14px 32px;font-size:15px}.course-menu{width:100%;max-width:1100px;padding:var(--space-4);margin:0 auto;animation:none}.menu-header{margin-bottom:var(--space-6);text-align:left;border-bottom:1px solid var(--border);max-width:640px;padding-bottom:var(--space-5)}.menu-eyebrow{margin-bottom:var(--space-3);color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;font-size:11px;font-weight:600;display:block}.menu-eyebrow a{color:var(--text);font-weight:700;text-decoration:none}.menu-eyebrow a:hover{text-underline-offset:3px;text-decoration:underline}.menu-eyebrow-sep{opacity:.35;margin:0 8px;font-weight:400}.menu-header h1{font-family:var(--font-serif);letter-spacing:-.03em;color:var(--text);margin-bottom:var(--space-1);font-size:28px;font-weight:700;line-height:1.05}.menu-product{color:var(--text-secondary);letter-spacing:.14em;text-transform:uppercase;margin-bottom:var(--space-4);font-size:15px;font-weight:500}.menu-subtitle{color:var(--text-secondary);max-width:520px;margin:0;font-size:17px;line-height:1.65}.menu-subtitle em,.menu-subtitle strong{font-style:normal;font-weight:inherit;color:inherit}.menu-brand{margin-top:var(--space-4);color:var(--text-muted);font-size:13px}.menu-brand a{color:var(--text-secondary);text-underline-offset:3px;font-weight:500;text-decoration:underline}.menu-brand a:hover{color:var(--text)}.user-badge{margin-left:var(--space-3);background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);border-radius:100px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-flex}.dashboard-stats{gap:var(--space-5);margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--border);flex-wrap:wrap;display:flex}.stat-pill{background:0 0;border:none;border-radius:0;align-items:baseline;gap:6px;padding:0;font-size:13px;display:flex}.stat-pill.locked{cursor:pointer;text-underline-offset:3px;text-decoration:underline}.stat-pill.locked:hover,.stat-pill.accent .stat-pill-num{color:var(--accent-warm)}.stat-pill-num{color:var(--text);font-size:15px;font-weight:700}.stat-pill-label{color:var(--text-secondary)}.featured-section{margin-bottom:var(--space-6)}.featured-label{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;padding:0 2px;display:flex}.featured-badge{color:var(--text);letter-spacing:.12em;text-transform:uppercase;background:0 0;border:none;border-radius:0;align-items:center;padding:4px 0;font-size:11px;font-weight:700;display:inline-flex}.featured-badge:before{display:none}.featured-cta{color:var(--text-muted);font-size:13px}.featured-card{gap:var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-4);text-align:center;cursor:pointer;color:inherit;grid-template-columns:1fr;align-items:center;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:grid;position:relative;overflow:hidden}.featured-card:hover{border-color:var(--border-hover);background:var(--bg-surface-hover)}.featured-icon{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto;display:flex}.course-icon{border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.hero-icon{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-surface);justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 16px;display:flex}.featured-body{min-width:0}.featured-body h2{font-family:var(--font-serif);margin-bottom:var(--space-2);color:var(--text);letter-spacing:-.02em;font-size:24px;font-weight:600}.featured-subtitle{color:var(--text-secondary);margin-bottom:var(--space-2);font-size:14px}.featured-desc{color:var(--text-muted);max-width:600px;font-size:14px;line-height:1.6}.featured-meta{color:var(--text-muted);gap:var(--space-3);margin-top:var(--space-3);font-size:12px;display:flex}.featured-actions{align-items:center;gap:var(--space-3);flex-direction:column;flex-shrink:0;width:100%;display:flex}.trending-badge{color:var(--accent-warm);border:1px solid var(--border);border-radius:var(--radius-xs);letter-spacing:.08em;text-transform:uppercase;background:0 0;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.featured-action{background:var(--accent);color:var(--text-on-accent);border-radius:var(--radius-xs);white-space:nowrap;text-align:center;width:100%;padding:10px 18px;font-size:13px;font-weight:600;transition:background .2s}.featured-card:hover .featured-action{background:var(--accent-light);box-shadow:none}.category-bar{gap:var(--space-2);margin-bottom:var(--space-5);padding:2px 2px var(--space-3);scrollbar-width:thin;flex-wrap:nowrap;display:flex;overflow-x:auto}.category-bar::-webkit-scrollbar{height:3px}.category-bar::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:2px}.cat-tab{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;border-radius:100px;flex-shrink:0;font-size:13px;font-weight:500;transition:all .2s;display:flex}.cat-tab:hover{border-color:var(--border-hover);color:var(--text);background:var(--bg-surface-hover)}.cat-tab.active{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent);box-shadow:none}.cat-tab.active .cat-count{color:var(--text-on-accent);background:#faf8f433}.cat-icon{font-size:13px}.cat-count{background:var(--border);color:var(--text-secondary);border-radius:12px;padding:1px 7px;font-size:11px;font-weight:600}.course-grid{gap:var(--space-3);margin-bottom:var(--space-6);grid-template-columns:1fr;display:grid}.course-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:left;cursor:pointer;box-shadow:var(--shadow-sm);color:inherit;flex-direction:column;padding:0;text-decoration:none;transition:all .25s cubic-bezier(.4,0,.2,1);animation:.4s backwards fadeUp;display:flex;position:relative;overflow:hidden}.course-card:first-child{animation-delay:40ms}.course-card:nth-child(2){animation-delay:80ms}.course-card:nth-child(3){animation-delay:.12s}.course-card:nth-child(4){animation-delay:.16s}.course-card:nth-child(5){animation-delay:.2s}.course-card:hover{border-color:var(--border-hover);background:var(--bg-surface-hover);box-shadow:var(--shadow);transform:none}.course-card-glow{display:none}.course-card-body{padding:var(--space-4);z-index:1;flex:1;position:relative}.course-card-top{margin-bottom:var(--space-3);justify-content:space-between;align-items:flex-start;display:flex}.course-badges{gap:var(--space-1);flex-direction:column;align-items:flex-end;display:flex}.course-badge{letter-spacing:.3px;white-space:nowrap;border-radius:100px;align-items:center;padding:3px 8px;font-size:10px;font-weight:600;display:inline-flex}.course-badge.new{color:var(--accent-dark);background:#0ea5e91a;border:1px solid #0ea5e933}.course-badge.premium{color:var(--warning);background:#f59e0b14;border:1px solid #f59e0b26}.course-cat-badge{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);margin-bottom:var(--space-2);letter-spacing:.3px;border-radius:100px;padding:3px 10px;font-size:10px;font-weight:600;display:inline-flex}.course-card h2{font-family:var(--font-serif);margin-bottom:var(--space-1);color:var(--text);letter-spacing:-.01em;font-size:17px;font-weight:600;line-height:1.35}.course-subtitle{color:var(--text-secondary);margin-bottom:var(--space-3);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;line-height:1.45;display:-webkit-box;overflow:hidden}.course-desc{color:var(--text-muted);font-size:13px;line-height:1.5}.course-meta{color:var(--text-muted);margin-top:var(--space-3);gap:var(--space-2);align-items:center;font-size:11px;display:flex}.course-dot{opacity:.4}.course-progress-mini{margin-top:var(--space-3);align-items:center;gap:var(--space-2);display:flex}.cp-bar{background:var(--border);border-radius:2px;flex:1;height:3px;overflow:hidden}.cp-fill{border-radius:2px;height:100%;transition:width .5s}.cp-text{color:var(--text-muted);white-space:nowrap;font-size:10px;font-weight:500}.course-card-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border);z-index:1;text-align:left;position:relative}.course-cta{color:var(--text);letter-spacing:.3px;font-size:12px;font-weight:700;transition:all .2s}.course-card:hover .course-cta{color:var(--accent-light)}.empty-cat{text-align:center;color:var(--text-muted);padding:var(--space-7) 0;font-size:14px}.dashboard-cta{justify-content:space-between;align-items:center;gap:var(--space-5);max-width:900px;margin:var(--space-7) auto 0;padding:var(--space-5) var(--space-6);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);text-align:left;display:flex}.dashboard-cta-text h3{margin-bottom:var(--space-1);color:var(--text);letter-spacing:-.2px;font-size:17px;font-weight:600}.dashboard-cta-text p{color:var(--text-secondary);max-width:560px;font-size:14px;line-height:1.6}.welcome{text-align:center;max-width:800px;margin:0 auto;animation:.5s fadeUp}.welcome-hero{margin-bottom:48px}.welcome-hero h1{font-family:var(--font-serif);color:var(--text);letter-spacing:-.03em;margin-bottom:12px;font-size:40px;font-weight:700}.hero-subtitle{color:var(--text-secondary);margin-bottom:16px;font-size:18px;font-weight:500}.hero-desc{color:var(--text-secondary);max-width:600px;margin:0 auto;font-size:15px;line-height:1.7}.welcome-highlights{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:40px;display:grid}.highlight-card{background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);padding:24px;transition:all .3s;animation:.5s backwards fadeUp}.highlight-card:first-child{animation-delay:.1s}.highlight-card:nth-child(2){animation-delay:.2s}.highlight-card:nth-child(3){animation-delay:.3s}.highlight-card:hover{box-shadow:var(--accent-glow);border-color:#0ea5e94d;transform:translateY(-4px)}.highlight-icon{margin-bottom:12px;font-size:36px;display:block}.highlight-card h3{color:var(--text);margin-bottom:8px;font-size:16px;font-weight:700}.highlight-card p{color:var(--text-secondary);font-size:13px;line-height:1.5}.welcome-quotes{flex-direction:column;gap:16px;margin-bottom:40px;display:flex}.welcome-quotes blockquote{background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);border-left:3px solid var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-secondary);text-align:left;padding:16px 20px;font-size:14px;font-style:italic;line-height:1.7}.welcome-quotes cite{color:var(--accent-light);margin-top:8px;font-size:12px;font-style:normal;font-weight:500;display:block}.step-viewer{max-width:900px;margin:0 auto}.step-header{margin-bottom:24px;animation:.3s fadeUp}.step-badge{background:linear-gradient(135deg, var(--accent), var(--accent-light));color:var(--text-on-accent);letter-spacing:.5px;text-transform:uppercase;border-radius:20px;margin-bottom:12px;padding:4px 14px;font-size:11px;font-weight:700;display:inline-block}.step-intro{color:var(--text-secondary);white-space:pre-line;font-size:16px;line-height:1.8}.code-block{background:var(--code-bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px;overflow:hidden;box-shadow:0 4px 24px #0003}.code-header{border-bottom:1px solid var(--border);color:var(--text-secondary);background:#0ea5e90f;justify-content:space-between;align-items:center;padding:10px 16px;font-size:13px;display:flex}.code-lang{color:var(--accent-light);text-transform:uppercase;letter-spacing:.5px;background:#0ea5e91a;border-radius:4px;padding:2px 10px;font-size:10px;font-weight:600}.code-block pre{color:var(--code-text);padding:20px;font-family:Cascadia Code,Fira Code,JetBrains Mono,monospace;font-size:13px;line-height:1.7;overflow-x:auto}.section-tabs{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.section-tab{border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;background:#0ea5e90a;padding:8px 16px;font-size:12px;font-weight:500;transition:all .25s}.section-tab:hover{color:var(--text);background:#0ea5e914;border-color:#0ea5e94d}.section-tab.active{background:linear-gradient(135deg, var(--accent), var(--accent-light));color:var(--text-on-accent);border-color:#0000;box-shadow:0 4px 15px #0ea5e94d}.section-panel{animation:.3s fadeUp;display:none}.section-panel.visible{display:block}.section-panel.hidden{display:none}.step-card{background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:24px;transition:all .25s;animation:.3s backwards fadeUp}.step-card:hover{border-color:#0ea5e926}.card-title{color:var(--accent-light);margin-bottom:12px;font-size:16px;font-weight:700}.card-content{color:var(--text);font-size:14px;line-height:1.8}.card-content p{margin-bottom:8px}.quote-card{border-left:3px solid var(--warning);background:#fdcb6e0a}.quote-card .card-content p{color:var(--text-secondary);font-style:italic}.diagram-card{background:var(--bg-glass);border-color:#0ea5e91a;overflow-x:auto}.diagram{color:var(--accent-light);white-space:pre;font-family:Cascadia Code,Fira Code,JetBrains Mono,monospace;font-size:12px;line-height:1.5}.card-code{background:var(--bg-glass);border-radius:var(--radius-sm);color:var(--success);margin-top:12px;padding:12px;font-size:13px;line-height:1.5;overflow-x:auto}.comparison-table,.usecases-table{border-collapse:collapse;width:100%;font-size:13px}.comparison-table th,.usecases-table th{text-align:left;border-bottom:1px solid var(--border);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;font-size:11px;font-weight:600}.comparison-table td,.usecases-table td{border-bottom:1px solid #0ea5e90f;padding:12px 16px}.comparison-table tr:last-child td,.usecases-table tr:last-child td{border-bottom:none}.comparison-table tr:hover td,.usecases-table tr:hover td{background:#0ea5e908}.dimension-cell{color:var(--accent-light);font-weight:600}.loop-cell{color:var(--success);font-weight:500}.badge{border-radius:20px;padding:4px 12px;font-size:11px;font-weight:600}.badge-loop{background:var(--success-soft);color:var(--success)}.badge-prompt{color:var(--warning);background:#fdcb6e1f}.api-key-banner{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);z-index:50;color:var(--text-secondary);align-items:center;gap:12px;padding:14px 24px;font-size:13px;display:flex;position:fixed;bottom:0;left:0;right:0}.api-key-banner input{background:var(--bg-glass);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);width:300px;padding:8px 14px;font-size:13px;transition:all .2s}.api-key-banner input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 20px #0ea5e91a}.ai-chat{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);border-left:1px solid var(--border);z-index:100;flex-direction:column;width:420px;height:100vh;animation:.3s slideLeft;display:flex;position:fixed;top:0;right:0}.chat-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;font-size:14px;font-weight:700;display:flex}.chat-close{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-xs);background:0 0;border:none;padding:4px 8px;font-size:18px;transition:all .2s}.chat-close:hover{color:var(--text);background:#0ea5e91a}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.chat-msg{animation:.3s fadeUp;display:flex}.chat-msg.user{justify-content:flex-end}.msg-bubble{border-radius:18px;max-width:85%;padding:12px 16px;font-size:13px;line-height:1.6}.chat-msg.assistant .msg-bubble{background:var(--bg-surface);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}.chat-msg.user .msg-bubble{background:linear-gradient(135deg, var(--accent), var(--accent-light));color:var(--text-on-accent);border-bottom-right-radius:4px}.typing{padding:16px 20px!important}.dot-pulse{background:var(--accent-light);border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite pulse;display:inline-block}.dot-pulse:nth-child(2){animation-delay:.15s}.dot-pulse:nth-child(3){animation-delay:.3s}@keyframes pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.chat-input{border-top:1px solid var(--border);gap:8px;padding:12px 16px;display:flex}.chat-input input{background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);flex:1;padding:10px 14px;font-size:13px;transition:all .2s}.chat-input input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 20px #0ea5e91a}.chat-input button{background:linear-gradient(135deg, var(--accent), var(--accent-light));border-radius:var(--radius-sm);color:var(--text-on-accent);cursor:pointer;border:none;padding:10px 18px;font-size:16px;transition:all .2s;box-shadow:0 4px 15px #0ea5e94d}.chat-input button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #0ea5e966}.chat-input button:disabled{opacity:.4;cursor:not-allowed}.login-screen{justify-content:center;align-items:center;width:100%;min-height:100vh;padding:24px;display:flex}.login-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:48px 40px;animation:.5s fadeUp}.login-wordmark{font-family:var(--font-serif);color:var(--text);letter-spacing:-.03em;cursor:default;-webkit-user-select:none;user-select:none;margin-bottom:8px;font-size:36px;font-weight:700}.login-brand-line{letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:20px;font-size:13px;font-weight:500}.login-brand-line a{color:var(--text-secondary);text-decoration:none}.login-brand-line a:hover{color:var(--text);text-underline-offset:3px;text-decoration:underline}.login-box h1{display:none}.login-sub{color:var(--text-secondary);margin-bottom:32px;font-size:14px;line-height:1.6}.login-form{flex-direction:column;gap:12px;display:flex}.login-form input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);text-align:left;padding:14px 16px;font-size:15px;transition:all .2s}.login-form input:focus{border-color:var(--border-active);background:var(--bg-surface-hover);outline:none}.login-form input::placeholder{color:var(--text-muted)}.login-form button{background:var(--accent);border-radius:var(--radius-xs);color:var(--text-on-accent);cursor:pointer;border:none;margin-top:6px;padding:14px;font-size:15px;font-weight:600;transition:background .2s}.login-form button:hover:not(:disabled){background:var(--accent-light);box-shadow:none}.form-error{color:var(--danger);text-align:center;background:var(--danger-soft);border-radius:var(--radius-xs);border:1px solid var(--danger-border);padding:10px 12px;font-size:13px}.login-form button:disabled{opacity:.5;cursor:not-allowed}.login-toggle{color:var(--text-secondary);cursor:pointer;margin-top:24px;font-size:13px;transition:color .2s}.login-toggle:hover{color:var(--text)}.top-bar{z-index:10;background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;width:100%;max-width:100%;padding:12px 16px;display:flex;position:sticky;top:0}.top-bar .theme-toggle{margin-right:auto}.top-bar-credits,.top-bar-admin,.top-bar-user{cursor:pointer;border-radius:var(--radius-xs);background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);white-space:nowrap;max-width:100%;padding:6px 10px;font-size:12px;font-weight:500;transition:all .2s}.top-bar-credits:hover{border-color:var(--success);color:var(--success);background:var(--success-soft)}.top-bar-admin:hover,.top-bar-user:hover{border-color:var(--border-hover);color:var(--text)}.course-card.locked{opacity:.75}.course-card.locked:hover{opacity:1}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (width>=640px){.course-menu{padding:var(--space-5) var(--space-4)}.course-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,260px),1fr))}.top-bar{padding:16px 24px}.top-bar-credits,.top-bar-admin,.top-bar-user{padding:7px 14px;font-size:13px}}@media (width>=769px){.app{flex-direction:row;height:100vh;min-height:0}.featured-card{gap:var(--space-6);padding:var(--space-6);text-align:left;grid-template-columns:auto 1fr auto}.featured-icon{margin:0}.featured-actions{align-items:flex-end;width:auto}.featured-action{width:auto}}@media (width>=900px){.course-menu{padding:var(--space-6) var(--space-5)}.course-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.menu-header h1{font-size:48px}}.mobile-step-select{display:none}@media (width<=1024px){.sidebar{width:220px}.ai-chat{width:360px}.course-grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.course-menu{padding:var(--space-5) var(--space-4)}.menu-header h1{font-size:32px}.featured-card{gap:var(--space-4);grid-template-columns:auto 1fr}.featured-actions{flex-direction:row;grid-column:1/-1;justify-content:space-between;align-items:center}.featured-action{text-align:center;flex:1}}@media (width<=768px){body{scrollbar-gutter:auto;overflow-y:auto}.sidebar{display:none}.mobile-step-select{align-items:center;gap:8px;width:100%;display:flex}.mobile-step-select select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);flex:1;max-width:200px;padding:8px 12px;font-size:13px}.mobile-step-select select:focus{border-color:var(--accent);outline:none}.mobile-step-select .progress-text{color:var(--text-secondary);white-space:nowrap;font-size:12px}.main{min-height:100vh;overflow-y:visible}.mobile-back-btn{justify-content:center;align-items:center;display:inline-flex}.main-header{padding:12px 16px}.main-header h1{font-size:16px}.content{padding:16px}.main-footer{flex-wrap:wrap;gap:8px;padding:12px 16px}.main-footer .btn{text-align:center;flex:1;padding:12px 16px;font-size:13px}.how-it-works{align-items:stretch;gap:var(--space-3);padding:var(--space-3);flex-direction:column}.how-step-arrow{display:none}.course-menu{padding:var(--space-4)}.menu-header{margin-bottom:var(--space-5)}.menu-subtitle{font-size:14px}.dashboard-stats{gap:var(--space-2)}.course-card-body{padding:var(--space-4)}.course-card h2{font-size:15px}.stat-pill{padding:5px 10px;font-size:11px}.stat-pill-num{font-size:13px}.featured-card{text-align:center;padding:var(--space-4);grid-template-columns:1fr}.featured-icon{margin:0 auto}.featured-actions{align-items:center;width:100%}.featured-action{width:100%}.dashboard-cta{text-align:center;padding:var(--space-4);gap:var(--space-4);flex-direction:column}.welcome{padding:0}.hero-icon{font-size:48px}.welcome-hero h1{font-size:28px}.hero-subtitle{font-size:15px}.welcome-highlights{grid-template-columns:1fr;gap:12px}.highlight-card{padding:16px}.btn-large{width:100%;padding:14px 32px;font-size:14px}.step-viewer{padding:0}.step-header{margin-bottom:16px}.step-intro{font-size:14px}.step-card{margin-bottom:12px;padding:16px}.card-title{font-size:14px}.card-content{font-size:13px}.code-block pre{padding:12px;font-size:12px}.code-header{padding:8px 12px;font-size:12px}.section-tabs{gap:6px}.section-tab{padding:6px 12px;font-size:11px}.diagram{font-size:10px}.comparison-table,.usecases-table{font-size:12px}.comparison-table th,.usecases-table th,.comparison-table td,.usecases-table td{padding:8px}.comparison-card,.usecases-card{overflow-x:auto}.comparison-card table,.usecases-card table{min-width:360px}.ai-chat{border-left:none;width:100%;left:0}.chat-messages{padding:12px}.msg-bubble{max-width:90%;font-size:14px}.chat-input{padding:10px 12px}.api-key-banner{flex-direction:column;gap:8px;padding:12px 16px}.api-key-banner input{width:100%}.welcome-quotes blockquote{padding:12px 16px;font-size:13px}}.modal-overlay{background:var(--overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;box-sizing:border-box;justify-content:center;align-items:center;width:100%;height:100%;margin:0;padding:24px;display:flex;position:fixed;top:0;left:0;transform:none}.modal-content{background:var(--bg-surface);border:1px solid var(--border);border-radius:24px;width:100%;max-width:640px;max-height:90vh;margin:auto;padding:40px;animation:.3s fadeUp;position:relative;overflow-y:auto}.modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:20px;position:absolute;top:16px;right:20px}.modal-content h2{background:linear-gradient(135deg, var(--success), var(--accent-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:16px;font-size:24px}.credits-balance{color:var(--text-secondary);margin-bottom:4px;font-size:15px}.credits-balance strong{color:var(--success)}.credits-info{color:var(--text-secondary);margin-bottom:28px;font-size:13px}.credits-packages{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.credit-card{background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:24px 20px;transition:all .25s;position:relative}.credit-card:hover{border-color:var(--accent);box-shadow:0 0 30px #6c5ce71a}.credit-card.popular{border-color:var(--success);box-shadow:0 0 30px var(--success-soft)}.credit-badge{background:linear-gradient(135deg, var(--success), var(--accent-light));color:var(--text-on-accent);white-space:nowrap;border-radius:20px;padding:4px 12px;font-size:10px;font-weight:700;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.credit-amount{color:var(--text);margin-bottom:4px;font-size:32px;font-weight:800}.credit-label{color:var(--text);margin-bottom:4px;font-size:14px;font-weight:700}.credit-desc{color:var(--text-secondary);margin-bottom:16px;font-size:11px}.credit-price{color:var(--accent-light);margin-bottom:16px;font-size:16px;font-weight:700}.credit-card .btn{width:100%;padding:10px;font-size:13px}.credit-card .btn:disabled{opacity:.5}@media (width<=600px){.credits-packages{grid-template-columns:1fr}.modal-content{padding:24px}}.admin-content{max-width:900px}.admin-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.admin-error{color:var(--danger);margin-bottom:12px;font-size:13px}.admin-stats-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-bottom:20px;display:grid}.stat-card{background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;flex-direction:column;gap:4px;padding:14px;display:flex}.stat-num{color:var(--accent-light);font-size:22px;font-weight:800}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:11px}.admin-tabs{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.admin-tab{background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-secondary);cursor:pointer;padding:8px 16px;font-size:13px;transition:all .2s}.admin-tab.active{border-color:var(--accent);color:var(--text);background:var(--accent-soft)}.admin-tab:hover{border-color:var(--accent)}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;font-size:12px}.admin-table th{text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap;text-transform:uppercase;letter-spacing:.3px;padding:8px 10px;font-size:11px;font-weight:600}.admin-table td{border-bottom:1px solid var(--border-subtle);color:var(--text);padding:8px 10px}.admin-table td.num{text-align:right;font-variant-numeric:tabular-nums}.admin-table tr:hover td{background:var(--accent-soft)}.btn-add-credits{border:1px dashed var(--border);color:var(--accent);cursor:pointer;vertical-align:middle;background:0 0;border-radius:4px;margin-left:6px;padding:2px 6px;font-size:14px;line-height:1}.btn-add-credits:hover{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}.add-credits-inline{align-items:center;gap:4px;margin-left:6px;display:inline-flex}.add-credits-inline input{border:1px solid var(--border);background:var(--bg);width:60px;color:var(--text);border-radius:4px;padding:2px 6px;font-size:12px}.btn-xs{min-width:auto!important;padding:1px 6px!important;font-size:11px!important}.course-reviews{margin-top:var(--space-7);padding-top:var(--space-5);border-top:1px solid var(--border);text-align:left;width:100%}.course-reviews h3{margin-bottom:var(--space-2);color:var(--text);letter-spacing:-.2px;font-size:17px;font-weight:600}.reviews-avg{color:var(--text-secondary);margin-bottom:var(--space-5);font-size:14px}.reviews-avg strong{color:var(--text);font-weight:700}.review-form{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-4);margin-bottom:var(--space-5);gap:var(--space-3);flex-direction:column;display:flex}.star-picker{align-items:center;gap:2px;display:flex}.star-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px;font-size:22px;line-height:1;transition:all .15s}.star-btn.on{color:var(--warning)}.star-btn:hover{color:var(--warning);transform:scale(1.1)}.star-label{color:var(--text-secondary);margin-left:var(--space-2);font-size:13px;font-weight:500}.review-form textarea{border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg-elevated);width:100%;color:var(--text);resize:vertical;box-sizing:border-box;min-height:90px;padding:12px 14px;font-family:inherit;font-size:14px;transition:all .2s}.review-form textarea:focus{border-color:var(--border-active);background:var(--bg-surface-hover);outline:none}.review-form textarea::placeholder{color:var(--text-muted)}.review-form .btn{align-self:flex-end}.reviews-list{gap:var(--space-3);flex-direction:column;display:flex}.review-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:var(--space-4);transition:all .2s}.review-card:hover{border-color:var(--border-hover);background:var(--bg-surface-hover)}.review-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);flex-wrap:wrap;display:flex}.review-author{color:var(--text);font-size:13px;font-weight:600}.review-stars{color:var(--warning);letter-spacing:1px;font-size:13px}.review-date{color:var(--text-muted);margin-left:auto;font-size:11px}.review-comment{color:var(--text-secondary);margin:0;font-size:14px;line-height:1.6}.reviews-empty{color:var(--text-muted);text-align:center;padding:var(--space-5);font-size:14px}.reviews-thanks{color:var(--text-secondary);padding:var(--space-4);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:var(--space-5);font-size:14px}.reviews-summary{margin-top:var(--space-5);text-align:left;width:100%}.reviews-summary h3{margin-bottom:var(--space-1);font-size:15px}.reviews-summary .reviews-avg{margin-bottom:16px}.reviews-thanks{color:var(--text-muted);text-align:center;padding:12px;font-size:14px}@media (width<=480px){.menu-header h1{font-size:20px}.main-header h1{font-size:14px}.content{padding:12px}.course-menu{padding:16px 12px}.course-card-body,.step-card{padding:12px}.code-block pre{padding:8px;font-size:11px}.section-tab{padding:5px 10px;font-size:10px}.mobile-step-select select{max-width:150px;padding:6px 10px;font-size:12px}}.unlock-top{border-bottom:1px solid var(--border);background:var(--bg-glass);justify-content:space-between;align-items:center;width:100%;padding:16px 24px;display:flex}.unlock-top-actions{align-items:center;gap:8px;display:flex}.unlock-back{color:var(--text-secondary);font-size:13px;font-weight:500;text-decoration:none}.unlock-back:hover{color:var(--text);text-underline-offset:3px;text-decoration:underline}.unlock-page{width:100%;max-width:640px;padding:var(--space-7) var(--space-5);margin:0 auto}.unlock-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-6)}.unlock-card-header{gap:var(--space-4);margin-bottom:var(--space-5);align-items:flex-start;display:flex}.unlock-icon{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;display:flex}.unlock-card-intro{min-width:0}.unlock-card-intro h1{font-family:var(--font-serif);letter-spacing:-.02em;margin:var(--space-2) 0 var(--space-1);font-size:28px;font-weight:700;line-height:1.2}.unlock-subtitle{color:var(--text-secondary);font-size:15px;line-height:1.5}.unlock-desc{color:var(--text-secondary);margin-bottom:var(--space-5);font-size:15px;line-height:1.65}.unlock-meta{gap:var(--space-3);margin-bottom:var(--space-5);padding-bottom:var(--space-5);border-bottom:1px solid var(--border);flex-wrap:wrap;list-style:none;display:flex}.unlock-meta li{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);font-size:12px;font-weight:600}.unlock-price{align-items:baseline;gap:var(--space-2);margin-bottom:var(--space-5);display:flex}.unlock-price-num{font-family:var(--font-serif);color:var(--text);font-size:40px;font-weight:700;line-height:1}.unlock-price-label{color:var(--text-secondary);font-size:14px}.unlock-warning{color:var(--accent-warm);margin-bottom:var(--space-4);font-size:14px}.unlock-link-btn{font:inherit;color:var(--text);cursor:pointer;background:0 0;border:none;margin-left:6px;padding:0;font-weight:600;text-decoration:underline}.unlock-actions{gap:var(--space-2);flex-wrap:wrap;display:flex}.unlock-actions .btn-primary{flex:1;min-width:160px}.unlock-footer{margin-top:var(--space-5);text-align:center;color:var(--text-muted);font-size:13px}.unlock-footer a{color:var(--text-secondary);text-underline-offset:3px;text-decoration:underline}@media (width<=768px){.unlock-page,.unlock-card{padding:var(--space-4)}.unlock-card-header{flex-direction:column}.unlock-icon{width:56px;height:56px}.unlock-card-intro h1{font-size:22px}.unlock-actions{flex-direction:column}.unlock-actions .btn{width:100%}}.theme-toggle{border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg-surface);width:34px;height:34px;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;padding:0;transition:border-color .2s,color .2s,background .2s;display:inline-flex}.theme-toggle:hover{border-color:var(--border-hover);color:var(--text);background:var(--bg-surface-hover)}.login-theme-row{justify-content:flex-end;margin:-8px 0 12px;display:flex}.sidebar-footer-row{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}
