@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-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:100vh;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;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}.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)}.join-form{display:flex;flex-direction:column;gap:.85rem}.join-form--connected{flex-direction:row;align-items:center;justify-content:space-between;gap:1rem}.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%}.join-form input:focus{border-color:var(--color-primary)}.join-form input::placeholder{color:var(--color-text-muted);opacity:.7}.status-bar{padding:.75rem 1.5rem;display:flex;align-items:center;gap:1rem;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)}.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-input{display:flex;gap:.75rem;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: 480px){body{padding:0}.app{max-width:100%}.app__main{border-radius:0;border-left:none;border-right:none}.join-form--connected{flex-direction:column;align-items:flex-start}.message{max-width:90%}}
