:root{--alice: #00d4ff;--bob: #ff00aa;--blinded: #ffd700;--double-blinded: #9d4edd;--match: #00ff88;--no-match: #6b6b8a;--private: #ff3366;--warning: #ffaa00;--bg: #0a0a0f;--surface: #12121e;--surface2: #1a1a2e;--border: #2d2d44;--text: #e0e0ff;--text-muted: #9999bb;--radius: 8px;--mono: "Fira Code", "Cascadia Code", "JetBrains Mono", ui-monospace, monospace;--focus: #00d4ff}[data-theme=light]{--bg: #f8f8ff;--surface: #ffffff;--surface2: #f0f0f8;--border: #c8c8dd;--text: #1a1a2e;--text-muted: #5555aa;--no-match: #888899}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,sans-serif;line-height:1.6;min-height:100vh;overflow-x:hidden}:focus-visible{outline:2px solid var(--focus);outline-offset:3px;border-radius:4px}.skip-link{position:absolute;top:-3rem;left:1rem;padding:.5rem 1rem;background:var(--alice);color:var(--bg);border-radius:0 0 var(--radius) var(--radius);font-weight:600;font-size:.9rem;z-index:9999;text-decoration:none;transition:top .15s}.skip-link:focus{top:0}#app{max-width:960px;margin:0 auto;padding:1rem}header{text-align:center;padding:2rem 1rem 1.25rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem}header h1{font-size:clamp(1.5rem,5vw,2rem);letter-spacing:-.5px;color:var(--alice)}header p{color:var(--text-muted);max-width:600px;margin:.5rem auto 0;font-size:clamp(.85rem,2.5vw,1rem)}[role=tablist]{display:flex;gap:0;overflow-x:auto;-webkit-overflow-scrolling:touch;border-bottom:2px solid var(--border);margin-bottom:1.5rem;scrollbar-width:none}[role=tablist]::-webkit-scrollbar{display:none}[role=tab]{flex-shrink:0;padding:.6rem .9rem;border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:clamp(.78rem,2vw,.9rem);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;white-space:nowrap;min-height:44px}[role=tab]:hover{color:var(--text)}[role=tab][aria-selected=true]{color:var(--alice);border-bottom-color:var(--alice);font-weight:600}[role=tabpanel]{display:none;animation:fadeIn .2s ease}[role=tabpanel].active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}h2{font-size:clamp(1.1rem,4vw,1.3rem);margin-bottom:.75rem;color:var(--text)}h3{margin:1.25rem 0 .5rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;font-size:.78rem}p{margin-bottom:.75rem;color:var(--text-muted);font-size:clamp(.85rem,2.5vw,1rem)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem}.card-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:540px){.card-row{grid-template-columns:1fr}}.set-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem}.set-label.alice{color:var(--alice)}.set-label.bob{color:var(--bob)}.element-list{list-style:none;display:flex;flex-direction:column;gap:.25rem}.element-list li{font-family:var(--mono);font-size:clamp(.72rem,2vw,.82rem);padding:.25rem .5rem;border-radius:4px;background:var(--surface2);border:1px solid var(--border);transition:background .3s,border-color .3s,box-shadow .3s;word-break:break-all}.element-list li.match{color:var(--match);border-color:var(--match);box-shadow:0 0 8px color-mix(in srgb,var(--match) 30%,transparent)}.element-list li.no-match{color:var(--no-match)}.element-list li.blinded{color:var(--blinded);border-color:color-mix(in srgb,var(--blinded) 40%,var(--border))}.element-list li.double-blinded{color:var(--double-blinded);border-color:color-mix(in srgb,var(--double-blinded) 40%,var(--border))}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1.1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface2);color:var(--text);cursor:pointer;font-size:clamp(.82rem,2vw,.875rem);transition:background .15s,border-color .15s;min-height:44px;min-width:44px}.btn:hover:not(:disabled){background:var(--surface);border-color:var(--alice)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--alice);color:var(--bg);border-color:var(--alice);font-weight:600}.btn.primary:hover:not(:disabled){filter:brightness(1.1)}.btn.danger{background:var(--private);color:#fff;border-color:var(--private)}.btn.danger:hover:not(:disabled){filter:brightness(1.1)}textarea{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--mono);font-size:clamp(.72rem,2vw,.82rem);padding:.75rem;resize:vertical;min-height:7rem}textarea:focus{outline:2px solid var(--focus);outline-offset:2px;border-color:var(--alice)}code,.mono{font-family:var(--mono);font-size:.82rem}pre{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;overflow-x:auto;font-family:var(--mono);font-size:clamp(.68rem,1.8vw,.8rem);line-height:1.6;white-space:pre;-webkit-overflow-scrolling:touch}.step-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem;min-height:180px}.step-counter{display:inline-flex;align-items:center;justify-content:center;width:1.8rem;height:1.8rem;border-radius:50%;background:var(--alice);color:var(--bg);font-weight:700;font-size:.85rem;margin-right:.5rem;flex-shrink:0}.step-nav{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.status{font-size:clamp(.78rem,2vw,.82rem);padding:.5rem .75rem;border-radius:var(--radius);margin-top:.25rem}.status.ok{color:var(--match)}.status.warn{color:var(--warning)}.status.error{color:var(--private)}.status.info{color:var(--alice)}.scalar-btn{display:inline-block;background:var(--private);color:var(--private);-webkit-user-select:none;user-select:none;border-radius:3px;font-family:var(--mono);font-size:.75rem;padding:.1rem .4rem;cursor:pointer;letter-spacing:1px;border:none;max-width:100%;overflow:hidden;text-overflow:ellipsis;word-break:break-all;transition:background .2s,color .2s}.scalar-btn.revealed{background:color-mix(in srgb,var(--private) 15%,var(--surface2));color:var(--private)}.scalar-btn:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.result-box{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-top:1rem}.intersection-item{display:flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:clamp(.78rem,2vw,.85rem);color:var(--match);padding:.2rem 0;word-break:break-all}.intersection-item:before{content:"✓";font-weight:700;flex-shrink:0}.info-grid{display:grid;grid-template-columns:auto 1fr;gap:.3rem .75rem;font-size:clamp(.78rem,2vw,.85rem);align-items:baseline}@media(max-width:400px){.info-grid{grid-template-columns:1fr;gap:.1rem}.info-label{margin-top:.4rem;font-size:.72rem}}.info-label{color:var(--text-muted)}.info-value{color:var(--text);font-family:var(--mono);word-break:break-all}.info-value.alice{color:var(--alice)}.info-value.bob{color:var(--bob)}.info-value.private{color:var(--private)}.info-value.match{color:var(--match)}.info-value.warning{color:var(--warning)}.warning-box{border:1px solid var(--warning);background:color-mix(in srgb,var(--warning) 10%,var(--surface));border-radius:var(--radius);padding:.85rem 1rem;color:var(--warning);font-size:clamp(.78rem,2vw,.875rem);margin-top:.75rem}.deployment-grid{display:grid;gap:.75rem}.deployment-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1.1rem}.deployment-card h4{color:var(--alice);font-size:.9rem;margin-bottom:.25rem}.deployment-card p{font-size:.84rem;margin:0}footer{margin-top:3rem;padding:1.5rem 0;border-top:1px solid var(--border);text-align:center;color:var(--text-muted);font-size:.82rem}.theme-toggle{position:fixed;top:.75rem;right:.75rem;padding:.4rem .7rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;font-size:.8rem;min-height:44px;min-width:44px;z-index:100}.theme-toggle:hover{border-color:var(--alice);color:var(--text)}.security-note{display:inline-block;background:color-mix(in srgb,var(--warning) 15%,var(--surface));border:1px solid var(--warning);border-radius:4px;padding:.15rem .5rem;font-size:.75rem;color:var(--warning);margin-left:.4rem;white-space:nowrap}.spinner{display:inline-block;width:.9rem;height:.9rem;border:2px solid var(--border);border-top-color:var(--alice);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.card-section-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:.5rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.exhibit{display:none}.exhibit.active{display:block}
