[data-theme=dark]{--background:#0f1117;--surface:#1a1b26;--surface-alt:#222333;--text:#c9ccd6;--text-muted:#8b8fa3;--accent:#7c8aff;--accent-hover:#9da6ff;--border:#2d2f3d;--code-bg:#1e1f2e;--sender-color:#60a5fa;--sender-surface:#172237;--receiver-color:#fbbf24;--receiver-surface:#27220f;--channel-color:#9ca3af;--success:#34d399;--warning:#fb923c;--hidden:#ef4444}[data-theme=light]{--background:#f8f9fb;--surface:#fff;--surface-alt:#f0f1f4;--text:#374151;--text-muted:#6b7280;--accent:#4f46e5;--accent-hover:#4338ca;--border:#dfe2e8;--code-bg:#eef0f4;--sender-color:#2563eb;--sender-surface:#eff6ff;--receiver-color:#d97706;--receiver-surface:#fffbeb;--channel-color:#6b7280;--success:#059669;--warning:#ea580c;--hidden:#dc2626}*,:before,:after{box-sizing:border-box}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}fieldset{border:none;margin:0;padding:0}body{color:var(--text);background:var(--background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:1rem;line-height:1.6}h1,h2,h3{color:var(--text);margin:0 0 .75rem;line-height:1.25}h1{letter-spacing:-.02em;font-size:1.85rem}h2{margin-top:2.5rem;font-size:1.5rem}h3{color:var(--text-muted);margin-top:1.5rem;font-size:1.15rem}p{margin:0 0 1rem}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.skip-link{z-index:100;background:var(--accent);color:#fff;border-radius:0 0 6px;padding:.75rem 1.25rem;font-weight:600;text-decoration:none;position:absolute;top:0;left:-9999px}.skip-link:focus{left:0}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}code{background:var(--code-bg);border-radius:4px;padding:.15em .4em;font-family:ui-monospace,Cascadia Code,Fira Code,Consolas,monospace;font-size:.875em}strong{color:var(--text)}ul{margin:0 0 1rem;padding-left:1.5rem}li{margin-bottom:.35rem}sub{font-size:.75em}.container{max-width:1100px;margin:0 auto;padding:0 1.5rem}.section{border-bottom:1px solid var(--border);padding:2.5rem 0}.section:last-child{border-bottom:none}.subsection{margin-top:2rem}.site-header{border-bottom:1px solid var(--border);padding:2rem 0 1.5rem;position:relative}.header-inner{justify-content:space-between;align-items:center;display:flex}.subtitle{color:var(--text-muted);margin:0;font-size:.95rem}.theme-toggle{border:1px solid var(--border);background:var(--surface);width:2.75rem;min-width:44px;height:2.75rem;min-height:44px;color:var(--text);cursor:pointer;z-index:10;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.2rem;transition:background .2s,border-color .2s;display:flex}.theme-toggle:hover{background:var(--surface-alt);border-color:var(--accent)}.card{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-bottom:1rem;padding:1.25rem}.sender-panel{border-left:3px solid var(--sender-color);background:var(--sender-surface)}.receiver-panel{border-left:3px solid var(--receiver-color);background:var(--receiver-surface)}.channel-panel{border-left:3px solid var(--channel-color)}.panel-label{text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem;font-size:.8rem;font-weight:600}.panel-label.sender{color:var(--sender-color)}.panel-label.receiver{color:var(--receiver-color)}.panel-label.channel{color:var(--channel-color)}.ot-visual{flex-wrap:wrap;justify-content:center;align-items:center;gap:1.5rem;margin:1.5rem 0;display:flex}.ot-visual-sender,.ot-visual-receiver{text-align:center;border-radius:8px;min-width:140px;padding:1rem 1.25rem}.ot-visual-sender{background:var(--sender-surface);border:1px solid var(--sender-color)}.ot-visual-receiver{background:var(--receiver-surface);border:1px solid var(--receiver-color)}.ot-visual-channel{flex-direction:column;align-items:center;gap:.25rem;display:flex}.ot-visual-arrow{color:var(--channel-color);font-size:2rem;line-height:1}.ot-visual-label{text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;font-size:.8rem;font-weight:600}.ot-visual-msg{border-radius:4px;margin:.25rem 0;padding:.35rem .75rem;font-family:ui-monospace,Consolas,monospace;font-size:.9rem}.ot-visual-msg.unlocked{background:color-mix(in srgb, var(--success) 15%, transparent);color:var(--success)}.ot-visual-msg.locked,.ot-visual-msg.hidden-msg{background:color-mix(in srgb, var(--hidden) 12%, transparent);color:var(--hidden);opacity:.8}.ot-visual-choice{color:var(--receiver-color);margin-bottom:.5rem;font-weight:600}.protocol-flow{grid-template-columns:1fr auto 1fr;gap:0;margin:1.5rem 0;font-size:.9rem;display:grid}.flow-col{padding:.75rem}.flow-header{text-align:center;border-bottom:2px solid var(--border);margin-bottom:.5rem;padding-bottom:.75rem;font-weight:700}.flow-step{border-bottom:1px dashed var(--border);align-items:center;min-height:3.5rem;padding:.6rem 0;display:flex}.flow-step:last-child{border-bottom:none}.flow-sender .flow-step{color:var(--sender-color)}.flow-receiver .flow-step{color:var(--receiver-color)}.flow-channel .flow-step{text-align:center;color:var(--channel-color);justify-content:center;font-family:ui-monospace,Consolas,monospace;font-size:.85rem}.ot-demo{grid-template-columns:1fr 200px 1fr;gap:1rem;margin:1.5rem 0;display:grid}@media (width<=860px){.ot-demo{grid-template-columns:1fr}}.demo-sender,.demo-receiver{border-radius:8px;padding:1.25rem}.demo-sender{background:var(--sender-surface);border:1px solid var(--sender-color)}.demo-receiver{background:var(--receiver-surface);border:1px solid var(--receiver-color)}.demo-channel{flex-direction:column;align-items:center;gap:.75rem;padding-top:2.5rem;display:flex}.channel-msg{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:6px;width:100%;padding:.5rem .75rem;font-size:.75rem;animation:.4s ease-out channelSlide}.channel-msg .direction{color:var(--channel-color);margin-bottom:.25rem;font-weight:600;display:block}.channel-msg .payload{color:var(--text-muted);word-break:break-all;font-family:ui-monospace,Consolas,monospace;font-size:.7rem}@keyframes channelSlide{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}textarea{border:1px solid var(--border);background:var(--surface);width:100%;min-height:3rem;color:var(--text);resize:vertical;border-radius:6px;margin-bottom:.75rem;padding:.6rem;font-family:inherit;font-size:.9rem}textarea:focus{outline:2px solid var(--accent);outline-offset:-1px}label{color:var(--text-muted);margin-bottom:.3rem;font-size:.85rem;display:block}.radio-group{gap:1.25rem;margin:.5rem 0 .75rem;display:flex}.radio-group label{cursor:pointer;color:var(--text);align-items:center;gap:.4rem;font-size:.9rem;display:flex}input[type=radio]{accent-color:var(--receiver-color)}.btn{border:1px solid var(--border);background:var(--surface);min-height:44px;color:var(--text);cursor:pointer;border-radius:6px;align-items:center;gap:.4rem;padding:.65rem 1.2rem;font-family:inherit;font-size:.9rem;transition:background .15s,border-color .15s;display:inline-flex}.btn:hover:not(:disabled){background:var(--surface-alt);border-color:var(--accent)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-sender{border-color:var(--sender-color);color:var(--sender-color)}.btn-sender:hover:not(:disabled){background:var(--sender-surface)}.btn-receiver{border-color:var(--receiver-color);color:var(--receiver-color)}.btn-receiver:hover:not(:disabled){background:var(--receiver-surface)}.hex-block{background:var(--code-bg);border:1px solid var(--border);word-break:break-all;color:var(--text-muted);border-radius:6px;margin:.5rem 0;padding:.6rem .8rem;font-family:ui-monospace,Consolas,monospace;font-size:.78rem;line-height:1.5}.hex-block .hex-label{color:var(--text);margin-bottom:.3rem;font-family:system-ui,sans-serif;font-size:.75rem;font-weight:600;display:block}.hex-label.private{color:var(--warning)}.redacted-container{border-radius:6px;margin:.5rem 0;position:relative;overflow:hidden}.redacted-content{color:var(--hidden);filter:blur(6px);-webkit-user-select:none;user-select:none;word-break:break-all;background:var(--code-bg);padding:.6rem .8rem;font-family:ui-monospace,Consolas,monospace;font-size:.78rem}.redacted-label{color:var(--hidden);background:color-mix(in srgb, var(--surface) 60%, transparent);pointer-events:none;justify-content:center;align-items:center;font-size:.85rem;font-weight:600;display:flex;position:absolute;inset:0}.audit-grid{grid-template-columns:1fr 1fr;gap:1rem;margin:1.5rem 0;display:grid}@media (width<=640px){.audit-grid{grid-template-columns:1fr}}.audit-box{border:1px solid var(--border);background:var(--surface);border-radius:8px;padding:1rem}.audit-box .audit-question{color:var(--text-muted);margin-bottom:.5rem;font-size:.85rem;font-weight:600}.audit-box .audit-answer{color:var(--success);font-size:.9rem}.decrypted-msg{background:color-mix(in srgb, var(--success) 10%, var(--surface));border:1px solid var(--success);color:var(--success);border-radius:6px;margin:.5rem 0;padding:.75rem 1rem;font-size:.95rem}.table-wrapper{margin:1rem 0;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.9rem}th,td{text-align:left;border-bottom:1px solid var(--border);padding:.6rem .8rem}th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;background:var(--surface-alt);font-size:.8rem;font-weight:600}td{color:var(--text)}.correctness-results{flex-direction:column;gap:.75rem;margin:1rem 0;display:flex}.result-row{background:var(--surface);border:1px solid var(--border);border-radius:6px;align-items:center;gap:.75rem;padding:.6rem 1rem;font-size:.9rem;display:flex}.result-icon{font-size:1.3rem}.ddh-points{flex-direction:column;gap:.75rem;margin:1rem 0;display:flex}.ddh-point{background:var(--code-bg);border:1px solid var(--border);border-radius:6px;padding:.6rem .8rem}.ddh-point-label{color:var(--text-muted);margin-bottom:.25rem;font-size:.8rem;font-weight:600}.ddh-point-hex{word-break:break-all;color:var(--text);font-family:ui-monospace,Consolas,monospace;font-size:.78rem}.note{background:var(--surface-alt);border-left:3px solid var(--accent);border-radius:0 6px 6px 0;margin:1rem 0;padding:.75rem 1rem;font-size:.9rem}.warning-note{background:color-mix(in srgb, var(--warning) 8%, var(--surface));border-left:3px solid var(--warning);border-radius:0 6px 6px 0;margin:1rem 0;padding:.75rem 1rem;font-size:.9rem}.xref-map{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;margin:1rem 0;display:grid}.xref-item{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;font-size:.88rem}.xref-item.current{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, var(--surface))}.xref-item strong{margin-bottom:.25rem;display:block}.site-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);padding:2rem 0;font-size:.85rem}.site-footer a{color:var(--accent)}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:1rem;height:1rem;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.step-tag{text-transform:uppercase;letter-spacing:.06em;border-radius:3px;margin-bottom:.5rem;padding:.15rem .5rem;font-size:.7rem;font-weight:700;display:inline-block}.step-tag.sender{background:color-mix(in srgb, var(--sender-color) 15%, transparent);color:var(--sender-color)}.step-tag.receiver{background:color-mix(in srgb, var(--receiver-color) 15%, transparent);color:var(--receiver-color)}@media (width<=640px){h1{font-size:1.4rem}h2{font-size:1.25rem}.header-inner{flex-wrap:wrap;gap:.75rem}.ot-visual{flex-direction:column}.ot-visual-arrow{transform:rotate(90deg)}.protocol-flow{grid-template-columns:1fr;gap:.5rem}.protocol-flow .flow-channel{border-bottom:1px solid var(--border);order:-1;padding-bottom:.5rem}.protocol-flow .flow-sender{order:0}.protocol-flow .flow-receiver{order:1}.ot-demo{grid-template-columns:1fr}.demo-channel{flex-flow:wrap;gap:.5rem;padding-top:0}.channel-msg{flex:auto;width:auto;min-width:120px}.audit-grid{grid-template-columns:1fr}.radio-group{flex-direction:column;gap:.75rem}.xref-map{grid-template-columns:1fr}}
