:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#090c16;--panel:#111726;--panel-2:#171f33;--text:#e7ecf7;--muted:#aeb9cf;--border:#ffffff1a;--server:#00d4ff;--phone:#f0a;--shared:gold;--purple:#9d4edd;--danger:#f36;--success:#0f8;--shadow:0 18px 50px #00000047;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f4f7fb;--panel:#fff;--panel-2:#eef3fb;--text:#101828;--muted:#475467;--border:#1018281f;--shadow:0 18px 40px #11182714}*{box-sizing:border-box}body{background:radial-gradient(circle at top left, #9d4edd40, transparent 20%), radial-gradient(circle at top right, #00d4ff33, transparent 20%), var(--bg);color:var(--text);margin:0;font-family:Inter,Segoe UI,Roboto,sans-serif}button,textarea,input{font:inherit}button{cursor:pointer}button:focus-visible,textarea:focus-visible,a:focus-visible{outline:3px solid var(--shared);outline-offset:2px}.skip-link{background:var(--shared);color:#111;z-index:10;border-radius:10px;padding:10px 14px;font-weight:700;text-decoration:none;position:absolute;top:-48px;left:12px}.skip-link:focus{top:12px}.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}#app{width:min(1280px,100%);min-height:100vh;margin:0 auto}.shell{gap:18px;padding:24px;display:grid}.panel{background:linear-gradient(180deg, var(--panel), var(--panel-2));border:1px solid var(--border);box-shadow:var(--shadow);border-radius:20px}.hero-section{grid-template-columns:2fr 1fr;gap:20px;padding:28px;display:grid}.eyebrow{color:var(--shared);letter-spacing:.12em;text-transform:uppercase;font-size:.85rem}h1,h2,h3,strong{color:var(--text)}h1{margin:12px 0;font-size:clamp(2.2rem,4vw,3.5rem);line-height:1.05}h2,h3{margin-top:0}.lead,p,li,blockquote,.small-note{color:var(--muted);line-height:1.6}blockquote{border-left:4px solid var(--shared);background:#ffd70014;border-radius:12px;margin:0 0 16px;padding:16px}blockquote span{color:var(--text);margin-top:8px;display:block}.badge-row,.button-row,.notice-row,.chip-row{flex-wrap:wrap;gap:10px;display:flex}.button-row>button{flex:190px}.badge,.chip{border:1px solid var(--border);border-radius:999px;padding:8px 12px;font-size:.92rem}.badge-gold{color:var(--shared);background:#ffd70024}.badge-green{color:var(--success);background:#00ff8824}.badge-purple,.chip{color:#dcc3ff;background:#9d4edd24}.primary-button,.secondary-button{border:1px solid var(--border);border-radius:12px;padding:10px 14px;transition:transform .15s,opacity .15s}.primary-button{background:linear-gradient(135deg, var(--server), var(--purple));color:#04111e;font-weight:700}.secondary-button{color:var(--text);background:#ffffff0a}.primary-button:hover,.secondary-button:hover{transform:translateY(-1px)}.primary-button:disabled,.secondary-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.status-banner{border:1px solid var(--border);border-radius:14px;width:100%;padding:14px 18px;font-weight:600}.tone-idle{background:#ffffff0a}.tone-working{background:#9d4edd24}.tone-success{background:#00ff881f}.tone-warning{background:#ffd7001f}.tone-danger{background:#ff336624}.protocol-stage{grid-template-columns:1fr 1.1fr 1fr;align-items:stretch;gap:18px;padding:20px;display:grid}.party-panel,.shared-lane{border:1px solid var(--border);border-radius:18px;padding:16px}.server-panel{background:#00d4ff14}.phone-panel{background:#ff00aa14}.shared-lane{background:#9d4edd14;align-content:center;gap:12px;display:grid}.party-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.dot{border-radius:50%;width:12px;height:12px;display:inline-block}.server-dot{background:var(--server)}.phone-dot{background:var(--phone)}.off-dot{background:var(--danger)}.masked-box{background:#090c1659;border-radius:14px;gap:8px;margin-top:14px;padding:12px;display:grid}.masked-row{flex-wrap:wrap;justify-content:space-between;gap:12px;font-size:.95rem;display:flex}.arrow{text-align:center;color:#eadcff;background:#9d4edd33;border-radius:10px;padding:10px}.arrow-right:after{content:" →"}.arrow-left:before{content:"← "}.joint-artifact{background:#ffd7001a;border:1px solid #ffd70040;border-radius:14px;padding:16px}.joint-title,.lane-label,.field-label{color:var(--shared);margin-bottom:8px;font-weight:700}.exhibits-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.exhibit{padding:20px}.live-exhibit,.applications-exhibit{grid-column:span 2}.comparison-stack{gap:12px;display:grid}.mini-card{border:1px solid var(--border);border-radius:14px;padding:14px}.bls-card{background:#00ff8814}.schnorr-card{background:#00d4ff14}.mldsa-card{background:#ff336614}.steps-list,.app-list{margin-bottom:0;padding-left:20px}textarea{border:1px solid var(--border);width:100%;color:var(--text);resize:vertical;background:#090c1659;border-radius:14px;margin:8px 0 14px;padding:12px}.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:14px 0;display:grid}.stat-card{border:1px solid var(--border);background:#ffffff0a;border-radius:14px;padding:12px}.stat-card span{color:var(--muted);margin-bottom:6px;display:block}.log-panel{gap:10px;max-height:420px;display:grid;overflow:auto}.log-row{border:1px solid var(--border);background:#090c163d;border-radius:14px;padding:12px}.log-ok{border-color:#00d4ff47}.log-reject{border-color:#f366}.log-accept{border-color:#0f86}.log-top,.log-actions{flex-wrap:wrap;justify-content:space-between;gap:12px;display:flex}.log-top{margin-bottom:6px}.log-actions{color:var(--muted);margin-top:8px;font-size:.92rem}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--border);padding:10px 8px}.footer-panel{margin-bottom:18px;padding:20px}@media (width<=900px){.hero-section,.protocol-stage,.exhibits-grid{grid-template-columns:1fr}.hero-section,.panel,.exhibit{padding:16px}.live-exhibit,.applications-exhibit{grid-column:span 1}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=640px){.shell{padding:12px}.button-row{flex-direction:column}.button-row>button{width:100%}.stats-grid{grid-template-columns:1fr}}
