*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d27;--border:#2e3347;--accent:#7c6af7;--accent2:#5ad8a6;--text:#e2e5f0;--muted:#7a7f9a;--danger:#f06a6a;--radius:10px;font-family:Segoe UI,system-ui,sans-serif}:root[data-theme=light]{--bg:#f4f5f9;--surface:#fff;--border:#d0d4e4;--accent:#6254d6;--accent2:#1fa87a;--text:#1a1d27;--muted:#6b7080;--danger:#d94f4f}@media (prefers-color-scheme:light){:root:not([data-theme=dark]){--bg:#f4f5f9;--surface:#fff;--border:#d0d4e4;--accent:#6254d6;--accent2:#1fa87a;--text:#1a1d27;--muted:#6b7080;--danger:#d94f4f}}body{background:var(--bg);color:var(--text);flex-direction:column;align-items:center;min-height:100vh;display:flex}header{text-align:center;border-bottom:1px solid var(--border);width:100%;margin-bottom:32px;padding:24px 0 16px;position:relative}header h1{letter-spacing:-.5px;font-size:1.7rem;font-weight:700}header p{color:var(--muted);margin-top:4px;font-size:.9rem}#theme-toggle{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);cursor:pointer;justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:1.1rem;transition:color .15s,border-color .15s;display:flex;position:absolute;top:50%;right:20px;transform:translateY(-50%)}#theme-toggle:hover{color:var(--text);border-color:var(--accent)}main{width:100%;max-width:560px;padding:0 16px 64px}.info-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px;font-size:.9rem}.info-box>summary{cursor:pointer;color:var(--muted);user-select:none;align-items:center;gap:8px;padding:12px 16px;font-weight:600;list-style:none;display:flex}.info-box>summary::-webkit-details-marker{display:none}.info-box>summary:before{content:"▸";font-size:.8rem;transition:transform .15s;display:inline-block}.info-box[open]>summary:before{transform:rotate(90deg)}.info-box>summary:hover{color:var(--text)}.info-body{color:var(--muted);flex-direction:column;gap:10px;padding:0 16px 14px;line-height:1.55;display:flex}.info-body a{color:var(--accent)}.info-body a:hover{text-decoration:underline}.tabs{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px;display:flex;overflow:hidden}.tab{background:var(--surface);color:var(--muted);cursor:pointer;border:none;flex:1;padding:12px;font-size:1rem;transition:background .15s,color .15s}.tab:first-child{border-right:1px solid var(--border)}.tab.active{background:var(--accent);color:#fff;font-weight:600}.tab-icon{margin-right:4px;font-weight:700;display:inline-block}.mode-switch{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);gap:4px;padding:4px;display:flex}.mode-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:8px 12px;font-size:.9rem;font-weight:600;transition:background .15s,color .15s}.mode-btn:hover:not(.active){color:var(--text)}.mode-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000026}textarea{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);resize:vertical;outline:none;min-height:120px;padding:12px 14px;font-family:inherit;font-size:.95rem;transition:border-color .15s}textarea:focus{border-color:var(--accent)}textarea[readonly]{color:var(--text);background:var(--bg)}#mode-file-pane,#mode-text-pane{flex-direction:column;gap:12px;display:flex}.panel{flex-direction:column;gap:16px;display:flex}.panel.hidden{display:none}.step{flex-direction:column;gap:12px;display:flex}.step.hidden{display:none}.step h2{font-size:1.1rem;font-weight:600}input[type=text],input[type=file]{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);outline:none;padding:12px 14px;font-size:.95rem;transition:border-color .15s}input[type=text]:focus{border-color:var(--accent)}input[type=file]{cursor:pointer}input[type=file]::-webkit-file-upload-button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 12px;font-size:.85rem}button{border-radius:var(--radius);cursor:pointer;border:none;padding:12px 20px;font-size:.95rem;font-weight:600;transition:opacity .15s,background .15s}button:hover:not(:disabled){opacity:.85}button:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-success{background:var(--accent2);color:#0f1117}.btn-danger{background:var(--danger);color:#fff}.btn-ghost{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-row{gap:10px;display:flex}.btn-row button{flex:1}.code-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);letter-spacing:.03em;color:var(--accent2);word-break:break-all;user-select:all;padding:14px 16px;font-family:Fira Mono,Consolas,monospace;font-size:1.1rem}.link-box-wrap{margin-top:4px}.wormhole-link{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--accent);word-break:break-all;padding:10px 14px;font-family:Fira Mono,Consolas,monospace;font-size:.8rem;text-decoration:none;display:block}.wormhole-link:hover{text-decoration:underline}.progress-track{background:var(--surface);border:1px solid var(--border);border-radius:99px;width:100%;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--accent), var(--accent2));border-radius:99px;width:0%;height:100%;transition:width .3s}.status{color:var(--muted);min-height:20px;font-size:.9rem}.status.error{color:var(--danger)}.status.ok{color:var(--accent2)}.status.warn{color:#f0a030}.qr-wrap{flex-direction:column;align-items:center;gap:6px;margin-top:4px;display:flex}.qr-code{border-radius:var(--radius);border:1px solid var(--border);background:#fff;padding:12px;line-height:0}.qr-code svg{width:200px;height:200px;display:block}.hidden{display:none!important}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}#nym-init-banner{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--muted);align-items:center;gap:12px;padding:14px 16px;font-size:.9rem;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:14px;padding:20px;display:flex}.done-icon{text-align:center;font-size:2.5rem}.transfer-warning{background:color-mix(in srgb, #f0a030 18%, var(--surface));border:1px solid color-mix(in srgb, #f0a030 55%, var(--border));border-radius:var(--radius);color:var(--text);margin-bottom:16px;padding:12px 16px;font-size:.88rem;line-height:1.45}.transfer-warning.hidden{display:none}.mixnet-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:10px;margin-bottom:20px;padding:12px 16px;display:flex}.mixnet-card.hidden{display:none}.mixnet-header{align-items:center;gap:8px;font-size:.85rem;display:flex}.conn-gateway{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;max-width:200px;margin-left:auto;font-family:monospace;font-size:.72rem;overflow:hidden}.conn-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.conn-dot.connecting{background:#f0a030;animation:1.1s ease-in-out infinite pulse-amber}.conn-dot.connected{background:var(--accent2);animation:2.2s ease-in-out infinite pulse-green}.conn-dot.error{background:var(--danger)}@keyframes pulse-amber{0%,to{box-shadow:0 0 #f0a03080}50%{box-shadow:0 0 0 5px #f0a03000}}@keyframes pulse-green{0%,to{box-shadow:0 0 #5ad8a673}50%{box-shadow:0 0 0 6px #5ad8a600}}.mixnet-viz{align-items:center;gap:6px;display:flex}.node-label{color:var(--muted);white-space:nowrap;min-width:26px;font-size:.72rem}.mix-path{flex:1;height:22px;position:relative}.mix-line{background:var(--border);height:1px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.mix-node{background:var(--surface);border:1.5px solid var(--border);z-index:1;border-radius:50%;width:8px;height:8px;transition:border-color .4s,background .4s;position:absolute;top:50%;transform:translate(-50%,-50%)}.mixnet-card.connected .mix-node{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 18%, var(--surface));animation:3s ease-in-out infinite node-idle}.mixnet-card.connected .mix-node:nth-child(2){animation-delay:1s}.mixnet-card.connected .mix-node:nth-child(3){animation-delay:2s}@keyframes node-idle{0%,to{box-shadow:none}50%{box-shadow:0 0 5px 1px color-mix(in srgb, var(--accent) 50%, transparent)}}#pkt-lane{pointer-events:none;z-index:2;position:absolute;inset:0;overflow:hidden}.pkt{opacity:0;border-radius:50%;width:7px;height:7px;position:absolute;top:50%;transform:translateY(-50%)}.pkt.out{background:var(--accent);box-shadow:0 0 6px 1px var(--accent);animation:1.8s cubic-bezier(.4,0,.6,1) forwards pkt-out}.pkt.in{background:var(--accent2);box-shadow:0 0 6px 1px var(--accent2);animation:1.8s cubic-bezier(.4,0,.6,1) forwards pkt-in}.pkt.out.cover{background:var(--muted);box-shadow:0 0 4px 1px var(--muted);animation:2.4s cubic-bezier(.4,0,.6,1) forwards pkt-out-cover}.pkt.in.cover{background:var(--muted);box-shadow:0 0 4px 1px var(--muted);animation:2.4s cubic-bezier(.4,0,.6,1) forwards pkt-in-cover}@keyframes pkt-out-cover{0%{opacity:0;left:0%}4%{opacity:.45}20%{left:22%;transform:translateY(-50%)scale(1)}26%{left:25%;transform:translateY(-50%)scale(1.5)}32%{left:28%;transform:translateY(-50%)scale(1)}45%{left:47%;transform:translateY(-50%)scale(1)}51%{left:50%;transform:translateY(-50%)scale(1.5)}57%{left:53%;transform:translateY(-50%)scale(1)}68%{left:72%;transform:translateY(-50%)scale(1)}74%{left:75%;transform:translateY(-50%)scale(1.5)}80%{left:78%;transform:translateY(-50%)scale(1)}96%{opacity:.45;left:100%}to{opacity:0;left:100%}}@keyframes pkt-in-cover{0%{opacity:0;left:100%}4%{opacity:.45}20%{left:78%;transform:translateY(-50%)scale(1)}26%{left:75%;transform:translateY(-50%)scale(1.5)}32%{left:72%;transform:translateY(-50%)scale(1)}45%{left:53%;transform:translateY(-50%)scale(1)}51%{left:50%;transform:translateY(-50%)scale(1.5)}57%{left:47%;transform:translateY(-50%)scale(1)}68%{left:28%;transform:translateY(-50%)scale(1)}74%{left:25%;transform:translateY(-50%)scale(1.5)}80%{left:22%;transform:translateY(-50%)scale(1)}96%{opacity:.45;left:0%}to{opacity:0;left:0%}}@keyframes pkt-out{0%{opacity:0;left:0%}4%{opacity:1}20%{left:22%;transform:translateY(-50%)scale(1)}26%{left:25%;transform:translateY(-50%)scale(1.8)}32%{left:28%;transform:translateY(-50%)scale(1)}45%{left:47%;transform:translateY(-50%)scale(1)}51%{left:50%;transform:translateY(-50%)scale(1.8)}57%{left:53%;transform:translateY(-50%)scale(1)}68%{left:72%;transform:translateY(-50%)scale(1)}74%{left:75%;transform:translateY(-50%)scale(1.8)}80%{left:78%;transform:translateY(-50%)scale(1)}96%{opacity:1;left:100%}to{opacity:0;left:100%}}@keyframes pkt-in{0%{opacity:0;left:100%}4%{opacity:1}20%{left:78%;transform:translateY(-50%)scale(1)}26%{left:75%;transform:translateY(-50%)scale(1.8)}32%{left:72%;transform:translateY(-50%)scale(1)}45%{left:53%;transform:translateY(-50%)scale(1)}51%{left:50%;transform:translateY(-50%)scale(1.8)}57%{left:47%;transform:translateY(-50%)scale(1)}68%{left:28%;transform:translateY(-50%)scale(1)}74%{left:25%;transform:translateY(-50%)scale(1.8)}80%{left:22%;transform:translateY(-50%)scale(1)}96%{opacity:1;left:0%}to{opacity:0;left:0%}}.mixnet-footer{gap:20px;font-size:.78rem;display:flex}.pkt-count{font-variant-numeric:tabular-nums}.pkt-out{color:var(--accent)}.pkt-in{color:var(--accent2)}.pkt-cover-label{color:var(--muted)}.field{flex-direction:column;gap:6px;display:flex}.field>span{color:var(--muted);font-size:.82rem;font-weight:600}.room-list{flex-direction:column;gap:6px;display:flex}.room-row{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;gap:10px;padding:10px 12px;transition:border-color .15s,background .15s;display:flex}.room-row:hover{border-color:var(--accent)}.room-row .room-icon{flex-shrink:0;font-size:1.1rem}.room-row .room-name{flex:1;font-size:.95rem;font-weight:600}.room-row .room-meta{color:var(--muted);white-space:nowrap;font-size:.75rem}.room-row .room-actions{gap:4px;display:flex}.room-row .room-actions button{color:var(--muted);border:1px solid var(--border);background:0 0;padding:4px 8px;font-size:.75rem}.room-row .room-actions button:hover:not(:disabled){color:var(--danger);border-color:var(--danger)}.btn-small{padding:6px 12px;font-size:.8rem}.input-row{align-items:stretch;gap:8px;display:flex}.input-row input{flex:1}.input-row .btn-small{white-space:nowrap}.chat-header{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding-bottom:6px;display:flex}.chat-room-name{font-size:1.05rem;font-weight:700}.chat-lock{font-size:.95rem}.chat-header-spacer{flex:1}.chat-members{color:var(--muted);flex-wrap:wrap;gap:6px;font-size:.78rem;display:flex}.chat-member-chip{background:var(--bg);border:1px solid var(--border);border-radius:99px;padding:2px 8px}.chat-member-chip.you{color:var(--accent);border-color:var(--accent)}.chat-share-area{background:var(--bg);border:1px dashed var(--border);border-radius:var(--radius);flex-direction:column;gap:8px;padding:10px;display:flex}.chat-messages{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:6px;height:320px;padding:10px;display:flex;overflow-y:auto}.chat-msg{word-wrap:break-word;gap:6px;font-size:.9rem;line-height:1.4;display:flex}.chat-msg .chat-nick{color:var(--accent);flex-shrink:0;font-weight:700}.chat-msg.you .chat-nick{color:var(--accent2)}.chat-msg.system{color:var(--muted);justify-content:center;font-size:.82rem;font-style:italic}.chat-msg .chat-ts{color:var(--muted);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:.72rem}.chat-msg .chat-text{white-space:pre-wrap;word-break:break-word}.chat-msg .chat-lock-mini{opacity:.7;flex-shrink:0;font-size:.72rem}.chat-input-row{gap:8px;display:flex}.chat-input-row input{flex:1}.chat-input-row button{padding:8px 16px}footer{text-align:center;width:100%;color:var(--muted);border-top:1px solid var(--border);margin-top:48px;padding:24px 0 32px;font-size:.8rem}footer a{color:var(--muted);text-underline-offset:3px}footer a:hover{color:var(--text)}
