:root{font-family:Inter,SF Pro Display,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f5f6fb;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--text: #0f172a;--muted: #64748b;--panel: #ffffff;--surface: #f8fafc;--border: #e2e8f0;--accent: #6366f1;--success: #22c55e;--warning: #facc15;--danger: #ef4444}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#eff2ff,#fdfbff);color:var(--text)}#root{min-height:100vh}a{color:inherit}.app-shell{max-width:960px;margin:0 auto;padding:2rem 1.5rem 3rem;display:flex;flex-direction:column;gap:1.5rem}.hero{display:flex;justify-content:space-between;align-items:center;gap:1rem}.hero h1{margin:0;font-size:clamp(1.6rem,3vw,2.2rem)}.hero p{margin:.2rem 0 0;color:var(--muted)}.connection-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .85rem;border-radius:999px;font-weight:600;font-size:.95rem;background-color:var(--panel);border:1px solid var(--border)}.connection-pill .dot{width:.65rem;height:.65rem;border-radius:999px;background-color:var(--muted)}.connection-pill.connected .dot{background-color:var(--success)}.connection-pill.connecting .dot{background-color:var(--warning)}.connection-pill.disconnected .dot{background-color:var(--danger)}.join-section{width:100%}.join-card{background:var(--panel);padding:1.75rem;border-radius:1.25rem;border:1px solid var(--border);box-shadow:0 12px 32px #0f172a14;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;align-items:start}.field-group{display:flex;flex-direction:column;gap:.5rem}.field-group label{font-size:.9rem;color:var(--muted)}.field-group input{padding:.7rem .85rem;border:1px solid var(--border);border-radius:.6rem;background:var(--surface);font-size:1rem;color:var(--text)}.key-field,.passphrase-field{grid-column:1 / -1}.key-input-row{display:flex;gap:.8rem;align-items:center;flex-wrap:wrap}.key-input-row input{flex:1 1 220px;font-size:1.05rem;letter-spacing:.05em}.key-status{margin:.4rem 0 0;font-size:.85rem;color:var(--muted)}.display-field{display:flex;flex-direction:column;gap:.55rem}.display-row{display:flex;gap:.8rem;align-items:center;flex-wrap:wrap}.display-row input{flex:1 1 240px}.join-btn{min-width:130px;justify-content:center}.leave-btn{padding:.55rem 1.2rem;white-space:nowrap}button{border:none;border-radius:999px;padding:.65rem 1.2rem;font-weight:600;cursor:pointer;transition:background .2s ease,opacity .2s ease}button.primary{background:var(--accent);color:#fff}button.ghost{background:transparent;border:1px solid var(--border);color:var(--text)}button.secondary{width:100%;background:#6366f11a;color:var(--accent);border-radius:.8rem;margin-top:1.25rem}button:disabled{opacity:.6;cursor:not-allowed}.generate-btn{border:none;background:linear-gradient(120deg,#8b5cf6,#6366f1);color:#fff;border-radius:.85rem;padding:.65rem 1.35rem;font-weight:600;box-shadow:0 10px 30px #6366f159}.generate-btn:hover{opacity:.92}.share-link-field{grid-column:1 / -1}.share-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.share-btn{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:.85rem;padding:.65rem 1.2rem;white-space:nowrap}.share-row .hint{margin:0}.session-chip{margin:0;grid-column:1 / -1;font-size:.9rem;color:var(--muted)}.feedback{color:var(--danger);font-weight:500;margin:0;grid-column:1 / -1}.fingerprint-chip{grid-column:1 / -1;font-size:.8rem;color:var(--muted);background:#0f172a0d;border-radius:.8rem;padding:.45rem .85rem}.fingerprint-chip code{font-family:JetBrains Mono,SFMono-Regular,ui-monospace,Roboto Mono,monospace;letter-spacing:.08em;word-break:break-all;overflow-wrap:anywhere}.sas-chip{background:#6366f11a}.short-auth-chip{display:flex;flex-direction:column;gap:.35rem}.chat-section{display:grid;grid-template-columns:260px 1fr;gap:1.5rem;min-height:420px}.sidebar{background:var(--panel);border:1px solid var(--border);border-radius:1rem;padding:1.25rem;display:flex;flex-direction:column}.sidebar-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.sidebar ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.sidebar li{padding:.4rem .2rem;border-radius:.35rem;display:flex;flex-direction:column;gap:.2rem}.sidebar li.self{background:#6366f126}.participant-row{display:flex;justify-content:space-between;align-items:center;gap:.4rem}.fingerprint-row code{font-size:.65rem;letter-spacing:.08em;color:var(--muted);font-family:JetBrains Mono,SFMono-Regular,ui-monospace,Roboto Mono,monospace;background:#0f172a0d;padding:.1rem .35rem;border-radius:.35rem}.short-auth-row{display:flex;flex-direction:column;gap:.25rem}.short-auth-label{text-transform:uppercase;font-size:.6rem;letter-spacing:.12em;color:var(--muted)}.short-auth-pills{display:flex;flex-wrap:wrap;gap:.3rem}.short-auth-pill{font-size:1rem;padding:.2rem .55rem;border-radius:.6rem;background:#6366f11f;border:1px solid rgba(99,102,241,.35);box-shadow:inset 0 1px #ffffff40;white-space:nowrap}.trust-pill{font-size:.7rem;text-transform:capitalize;border-radius:999px;padding:.1rem .55rem;border:1px solid var(--border);color:var(--muted)}.trust-pill.verified{border-color:#22c55e66;color:var(--success)}.trust-pill.unverified{border-color:#facc1573;color:var(--warning)}.trust-pill.pending{border-color:#64748b73;color:var(--muted)}.badge{background:var(--accent);padding:.1rem .4rem;border-radius:999px;font-size:.7rem;color:#fff;margin-left:.3rem}.hint{font-size:.8rem;color:var(--muted);margin-top:.6rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.voice-toggle{width:48px;height:48px;border-radius:50%;border:1px solid rgba(99,102,241,.35);background:#6366f11f;color:var(--accent);display:inline-flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.voice-toggle.recording{background:#ef444429;border-color:#ef444466;color:var(--danger)}.voice-toggle-icon{width:20px;height:20px}.voice-recording-bar{display:flex;justify-content:space-between;align-items:center;gap:.75rem;background:#ef444414;border:1px dashed rgba(239,68,68,.4);border-radius:.9rem;padding:.5rem .9rem;margin-top:.5rem;font-size:.9rem;color:var(--danger)}.voice-recording-bar button{padding:.4rem .9rem}.voice-hint{margin-top:.35rem}.voice-hint.composer-hint{margin-bottom:0;color:var(--muted)}.chat-panel{background:var(--panel);border:1px solid var(--border);border-radius:1rem;padding:1.25rem;display:flex;flex-direction:column;min-height:420px}.message-list{flex:1;overflow-y:auto;margin-bottom:1rem;display:flex;flex-direction:column;gap:.65rem;max-height:min(60vh,600px);min-height:0;padding-right:.25rem;scrollbar-gutter:stable}.message{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem}.message.self{align-items:flex-end}.message .meta{font-size:.75rem;color:var(--muted);display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.message .meta .delivery-pill,.message .meta .ack-pill{padding:.1rem .6rem;border-radius:999px;border:1px solid var(--border);background:var(--surface);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.message .meta .ack-pill.pending{border-color:#facc1566;background:#facc1526;color:var(--warning)}.message .meta .ack-pill.acked{border-color:#22c55e66;background:#22c55e26;color:var(--success)}.bubble{padding:.75rem 1rem;border-radius:1rem;background:#fff;max-width:min(80%,480px);box-shadow:0 4px 15px #0f172a14}.message.self .bubble{background:var(--accent);color:#fff}.bubble.file{display:flex;justify-content:space-between;align-items:center;gap:1rem}.bubble.file button{border-radius:.65rem;background:#ffffff26;border:1px solid rgba(255,255,255,.4);color:inherit}.bubble.voice{display:flex;flex-direction:column;gap:.75rem}.voice-meta strong{display:block}.voice-meta p{margin:.15rem 0 0;font-size:.85rem;color:var(--muted)}.voice-player{display:flex;align-items:center;gap:.75rem}.voice-play{width:48px;height:48px;border-radius:50%;border:none;background:#6366f11f;color:var(--accent);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.voice-play.playing{background:#6366f133}.voice-play:disabled{opacity:.55;cursor:not-allowed}.voice-icon{width:16px;height:16px;position:relative;display:inline-flex;align-items:center;justify-content:center}.voice-icon.pause{gap:4px}.voice-icon.play:before{content:"";border-style:solid;border-width:8px 0 8px 12px;border-color:transparent transparent transparent currentColor;margin-left:2px}.voice-icon.pause:before,.voice-icon.pause:after{content:"";display:inline-block;width:4px;height:16px;background:currentColor;border-radius:2px}.voice-icon.pause:after{margin-left:4px}.voice-track{flex:1;display:flex;flex-direction:column;gap:.3rem}.voice-track input[type=range]{width:100%;accent-color:var(--accent)}.voice-timestamps{display:flex;justify-content:space-between;font-size:.75rem;color:var(--muted)}.voice-error{margin:0;font-size:.85rem;color:var(--danger)}.message.self .bubble.voice{background:#fff;color:var(--text)}.composer{display:flex;gap:.75rem;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:1rem;padding:.75rem;box-shadow:inset 0 1px #fff9}.composer input{flex:1;border-radius:1rem;border:1px solid var(--border);padding:.8rem 1rem;background:var(--surface);font-size:1rem}.composer button:not(.voice-toggle){border-radius:1rem;background:var(--accent);color:#fff;padding:0 1.5rem}.support-section{width:100%;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.info-card{background:var(--panel);border:1px solid var(--border);border-radius:1rem;padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:0 10px 35px #0f172a14}.info-card h2{margin:0;font-size:1.2rem}.info-card p{margin:0;color:var(--muted)}.help-card ul{margin:0;padding-left:1.25rem;display:flex;flex-direction:column;gap:.45rem;color:var(--text)}.help-card li strong{color:var(--accent)}.faq-list{margin:0;display:flex;flex-direction:column;gap:.85rem}.faq-item dt{font-weight:600;font-size:.95rem}.faq-item dd{margin:.25rem 0 0;color:var(--muted);font-size:.9rem}.compliance-footer{border:1px solid var(--border);border-radius:1rem;padding:1.2rem 1.5rem;background:var(--surface);display:flex;flex-direction:column;gap:.4rem}.gdpr-statement{margin:0;color:var(--muted);font-size:.9rem}.copyright{margin:0;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em}.muted{color:var(--muted);font-style:italic}@media(max-width:960px){.chat-section{grid-template-columns:1fr}.sidebar{order:2}}@media(max-width:640px){.app-shell{padding:1.5rem 1rem 2rem}.hero{flex-direction:column;align-items:center;text-align:center;gap:.25rem}.connection-pill{align-self:center}.join-card{grid-template-columns:1fr}.display-row{flex-direction:column}.display-row input{flex:initial;width:100%}.key-input-row{flex-direction:column;align-items:stretch}.key-input-row input{width:100%}.key-input-row .generate-btn,.join-btn,.leave-btn{width:100%;text-align:center}.composer{flex-direction:column;align-items:stretch;padding:.9rem;gap:.65rem}.composer .voice-toggle{align-self:center}.composer input,.composer button:not(.voice-toggle){width:100%}.composer button:not(.voice-toggle){padding:.9rem 1.1rem}}
