:root{--bg: #0a0e14;--surface: #111822;--surface-hover: #1a2433;--accent: #6ee7b7;--accent-dim: #34d399;--text: #d4dce8;--text-dim: #6b7d94;--border: #1e2d3d;--bit-0: #2a3444;--bit-1: #6ee7b7;--error: #f87171;--success: #6ee7b7;--warning: #fbbf24;--info: #60a5fa}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:14px}#app{display:flex;height:100%}#sidebar{width:260px;min-width:260px;background:var(--surface);border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column;gap:20px;overflow-y:auto}#sidebar h1{font-size:18px;font-weight:700;color:var(--accent);line-height:1.3;letter-spacing:-.5px}#experiment-list{display:flex;flex-direction:column;gap:4px}.experiment-card{padding:12px;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:all .15s ease;background:transparent;text-align:left;color:var(--text);font-family:inherit;font-size:inherit}.experiment-card:hover{background:var(--surface-hover)}.experiment-card.active{background:var(--surface-hover);border-color:var(--accent);border-left:3px solid var(--accent)}.experiment-card .name{font-weight:600;font-size:13px;margin-bottom:4px}.experiment-card .description{font-size:11px;color:var(--text-dim);line-height:1.4}#viewport{flex:1;overflow-y:auto;padding:32px}#experiment-container{max-width:900px;margin:0 auto}.experiment-header{margin-bottom:32px}.experiment-header h2{font-size:24px;color:var(--accent);margin-bottom:8px}.experiment-header p{color:var(--text-dim);font-size:13px;line-height:1.6;max-width:600px}.experiment-section{margin-top:24px;padding:20px;border:1px solid var(--border);border-radius:12px;background:var(--surface)}.experiment-section h3{font-size:13px;color:var(--accent-dim);text-transform:uppercase;letter-spacing:.8px;margin-bottom:16px}.crypto-input{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:14px;margin-bottom:12px}.crypto-input:focus{outline:none;border-color:var(--accent)}.crypto-textarea{width:100%;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:13px;resize:vertical;min-height:60px}.crypto-textarea:focus{outline:none;border-color:var(--accent)}.crypto-btn{padding:8px 16px;background:var(--surface-hover);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:12px;cursor:pointer;transition:all .15s ease}.crypto-btn:hover{border-color:var(--accent);color:var(--accent)}.crypto-btn.primary{background:color-mix(in srgb,var(--accent) 15%,var(--bg));border-color:var(--accent-dim);color:var(--accent)}.crypto-btn.primary:hover{background:color-mix(in srgb,var(--accent) 25%,var(--bg))}.crypto-btn:disabled{opacity:.4;cursor:not-allowed}.hash-output{padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;font-size:13px;word-break:break-all;line-height:1.6;margin-bottom:12px}.hash-label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-weight:600}.bit-grid{display:flex;flex-wrap:wrap;gap:2px;margin-bottom:12px}.bit-cell{width:18px;height:20px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;border-radius:3px;transition:all .1s ease}.bit-cell[data-value="1"]{background:color-mix(in srgb,var(--bit-1) 25%,var(--bg));color:var(--bit-1)}.bit-cell[data-value="0"]{background:var(--bit-0);color:var(--text-dim);opacity:.5}.bit-cell.diff{background:color-mix(in srgb,var(--error) 30%,var(--bg));color:var(--error);opacity:1}.bit-grid .byte-sep{width:4px}.status-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600}.status-badge.success{background:color-mix(in srgb,var(--success) 15%,var(--bg));color:var(--success)}.status-badge.error{background:color-mix(in srgb,var(--error) 15%,var(--bg));color:var(--error)}.status-badge.info{background:color-mix(in srgb,var(--info) 15%,var(--bg));color:var(--info)}.party-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.party-card{padding:16px;border:1px solid var(--border);border-radius:10px;background:var(--bg)}.party-card h4{font-size:14px;margin-bottom:12px;color:var(--accent)}.party-card .key-display{font-size:11px;word-break:break-all;color:var(--text-dim);line-height:1.5;padding:8px;background:var(--surface);border-radius:6px;margin-bottom:8px}.party-card .key-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin-bottom:4px;font-weight:600}.secret-compare{display:grid;grid-template-columns:1fr 1fr;gap:16px}.secret-box{padding:12px;border:1px solid var(--border);border-radius:8px;background:var(--bg)}.secret-box.match{border-color:var(--success)}.secret-box h5{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.secret-box .secret-value{font-size:11px;word-break:break-all;line-height:1.5;color:var(--text)}.exchange-arrow{display:flex;align-items:center;justify-content:center;padding:12px;font-size:13px;color:var(--accent-dim)}.controls-row{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.cipher-output{padding:12px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;font-size:12px;word-break:break-all;line-height:1.6;margin-bottom:12px;max-height:200px;overflow-y:auto}.format-tabs{display:flex;gap:4px;margin-bottom:12px}.format-tab{padding:4px 12px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-dim);font-family:inherit;font-size:11px;cursor:pointer;transition:all .12s ease}.format-tab:hover{border-color:var(--accent-dim);color:var(--text)}.format-tab.active{background:color-mix(in srgb,var(--accent) 15%,var(--bg));border-color:var(--accent);color:var(--accent)}.step-indicator{display:flex;gap:8px;margin-bottom:20px;align-items:center}.step{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-dim)}.step.active{color:var(--accent)}.step.complete{color:var(--success)}.step-number{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--border);font-size:10px;font-weight:700}.step.active .step-number{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 15%,var(--bg))}.step.complete .step-number{border-color:var(--success);background:color-mix(in srgb,var(--success) 15%,var(--bg))}.step-connector{width:24px;height:1px;background:var(--border)}#learn-section{border-top:1px solid var(--border);padding-top:16px;display:flex;flex-direction:column;gap:4px}.learn-heading{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim);margin-bottom:4px}.learn-group{border-radius:8px;overflow:hidden}.learn-group summary{padding:8px 12px;font-size:12px;font-weight:600;color:var(--text);cursor:pointer;border-radius:8px;transition:background .12s ease;list-style:none}.learn-group summary::-webkit-details-marker{display:none}.learn-group summary:before{content:"▸";display:inline-block;margin-right:8px;font-size:10px;color:var(--text-dim);transition:transform .15s ease}.learn-group[open] summary:before{transform:rotate(90deg)}.learn-group summary:hover{background:var(--surface-hover)}.learn-group p{padding:0 12px 8px;font-size:11px;color:var(--text-dim);line-height:1.6}.learn-links{display:flex;flex-direction:column;gap:2px}.learn-links a{display:block;padding:7px 12px;font-size:11px;color:var(--accent);text-decoration:none;border-radius:6px;transition:background .12s ease}.learn-links a:hover{background:var(--surface-hover);text-decoration:underline}


.exploration-site-header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border,#222233);background:var(--surface,#13131a);padding:8px 16px;z-index:100}
.exploration-site-name{color:var(--text,#d8d8e0);font-weight:700;font-size:14px;text-decoration:none;white-space:nowrap}
.exploration-site-name:hover{text-decoration:underline}
.exploration-site-nav{display:flex;flex-wrap:wrap;gap:6px 14px;align-items:center}
.exploration-site-nav a{color:var(--text-dim,#999);text-decoration:none;font-size:12px}
.exploration-site-nav a:hover,.exploration-site-nav a:focus-visible{color:var(--text,#d8d8e0);text-decoration:underline}
html,body{min-height:100%}
body{display:flex;flex-direction:column;min-height:100vh;min-height:100svh;min-height:100dvh}
#app{flex:1 0 auto;min-height:0}
@media (max-width:720px){.exploration-site-header{flex-wrap:wrap;padding:8px 12px}.exploration-site-nav{gap:6px 10px}}
@media (max-width:768px){html,body{overflow:auto}#app{flex-direction:column}#sidebar{width:100%;min-width:0;max-height:40vh;border-right:none;border-bottom:1px solid var(--border,#222233);overflow-y:auto}#viewport{min-height:50vh}}
