@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--color-bg: #0f1117;--color-surface: #1a1d27;--color-surface-raised: #22263a;--color-border: #2e3347;--color-text: #e8eaf0;--color-text-muted: #8b92a8;--color-primary: #6c63ff;--color-primary-hover: #7c74ff;--color-danger: #e05c5c;--color-danger-hover: #eb6e6e;--color-success: #4ecb81;--color-warning: #f0a05a;--color-voice-join: #2563eb;--color-voice-join-hover: #3b82f6;--color-voice-active: #16a34a;--color-voice-active-hover: #22c55e;--color-voice-muted: #9333ea;--color-voice-muted-hover: #a855f7;--color-voice-leave: #dc2626;--color-voice-leave-hover: #ef4444;--color-status-disconnected: #8b92a8;--color-status-connecting: var(--color-warning);--color-status-connected: var(--color-success);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--font-family: "Inter", system-ui, sans-serif;--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--color-bg);color:var(--color-text);min-height:100dvh;display:flex;justify-content:center;align-items:flex-start;padding:2rem 1rem;-webkit-font-smoothing:antialiased}.app{width:100%;max-width:680px;display:flex;flex-direction:column;gap:0}.app__header{text-align:center;margin-bottom:2rem}.app__title{font-size:2rem;font-weight:700;letter-spacing:-.03em;background:linear-gradient(135deg,var(--color-primary),#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app__subtitle{font-size:.875rem;color:var(--color-text-muted);margin-top:.25rem;letter-spacing:.02em}.app__main{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.app__section{padding:1.25rem 1.5rem}.app__chat{flex:1;min-height:0;display:flex;flex-direction:column}.app__divider{height:1px;background:var(--color-border);flex-shrink:0}.app__p2p-notice{margin-top:.75rem;padding:.6rem 1rem;background:#4ecb8114;border:1px solid rgba(78,203,129,.2);border-radius:var(--radius-md);font-size:.78rem;color:var(--color-text-muted);text-align:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1.25rem;border:none;border-radius:var(--radius-sm);font-family:var(--font-family);font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color var(--transition),transform var(--transition),opacity var(--transition);white-space:nowrap;min-height:44px}.btn:disabled{opacity:.4;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.btn--danger{background:var(--color-danger);color:#fff}.btn--danger:hover:not(:disabled){background:var(--color-danger-hover);transform:translateY(-1px)}.btn--voice-join{background:var(--color-voice-join);color:#fff;font-size:.82rem;padding:.4rem .9rem;min-height:36px}.btn--voice-join:hover:not(:disabled){background:var(--color-voice-join-hover);transform:translateY(-1px)}.btn--voice-active{background:var(--color-voice-active);color:#fff;font-size:.82rem;padding:.4rem .75rem;min-height:36px}.btn--voice-active:hover:not(:disabled){background:var(--color-voice-active-hover);transform:translateY(-1px)}.btn--voice-muted{background:var(--color-voice-muted);color:#fff;font-size:.82rem;padding:.4rem .75rem;min-height:36px}.btn--voice-muted:hover:not(:disabled){background:var(--color-voice-muted-hover);transform:translateY(-1px)}.btn--voice-leave{background:var(--color-voice-leave);color:#fff;font-size:.82rem;padding:.4rem .9rem;min-height:36px}.btn--voice-leave:hover:not(:disabled){background:var(--color-voice-leave-hover);transform:translateY(-1px)}@media (max-width: 380px){.btn__label{display:none}}.btn--attach{background:var(--color-surface-raised);color:var(--color-text-muted);border:1px solid var(--color-border);padding:0 .75rem;font-size:1.1rem;height:44px;flex-shrink:0;transition:background-color var(--transition),color var(--transition),border-color var(--transition)}.btn--attach:hover:not(:disabled){background:var(--color-border);color:var(--color-text);border-color:var(--color-primary)}.join-form{display:flex;flex-direction:column;gap:.85rem}.join-form--connected{flex-direction:row;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.join-form__room-label{font-size:.9rem;color:var(--color-text-muted)}.join-form__room-label strong{color:var(--color-text)}.join-form__field{display:flex;flex-direction:column;gap:.4rem}.join-form__field label{font-size:.8rem;font-weight:500;color:var(--color-text-muted);letter-spacing:.03em;text-transform:uppercase}.join-form input{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-family);font-size:.95rem;padding:.6rem .85rem;outline:none;transition:border-color var(--transition);width:100%;min-height:44px}.join-form input:focus{border-color:var(--color-primary)}.join-form input::placeholder{color:var(--color-text-muted);opacity:.7}.status-bar{padding:.6rem 1.5rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;background:var(--color-surface-raised);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.status-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:500}.status-badge__dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-badge--disconnected{color:var(--color-status-disconnected)}.status-badge--disconnected .status-badge__dot{background:var(--color-status-disconnected)}.status-badge--connecting{color:var(--color-status-connecting)}.status-badge--connecting .status-badge__dot{background:var(--color-status-connecting);animation:pulse 1.2s ease-in-out infinite}.status-badge--connected{color:var(--color-status-connected)}.status-badge--connected .status-badge__dot{background:var(--color-status-connected)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.status-bar__hint{font-size:.78rem;color:var(--color-text-muted);flex:1}.status-bar__voice{margin-left:auto;display:flex;align-items:center;gap:.5rem}.message-list{flex:1;overflow-y:auto;padding:1rem 1.5rem;display:flex;flex-direction:column;gap:.75rem;min-height:300px;max-height:420px;scroll-behavior:smooth}.message-list--empty{justify-content:center;align-items:center}.message-list__empty-text{font-size:.875rem;color:var(--color-text-muted);text-align:center}.message-list::-webkit-scrollbar{width:4px}.message-list::-webkit-scrollbar-track{background:transparent}.message-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.message{display:flex;flex-direction:column;max-width:75%;gap:.2rem;animation:message-slide-in .15s ease}@keyframes message-slide-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.message--local{align-self:flex-end;align-items:flex-end}.message--remote{align-self:flex-start;align-items:flex-start}.message--system{align-self:center;max-width:100%;align-items:center}.message__header{display:flex;gap:.5rem;align-items:baseline}.message__from{font-size:.75rem;font-weight:600;color:var(--color-text-muted)}.message__time{font-size:.7rem;color:var(--color-text-muted);opacity:.7}.message__text{padding:.5rem .85rem;border-radius:var(--radius-md);font-size:.9rem;line-height:1.5;word-break:break-word;white-space:pre-wrap}.message--local .message__text{background:var(--color-primary);color:#fff;border-bottom-right-radius:var(--radius-sm)}.message--remote .message__text{background:var(--color-surface-raised);color:var(--color-text);border-bottom-left-radius:var(--radius-sm)}.message--system .message__text{background:transparent;color:var(--color-text-muted);font-size:.78rem;font-style:italic;padding:.2rem .5rem}.message__attachment{display:flex;flex-direction:column;gap:.4rem;max-width:280px}.message__attachment-link{display:block;border-radius:var(--radius-md);overflow:hidden;transition:opacity var(--transition)}.message__attachment-link:hover{opacity:.9}.message__attachment-image{display:block;width:100%;max-width:280px;max-height:300px;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface-raised)}.message__attachment-video{display:block;width:100%;max-width:280px;max-height:300px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:#000}.message__attachment-meta{display:flex;align-items:center;gap:.5rem;padding:0 .1rem}.message__attachment-name{font-size:.78rem;color:var(--color-text-muted);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.message__attachment-size{font-size:.72rem;color:var(--color-text-muted);opacity:.7;flex-shrink:0}.message-input-wrapper{display:flex;flex-direction:column}.message-input__file-error{padding:.5rem 1.5rem;background:#e05c5c1f;border-bottom:1px solid rgba(224,92,92,.3);color:var(--color-danger);font-size:.82rem;animation:message-slide-in .15s ease}.message-input{display:flex;gap:.5rem;align-items:flex-end;padding:1rem 1.5rem}.message-input__textarea{flex:1;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-family);font-size:.9rem;line-height:1.5;padding:.6rem .85rem;outline:none;resize:none;transition:border-color var(--transition)}.message-input__textarea:focus{border-color:var(--color-primary)}.message-input__textarea::placeholder{color:var(--color-text-muted);opacity:.7}.message-input__textarea:disabled{opacity:.5;cursor:not-allowed}.message-input__send{flex-shrink:0;height:44px}@media (max-width: 600px){body{padding:0;min-height:100dvh;align-items:stretch}.app{max-width:100%;min-height:100dvh;display:flex;flex-direction:column}.app__header{padding:1rem 1rem .5rem;margin-bottom:.5rem}.app__title{font-size:1.5rem}.app__main{border-radius:0;border-left:none;border-right:none;flex:1;display:flex;flex-direction:column}.app__section{padding:.85rem 1rem}.app__chat{flex:1}.message-list{max-height:none;flex:1;min-height:120px;padding:.75rem 1rem}.message{max-width:90%}.message__attachment{max-width:220px}.message__attachment-image,.message__attachment-video{max-width:220px;max-height:220px}.message-input{padding:.75rem 1rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom))}.status-bar{padding:.5rem 1rem}.status-bar__voice{margin-left:0;width:100%;justify-content:flex-end}.join-form--connected{flex-direction:column;align-items:flex-start}.app__p2p-notice{margin:.5rem 1rem;font-size:.72rem}}@media (max-width: 380px){.message-input{gap:.35rem}.btn--primary{padding:.55rem .85rem}}.transfer-progress{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 14px;margin:6px 0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeInUp .25s ease}.transfer-progress--failed{border-color:#ef444466;background:#ef444414}.transfer-progress__header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.transfer-progress__icon{font-size:14px;flex-shrink:0}.transfer-progress__name{flex:1;font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transfer-progress__size{font-size:11px;color:var(--text-muted);flex-shrink:0}.transfer-progress__bar-wrap{height:6px;background:#ffffff1a;border-radius:999px;overflow:hidden;margin-bottom:6px}.transfer-progress__bar{height:100%;border-radius:999px;background:linear-gradient(90deg,#6366f1,#8b5cf6);transition:width .15s ease;position:relative;overflow:hidden}.transfer-progress__bar:after{content:"";position:absolute;top:0;left:-60%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);animation:shimmer 1.4s infinite}.transfer-progress__bar--failed{background:linear-gradient(90deg,#ef4444,#dc2626)}.transfer-progress__bar--failed:after{display:none}.transfer-progress__footer{display:flex;justify-content:space-between;align-items:center}.transfer-progress__from{font-size:11px;color:var(--text-muted)}.transfer-progress__pct{font-size:11px;font-weight:600;color:#a1a1aa}.transfer-progress--failed .transfer-progress__pct{color:#f87171}@keyframes shimmer{0%{left:-60%}to{left:110%}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
