.zk-tutorial{--primary:#6366f1;--primary-dark:#4f46e5;--secondary:#10b981;--accent:#f59e0b;--bg:#0f172a;--bg-light:#1e293b;--bg-card:#334155;--text:#f1f5f9;--text-muted:#94a3b8;--border:#475569;--success:#22c55e;--warning:#eab308;--error:#ef4444;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;font-size:18px;min-height:100vh}.zk-tutorial *,.zk-tutorial :after,.zk-tutorial :before{margin:0;padding:0;box-sizing:border-box}.zk-tutorial .nav{position:fixed;top:0;left:0;right:0;background:rgba(15,23,42,.95);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);z-index:1000;padding:1rem 2rem}.zk-tutorial .nav-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.zk-tutorial .nav-logo{font-weight:700;font-size:1.25rem;color:var(--primary)}.zk-tutorial .nav-links{display:flex;gap:.5rem}.zk-tutorial .nav-link{padding:.5rem 1rem;border-radius:.5rem;color:var(--text-muted);text-decoration:none;font-size:.9rem;transition:all .2s}.zk-tutorial .nav-link.active,.zk-tutorial .nav-link:hover{background:var(--bg-light);color:var(--text)}.zk-tutorial .progress-bar{position:fixed;top:60px;left:0;height:3px;background:var(--primary);z-index:999;transition:width .3s}.zk-tutorial main{max-width:900px;margin:0 auto;padding:100px 2rem 4rem}.zk-tutorial section{margin-bottom:6rem;scroll-margin-top:100px}.zk-tutorial h1{font-size:3rem;font-weight:800;margin-bottom:1.5rem;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.zk-tutorial h2{font-size:2rem;font-weight:700;margin:3rem 0 1.5rem;color:var(--primary);display:flex;align-items:center;gap:.75rem}.zk-tutorial h2 .part-number{background:var(--primary);color:white;padding:.25rem .75rem;border-radius:.5rem;font-size:.9rem}.zk-tutorial h3{font-size:1.5rem;font-weight:600;margin:2rem 0 1rem;color:var(--text)}.zk-tutorial p{margin-bottom:1.25rem;color:var(--text)}.zk-tutorial .lead{font-size:1.25rem;color:var(--text-muted);margin-bottom:2rem}.zk-tutorial .concept-card{background:var(--bg-light);border:1px solid var(--border);border-radius:1rem;padding:2rem;margin:2rem 0}.zk-tutorial .concept-card h4{color:var(--secondary);font-size:1.1rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.zk-tutorial .highlight-box{background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(16,185,129,.1));border-left:4px solid var(--primary)}.zk-tutorial .highlight-box,.zk-tutorial .warning-box{padding:1.5rem;margin:2rem 0;border-radius:0 .5rem .5rem 0}.zk-tutorial .warning-box{background:rgba(245,158,11,.1);border-left:4px solid var(--accent)}.zk-tutorial .key-insight{background:rgba(16,185,129,.1);border:1px solid var(--secondary);border-radius:1rem;padding:1.5rem;margin:2rem 0}.zk-tutorial .key-insight:before{content:"\1F4A1 Key Insight";display:block;color:var(--secondary);font-weight:600;margin-bottom:.75rem}.zk-tutorial .code-block{background:#0d1117;border:1px solid var(--border);border-radius:.75rem;padding:1.5rem;margin:1.5rem 0;overflow-x:auto;font-family:Fira Code,Consolas,monospace;font-size:.9rem;line-height:1.6;white-space:pre-wrap;word-wrap:break-word}.zk-tutorial .code-block .comment{color:#6a737d}.zk-tutorial .code-block .keyword{color:#ff7b72}.zk-tutorial .code-block .function{color:#d2a8ff}.zk-tutorial .code-block .string{color:#a5d6ff}.zk-tutorial .code-block .number{color:#79c0ff}.zk-tutorial code{background:var(--bg-card);padding:.2rem .5rem;border-radius:.25rem;font-family:Fira Code,Consolas,monospace;font-size:.9em}.zk-tutorial .interactive-demo{background:var(--bg-light);border:2px solid var(--primary);border-radius:1rem;padding:2rem;margin:2rem 0}.zk-tutorial .interactive-demo h4{color:var(--primary);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.zk-tutorial .interactive-demo h4:before{content:"\1F3AE"}.zk-tutorial .demo-controls{display:flex;gap:1rem;margin:1rem 0;flex-wrap:wrap}.zk-tutorial button{background:var(--primary);color:white;border:none;padding:.75rem 1.5rem;border-radius:.5rem;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s}.zk-tutorial button:hover{background:var(--primary-dark);transform:translateY(-2px)}.zk-tutorial button:active{transform:translateY(0)}.zk-tutorial button.secondary{background:var(--bg-card);border:1px solid var(--border)}.zk-tutorial button.secondary:hover{background:var(--border)}.zk-tutorial input[type=number],.zk-tutorial input[type=text]{background:var(--bg-card);border:1px solid var(--border);color:var(--text);padding:.75rem 1rem;border-radius:.5rem;font-size:1rem;width:120px}.zk-tutorial input:focus{outline:none;border-color:var(--primary)}.zk-tutorial .demo-output{background:var(--bg);border-radius:.5rem;padding:1.5rem;margin-top:1rem;font-family:Fira Code,monospace;min-height:60px}.zk-tutorial .diagram{background:var(--bg-light);border-radius:1rem;padding:2rem;margin:2rem 0;text-align:center}.zk-tutorial .diagram svg{max-width:100%;height:auto}.zk-tutorial .diagram-caption{color:var(--text-muted);font-size:.9rem;margin-top:1rem;font-style:italic}.zk-tutorial ol,.zk-tutorial ul{margin:1rem 0 1.5rem 1.5rem}.zk-tutorial li{margin-bottom:.5rem}.zk-tutorial .analogy{background:linear-gradient(135deg,var(--bg-light),var(--bg-card));border-radius:1rem;padding:2rem;margin:2rem 0;position:relative}.zk-tutorial .analogy:before{content:"\1F3AD Analogy";position:absolute;top:-12px;left:20px;background:var(--accent);color:var(--bg);padding:.25rem .75rem;border-radius:.5rem;font-size:.85rem;font-weight:600}.zk-tutorial .steps{counter-reset:step;margin:2rem 0}.zk-tutorial .step{position:relative;padding-left:4rem;margin-bottom:2rem}.zk-tutorial .step:before{counter-increment:step;content:counter(step);position:absolute;left:0;top:0;width:3rem;height:3rem;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem}.zk-tutorial .step h4{color:var(--text);font-size:1.2rem;margin-bottom:.5rem}.zk-tutorial .math{font-style:italic;font-size:1.1em}.zk-tutorial .math,.zk-tutorial .math-block{font-family:Times New Roman,serif;color:var(--secondary)}.zk-tutorial .math-block{background:var(--bg-card);padding:1.5rem;border-radius:.5rem;text-align:center;margin:1.5rem 0;font-size:1.3rem;overflow-x:auto}.zk-tutorial .comparison{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin:2rem 0}.zk-tutorial .comparison-item{background:var(--bg-light);padding:1.5rem;border-radius:.75rem}.zk-tutorial .comparison-item.good{border:2px solid var(--success)}.zk-tutorial .comparison-item.bad{border:2px solid var(--error)}.zk-tutorial .comparison-item h5{margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.zk-tutorial .toc{background:var(--bg-light);border-radius:1rem;padding:2rem;margin:2rem 0}.zk-tutorial .toc h3{margin-top:0;margin-bottom:1rem}.zk-tutorial .toc-list{list-style:none;margin:0;padding:0}.zk-tutorial .toc-list li{margin:0;padding:0}.zk-tutorial .toc-list a{display:block;padding:.75rem 1rem;color:var(--text-muted);text-decoration:none;border-radius:.5rem;transition:all .2s}.zk-tutorial .toc-list a:hover{background:var(--bg-card);color:var(--text);padding-left:1.5rem}.zk-tutorial .toc-list .part-label{color:var(--primary);font-weight:600}@keyframes zkTutorialFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.zk-tutorial section{animation:zkTutorialFadeIn .5s ease-out}.zk-tutorial .footnote{font-size:.85rem;color:var(--text-muted);border-top:1px solid var(--border);padding-top:1rem;margin-top:3rem}.zk-tutorial .protocol-box{background:var(--bg);border:2px solid var(--secondary);border-radius:1rem;padding:2rem;margin:2rem 0}.zk-tutorial .protocol-box h4{color:var(--secondary);margin-bottom:1rem;font-size:1.2rem}.zk-tutorial .protocol-step{display:flex;gap:1rem;margin:1rem 0;align-items:flex-start}.zk-tutorial .protocol-step .actor{background:var(--primary);color:white;padding:.25rem .75rem;border-radius:.25rem;font-size:.85rem;font-weight:600;min-width:80px;text-align:center}.zk-tutorial .protocol-step .actor.verifier{background:var(--secondary)}.zk-tutorial .quiz{background:var(--bg-light);border-radius:1rem;padding:2rem;margin:2rem 0}.zk-tutorial .quiz h4{color:var(--accent);margin-bottom:1rem}.zk-tutorial .quiz-option{display:block;padding:1rem;margin:.5rem 0;background:var(--bg-card);border:2px solid transparent;border-radius:.5rem;cursor:pointer;transition:all .2s}.zk-tutorial .quiz-option:hover{border-color:var(--primary)}.zk-tutorial .quiz-option.correct{border-color:var(--success);background:rgba(34,197,94,.1)}.zk-tutorial .quiz-option.incorrect{border-color:var(--error);background:rgba(239,68,68,.1)}.zk-tutorial .quiz-feedback{margin-top:1rem;padding:1rem;border-radius:.5rem;display:none}.zk-tutorial .quiz-feedback.show{display:block}.zk-tutorial .quiz-feedback.correct{background:rgba(34,197,94,.1);border:1px solid var(--success)}.zk-tutorial .quiz-feedback.incorrect{background:rgba(239,68,68,.1);border:1px solid var(--error)}.zk-tutorial .tool-link{display:flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,rgba(99,102,241,.15),rgba(16,185,129,.15));border:1px solid var(--primary);border-radius:.75rem;padding:1rem 1.25rem;margin:1.5rem 0;text-decoration:none;color:var(--text);transition:all .2s}.zk-tutorial .tool-link:hover{transform:translateY(-2px);box-shadow:0 4px 20px rgba(99,102,241,.3);border-color:var(--secondary)}.zk-tutorial .tool-link-icon{font-size:1.5rem}.zk-tutorial .tool-link-content{flex:1}.zk-tutorial .tool-link-title{font-weight:600;color:var(--primary);margin-bottom:.25rem}.zk-tutorial .tool-link-desc{font-size:.9rem;color:var(--text-muted)}.zk-tutorial .tool-link-arrow{color:var(--primary);font-size:1.25rem}@media (max-width:768px){.zk-tutorial h1{font-size:2rem}.zk-tutorial h2{font-size:1.5rem}.zk-tutorial .comparison{grid-template-columns:1fr}.zk-tutorial .nav-links{display:none}.zk-tutorial main{padding:80px 1rem 2rem}}.zk-explorer{--primary:#6366f1;--secondary:#10b981;--accent:#f59e0b;--bg:#0f172a;--bg-light:#1e293b;--text:#f1f5f9;--text-muted:#94a3b8;font-family:Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;padding:1rem}.zk-explorer *,.zk-explorer :after,.zk-explorer :before{margin:0;padding:0;box-sizing:border-box}.zk-explorer .container{max-width:1200px;margin:0 auto}.zk-explorer h1{font-size:1.75rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.zk-explorer .subtitle{color:var(--text-muted);margin-bottom:1.5rem;font-size:.95rem;line-height:1.5}.zk-explorer .demo-grid{display:flex;flex-direction:column;gap:1.5rem}.zk-explorer .canvas-container{background:var(--bg-light);border-radius:1rem;padding:.75rem;width:100%}.zk-explorer canvas{display:block;width:100%;height:280px;border-radius:.5rem;background:var(--bg)}.zk-explorer .controls{background:var(--bg-light);border-radius:1rem;padding:1.25rem}.zk-explorer .control-section{margin-bottom:1.25rem}.zk-explorer .control-section h3{color:var(--primary);font-size:1rem;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.zk-explorer .control-section h3.poly-2-title{color:var(--secondary)}.zk-explorer .degree-control{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;padding:.5rem;background:var(--bg);border-radius:.5rem}.zk-explorer .degree-control label{font-size:.85rem;min-width:60px}.zk-explorer .degree-control input[type=range]{flex:1;height:6px;accent-color:var(--primary)}.zk-explorer .degree-control .degree-val{font-family:Courier New,monospace;font-weight:700;min-width:20px;text-align:center}.zk-explorer .polynomial-display{background:var(--bg);padding:.75rem;border-radius:.5rem;font-family:Courier New,monospace;margin-bottom:.75rem;font-size:.85rem;word-break:break-all;min-height:2.5rem}.zk-explorer .poly-1{color:var(--primary)}.zk-explorer .poly-2{color:var(--secondary)}.zk-explorer .coefficients-container{max-height:200px;overflow-y:auto;padding-right:.5rem}.zk-explorer .slider-group{margin-bottom:.6rem}.zk-explorer .slider-group label{display:flex;justify-content:space-between;margin-bottom:.3rem;font-size:.8rem}.zk-explorer .slider-group input[type=range]{width:100%;height:6px;accent-color:var(--primary);cursor:pointer}.zk-explorer .slider-group.poly-2 input[type=range]{accent-color:var(--secondary)}.zk-explorer .button-row{display:flex;gap:.5rem;margin-bottom:1rem}.zk-explorer button{background:var(--primary);color:white;border:none;padding:.7rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.9rem;flex:1;transition:all .2s;touch-action:manipulation}.zk-explorer button:hover{opacity:.9}.zk-explorer button:active{transform:scale(.98)}.zk-explorer button.secondary{background:var(--bg);border:1px solid var(--primary)}.zk-explorer .stats{background:var(--bg);padding:.75rem;border-radius:.5rem;margin-bottom:1rem}.zk-explorer .stat-item{display:flex;justify-content:space-between;padding:.4rem 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:.85rem}.zk-explorer .stat-item:last-child{border-bottom:none}.zk-explorer .stat-value{color:var(--accent);font-family:Courier New,monospace;font-weight:700}.zk-explorer .explanation{background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(16,185,129,.1));border-left:4px solid var(--primary);padding:1rem;margin-top:1rem;border-radius:0 .5rem .5rem 0;font-size:.9rem;line-height:1.6}.zk-explorer .test-point{background:rgba(245,158,11,.15);border:1px solid var(--accent);padding:1rem;border-radius:.5rem}.zk-explorer .test-point h4{color:var(--accent);margin-bottom:.5rem;font-size:.95rem}.zk-explorer .test-point p{font-size:.85rem;color:var(--text-muted);margin-bottom:.75rem}.zk-explorer .test-point button{width:100%;margin-bottom:.75rem}.zk-explorer .test-result{font-family:Courier New,monospace;padding:.75rem;background:var(--bg);border-radius:.25rem;font-size:.8rem;line-height:1.6}.zk-explorer .match{color:#22c55e}.zk-explorer .no-match{color:#ef4444}.zk-explorer .back-link{display:inline-block;color:var(--text-muted);text-decoration:none;margin-bottom:1rem;font-size:.85rem;padding:.5rem 0}.zk-explorer .back-link:hover{color:var(--text)}.zk-explorer .coefficients-container::-webkit-scrollbar{width:6px}.zk-explorer .coefficients-container::-webkit-scrollbar-track{background:var(--bg);border-radius:3px}.zk-explorer .coefficients-container::-webkit-scrollbar-thumb{background:var(--bg-light);border-radius:3px}@media (min-width:768px){.zk-explorer{padding:2rem}.zk-explorer h1{font-size:2.25rem}.zk-explorer .subtitle{font-size:1.1rem}.zk-explorer .demo-grid{display:grid;grid-template-columns:1fr 380px;gap:2rem}.zk-explorer canvas{height:400px}.zk-explorer .control-section h3{font-size:1.1rem}.zk-explorer .polynomial-display,.zk-explorer .stat-item{font-size:.9rem}}@media (min-width:1024px){.zk-explorer canvas{height:450px}.zk-explorer .demo-grid{grid-template-columns:1fr 420px}}