[data-theme=dark]{--background:#0a0e1a;--surface:#111827;--surface-alt:#1a2035;--text:#e2e8f0;--text-muted:#94a3b8;--accent:#f59e0b;--accent-hover:#fbbf24;--border:#1e293b;--code-bg:#151c2c;--g1-color:#38bdf8;--g2-color:#a78bfa;--gt-color:#f472b6;--success:#34d399;--warning:#fbbf24;--error:#f87171}[data-theme=light]{--background:#f8fafc;--surface:#fff;--surface-alt:#f1f5f9;--text:#1e293b;--text-muted:#64748b;--accent:#d97706;--accent-hover:#b45309;--border:#e2e8f0;--code-bg:#f1f5f9;--g1-color:#0369a1;--g2-color:#7c3aed;--gt-color:#db2777;--success:#059669;--warning:#d97706;--error:#dc2626}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--background);color:var(--text);-webkit-tap-highlight-color:transparent;min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.6}.skip-link{background:var(--accent);color:var(--background);z-index:100;border-radius:0 0 6px;padding:.5rem 1rem;font-size:.9rem;text-decoration:none;position:absolute;top:-100%;left:0}.skip-link:focus{top:0}h1,h2,h3,h4{color:var(--text);font-weight:600;line-height:1.3}h1{letter-spacing:-.02em;font-size:2rem}h2{border-bottom:1px solid var(--border);margin-bottom:.75rem;padding-bottom:.5rem;font-size:1.5rem}h3{margin-bottom:.5rem;font-size:1.15rem}p{color:var(--text-muted);margin-bottom:.75rem}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}code,.mono{font-family:SF Mono,Cascadia Code,Fira Code,Consolas,monospace;font-size:.875em}code{background:var(--code-bg);border:1px solid var(--border);border-radius:4px;padding:.15em .4em}pre{background:var(--code-bg);border:1px solid var(--border);border-radius:8px;padding:1rem;font-family:SF Mono,Cascadia Code,Fira Code,Consolas,monospace;font-size:.85rem;line-height:1.5;overflow-x:auto}#app{max-width:960px;margin:0 auto;padding:1rem 1.5rem 3rem}header{text-align:center;border-bottom:1px solid var(--border);margin-bottom:2rem;padding:2rem 0 1.5rem;position:relative}header .subtitle{color:var(--text-muted);margin-top:.25rem;font-size:1.05rem}header .portfolio-link{color:var(--accent);margin-top:.5rem;font-size:.85rem;display:inline-block}.theme-toggle{z-index:10;border:1px solid var(--border);background:var(--surface);width:2.6rem;height:2.6rem;color:var(--text);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;transition:background .2s,border-color .2s;display:flex;position:absolute;top:0;right:0}.theme-toggle:hover{background:var(--surface-alt);border-color:var(--accent)}.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}section.demo-section{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:1.5rem;padding:1.5rem}section.demo-section h2{border-bottom-color:var(--border)}.group-boxes{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin:1rem 0;display:grid}.group-box{background:var(--surface-alt);border:1px solid var(--border);text-align:center;border-radius:8px;padding:1rem}.group-box.g1{border-top:3px solid var(--g1-color)}.group-box.g2{border-top:3px solid var(--g2-color)}.group-box.gt{border-top:3px solid var(--gt-color)}.group-box .group-label{margin-bottom:.25rem;font-size:1.1rem;font-weight:700}.group-box.g1 .group-label{color:var(--g1-color)}.group-box.g2 .group-label{color:var(--g2-color)}.group-box.gt .group-label{color:var(--gt-color)}.group-box .group-detail{color:var(--text-muted);font-size:.85rem}.math-block{background:var(--code-bg);border:1px solid var(--border);text-align:center;border-radius:8px;margin:1rem 0;padding:1rem 1.25rem;font-family:SF Mono,Cascadia Code,Fira Code,Consolas,monospace;font-size:.95rem;overflow-x:auto}.math-block .g1{color:var(--g1-color)}.math-block .g2{color:var(--g2-color)}.math-block .gt{color:var(--gt-color)}button{border:1px solid var(--border);background:var(--surface-alt);color:var(--text);cursor:pointer;border-radius:6px;padding:.5rem 1.1rem;font-family:inherit;font-size:.9rem;transition:background .15s,border-color .15s}button:hover:not(:disabled){background:var(--accent);color:var(--background);border-color:var(--accent)}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}button.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}button.danger{color:var(--error);border-color:var(--error);background:0 0}button.danger:hover:not(:disabled){background:var(--error);color:var(--background)}input[type=text],input[type=range]{font-family:inherit;font-size:.9rem}input[type=text]{background:var(--code-bg);border:1px solid var(--border);color:var(--text);border-radius:6px;width:100%;padding:.5rem .75rem}input[type=text]:focus{outline:2px solid var(--accent);outline-offset:1px}input[type=range]{width:100%;accent-color:var(--accent)}.controls{flex-wrap:wrap;align-items:center;gap:.5rem;margin:1rem 0;display:flex}.controls label{color:var(--text-muted);font-size:.9rem}.field-group{margin-bottom:.75rem}.field-group label{color:var(--text-muted);margin-bottom:.25rem;font-size:.85rem;display:block}.output-block{background:var(--code-bg);border:1px solid var(--border);word-break:break-all;border-radius:8px;margin:.75rem 0;padding:.75rem 1rem;font-family:SF Mono,Cascadia Code,Fira Code,Consolas,monospace;font-size:.8rem;line-height:1.6}.output-block .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;font-family:Segoe UI,system-ui,sans-serif;font-size:.75rem}.output-block .value{color:var(--text)}.output-block .value.g1{color:var(--g1-color)}.output-block .value.g2{color:var(--g2-color)}.output-block .value.gt{color:var(--gt-color)}.badge{border-radius:4px;padding:.2rem .6rem;font-size:.85rem;font-weight:600;display:inline-block}.badge.valid{background:color-mix(in srgb, var(--success) 15%, transparent);color:var(--success);border:1px solid var(--success)}.badge.invalid{background:color-mix(in srgb, var(--error) 15%, transparent);color:var(--error);border:1px solid var(--error)}.timing{flex-wrap:wrap;gap:.75rem;margin:.75rem 0;font-size:.85rem;display:flex}.timing .timing-item{background:var(--surface-alt);border:1px solid var(--border);border-radius:6px;padding:.35rem .7rem}.timing .timing-item .timing-label{color:var(--text-muted);margin-right:.3rem}.timing .timing-item .timing-value{color:var(--accent);font-family:SF Mono,monospace;font-weight:600}.metric-banner{background:var(--surface-alt);border:2px solid var(--accent);text-align:center;border-radius:10px;margin:1rem 0;padding:1rem 1.25rem;font-size:1rem;line-height:1.6}.metric-banner strong{color:var(--accent)}.table-wrap{-webkit-overflow-scrolling:touch;margin:1rem 0;overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:420px;font-size:.9rem}th,td{border:1px solid var(--border);text-align:left;padding:.5rem .75rem}th{background:var(--surface-alt);color:var(--text);font-weight:600}td{color:var(--text-muted)}.signer-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem;margin:1rem 0;display:grid}.signer-card{background:var(--surface-alt);border:1px solid var(--border);text-align:center;opacity:1;border-radius:6px;padding:.5rem;font-size:.75rem;transition:all .4s;transform:scale(1)}.signer-card .signer-index{color:var(--text);margin-bottom:.2rem;font-weight:700}.signer-card .signer-pk{color:var(--g2-color);font-family:SF Mono,monospace;font-size:.7rem}.signer-card .signer-sig{color:var(--g1-color);font-family:SF Mono,monospace;font-size:.7rem}.signer-card.merging{opacity:0;transform:scale(.3)translate(-50px)}.signer-card.aggregate{background:color-mix(in srgb, var(--accent) 10%, var(--surface-alt));border-color:var(--accent);grid-column:1/-1;padding:1rem;font-size:.85rem}.attack-visual{grid-template-columns:1fr 1fr;gap:1rem;margin:1rem 0;display:grid}.key-card{background:var(--surface-alt);border:1px solid var(--border);border-radius:8px;padding:1rem;font-size:.85rem}.key-card.malicious{border-color:var(--error);background:color-mix(in srgb, var(--error) 8%, var(--surface-alt))}.key-card .key-card-title{margin-bottom:.5rem;font-weight:600}.key-card.malicious .key-card-title{color:var(--error)}.defense-list{margin:1rem 0}.defense-item{background:var(--surface-alt);border:1px solid var(--border);border-radius:8px;margin-bottom:.75rem;padding:1rem}.defense-item h4{color:var(--accent);margin-bottom:.4rem}.deployment-grid{gap:1rem;margin:1rem 0;display:grid}.deployment-card{background:var(--surface-alt);border:1px solid var(--border);border-radius:8px;padding:1rem}.deployment-card h4{margin-bottom:.4rem}.note{background:color-mix(in srgb, var(--accent) 8%, var(--surface));border-left:3px solid var(--accent);color:var(--text-muted);border-radius:0 6px 6px 0;margin:.75rem 0;padding:.75rem 1rem;font-size:.9rem}footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);margin-top:2rem;padding:2rem 0 1rem;font-size:.85rem}footer .scripture{margin-top:.5rem;font-style:italic}@media (width<=640px){#app{padding:.75rem 1rem 2rem}h1{font-size:1.5rem}h2{font-size:1.25rem}.group-boxes,.attack-visual{grid-template-columns:1fr}.signer-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}.controls{flex-direction:column;align-items:stretch}.math-block{padding:.75rem;font-size:.82rem}section.demo-section{padding:1rem}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}
