@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg-primary: #0a0a0c;--bg-secondary: #131316;--bg-tertiary: rgba(25, 25, 28, .8);--text-primary: #f8f8f2;--text-secondary: #a0a0ab;--accent-color: #6366f1;--accent-hover: #4f46e5;--glass-bg: rgba(19, 19, 22, .7);--glass-border: rgba(255, 255, 255, .06);--glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, .4);--message-mine: linear-gradient(135deg, #6366f1, #4f46e5);--message-theirs: rgba(255, 255, 255, .06);--success: #10b981;--danger: #ef4444;--warning: #f59e0b}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;width:100%;margin:0;padding:0;overflow:hidden;position:fixed;top:0;left:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;display:flex;flex-direction:column;background-image:radial-gradient(circle at 10% 20%,rgba(99,102,241,.15),transparent 30%),radial-gradient(circle at 90% 80%,rgba(16,185,129,.1),transparent 30%)}#root{display:flex;flex-direction:column;height:100%;width:100%;flex:1}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow)}.glass-card{background:#ffffff08;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:16px;transition:all .3s ease}.glass-card:hover{background:#ffffff0d;border-color:#ffffff1a;transform:translateY(-2px)}.btn-primary{background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));color:#fff;border:none;border-radius:8px;padding:10px 20px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 14px #6366f163}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #6366f180}.btn-primary:active{transform:translateY(1px)}.btn-icon{background:transparent;color:var(--text-secondary);border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.btn-icon:hover{background:#ffffff1a;color:var(--text-primary)}.glass-input{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px 16px;color:var(--text-primary);font-family:inherit;font-size:.95rem;transition:all .2s ease;outline:none}.glass-input:focus{background:#ffffff14;border-color:var(--accent-color);box-shadow:0 0 0 2px #6366f133}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .3s cubic-bezier(.16,1,.3,1) forwards}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #6366f166}70%{transform:scale(1);box-shadow:0 0 0 6px #6366f100}to{transform:scale(1);box-shadow:0 0 #6366f100}}.animate-pulse{animation:pulse 2s infinite}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#fff3}.app-container{display:flex;flex:1;height:var(--vh, 100%);width:100%;overflow:hidden;padding:1rem}.chat-card{display:flex;flex:1;border-radius:20px;overflow:hidden;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);min-height:0;min-width:0}.sidebar{width:320px;background:#0003;border-right:1px solid var(--glass-border);display:flex;flex-direction:column}.sidebar-header{padding:20px;border-bottom:1px solid var(--glass-border)}.sidebar-title{font-size:1.5rem;font-weight:700;display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#fff,#a0a0ab);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.peers-list{flex:1;overflow-y:auto;padding:12px 0}.peer-item{display:flex;align-items:center;gap:12px;padding:12px 20px;cursor:pointer;transition:all .2s ease}.peer-item:hover{background:#ffffff0d}.peer-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;position:relative}.status-indicator{position:absolute;bottom:0;right:0;width:12px;height:12px;border-radius:50%;border:2px solid var(--bg-secondary)}.status-online{background-color:var(--success)}.role-badge{font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.5px;display:inline-block}.role-host{background:var(--accent-color);color:#fff;box-shadow:0 2px 8px #6366f166}.role-peer{background:#ffffff1a;color:var(--text-secondary)}.chat-area{flex:1;display:flex;flex-direction:column;position:relative;min-height:0;min-width:0}.chat-header{padding:20px;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-between;background:#ffffff05;flex-shrink:0}.header-info{display:flex;align-items:center;gap:12px}.header-title{font-weight:600;font-size:1.1rem}.header-subtitle{font-size:.85rem;color:var(--text-secondary)}.messages-container{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px}.disconnect-banner{background:linear-gradient(135deg,var(--danger),#b91c1c);color:#fff;padding:16px;border-radius:16px;display:flex;align-items:center;gap:16px;margin-bottom:8px;margin-top:8px;box-shadow:0 8px 24px #ef444466;flex-shrink:0}.disabled-area{opacity:.6;pointer-events:none;filter:grayscale(80%)}.message-wrapper{display:flex;flex-direction:column;max-width:65%;animation:fadeIn .3s cubic-bezier(.16,1,.3,1) forwards}.message-wrapper.mine{align-self:flex-end}.message-wrapper.theirs{align-self:flex-start}.message-bubble{padding:12px 16px;border-radius:18px;font-size:.95rem;line-height:1.5;word-break:break-word;position:relative}.mine .message-bubble{background:var(--message-mine);color:#fff;border-bottom-right-radius:4px}.theirs .message-bubble{background:var(--message-theirs);color:var(--text-primary);border:1px solid var(--glass-border);border-bottom-left-radius:4px}.message-meta{font-size:.75rem;color:var(--text-secondary);margin-top:4px;display:flex;gap:8px}.mine .message-meta{justify-content:flex-end}.file-message{display:flex;align-items:center;gap:12px;padding:8px;background:#0003;border-radius:12px;margin-top:8px;cursor:pointer;transition:all .2s ease}.file-message:hover{background:#0000004d}.file-icon{width:40px;height:40px;border-radius:8px;background:#ffffff1a;display:flex;align-items:center;justify-content:center}.file-info{display:flex;flex-direction:column}.file-name{font-weight:500;font-size:.9rem}.file-size{font-size:.75rem;color:#ffffffb3}.chat-input-area{padding:16px 24px;background:#13131699;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.03);z-index:10;flex-shrink:0}.input-container{display:flex;align-items:flex-end;gap:8px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:6px 6px 6px 16px;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:inset 0 2px 4px #0000001a}.input-container:focus-within{border-color:#6366f166;background:#ffffff0d;box-shadow:0 4px 20px #6366f126,inset 0 2px 4px #0000001a;transform:translateY(-1px)}.chat-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-family:inherit;font-size:.95rem;line-height:1.5;resize:none;max-height:120px;min-height:24px;padding:12px 0;outline:none}.chat-input::placeholder{color:#ffffff4d}.btn-send{background:transparent;color:var(--text-secondary);border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1)}.btn-send.active{background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));color:#fff;box-shadow:0 4px 12px #6366f166}.btn-send.active:active{transform:scale(.95)}.btn-attach{color:var(--text-secondary);background:transparent;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;margin-bottom:2px}.btn-attach:hover{color:var(--accent-color);background:#6366f11a}.join-screen{display:flex;align-items:center;justify-content:center;height:var(--vh, 100%);width:100%;padding:20px}.join-card{width:100%;max-width:400px;padding:40px;display:flex;flex-direction:column;gap:24px;text-align:center}.logo-container{width:80px;height:80px;border-radius:24px;background:linear-gradient(135deg,var(--accent-color),var(--accent-hover));margin:0 auto;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #6366f166}.join-title{font-size:1.8rem;font-weight:700;margin-bottom:8px}.join-subtitle{color:var(--text-secondary);font-size:.95rem}.join-form{display:flex;flex-direction:column;gap:16px}.file-uploading{position:absolute;top:0;left:0;height:100%;background:#6366f133;border-radius:12px;transition:width .3s ease;z-index:0}.file-content{position:relative;z-index:1;display:flex;align-items:center;gap:12px}.mobile-overlay{display:none}.mobile-only{display:none!important}.desktop-only{display:flex}.leave-btn{display:flex;align-items:center;gap:8px}.leave-text{display:inline}.mobile-menu-btn{display:none}@media(max-width:768px){.app-container{padding:0}.chat-card{border-radius:0;flex-direction:column;height:var(--vh, 100%);width:100%;position:relative;border:none}.sidebar{position:absolute;top:0;left:-320px;height:100%;width:280px;max-width:80vw;z-index:50;max-height:none;border-right:1px solid var(--glass-border);transition:left .3s cubic-bezier(.16,1,.3,1);background:var(--glass-bg)}.sidebar.show{left:0}.mobile-overlay{display:block;position:absolute;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:40;opacity:0;pointer-events:none;transition:opacity .3s ease}.mobile-overlay.show{opacity:1;pointer-events:auto}.desktop-only{display:none!important}.mobile-only{display:flex!important}.mobile-menu-btn{display:flex;margin-right:4px;padding:8px;color:var(--text-primary)}.sidebar-header{padding:16px}.sidebar-title{font-size:1.2rem}.chat-area{flex:1;min-height:0;overflow:hidden}.chat-header{padding:12px 16px}.header-info{gap:8px}.messages-container{padding:16px}.message-wrapper{max-width:85%}.chat-input-area{padding:12px 12px calc(24px + env(safe-area-inset-bottom,0px))}.join-card{padding:30px 20px;border-radius:0;border-left:none;border-right:none}.leave-text{display:none}.leave-btn{padding:8px!important}}@media(max-width:480px){.message-wrapper{max-width:95%}}
