@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700&family=Outfit:wght@500;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@500;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@500;700&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:left;flex-direction:column;width:100%;min-height:100vh;margin:0;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.login-container{background:linear-gradient(135deg,#0f172a 0%,#1e1b4b 100%);justify-content:center;align-items:center;min-height:100vh;font-family:Inter,sans-serif;display:flex;position:relative;overflow:hidden}.login-container:before,.login-container:after{content:"";filter:blur(80px);z-index:0;border-radius:50%;animation:10s ease-in-out infinite alternate float;position:absolute}.login-container:before{background:#6366f166;width:400px;height:400px;top:-10%;left:-10%}.login-container:after{background:#ec48994d;width:350px;height:350px;animation-delay:-5s;bottom:-10%;right:-10%}@keyframes float{0%{transform:translate(0)scale(1)}to{transform:translate(30px,50px)scale(1.1)}}.login-card{z-index:1;-webkit-backdrop-filter:blur(20px);text-align:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:24px;width:100%;max-width:420px;padding:48px 40px;position:relative;box-shadow:0 25px 50px -12px #00000080}.login-header{margin-bottom:32px}.login-logo{color:#a855f7;text-shadow:0 0 20px #a855f766;letter-spacing:-1px;margin:0;font-family:Outfit,sans-serif;font-size:3rem;font-weight:700}.login-subtitle{color:#94a3b8;margin-top:8px;font-size:.95rem}.login-form{flex-direction:column;gap:20px;display:flex}.input-group{text-align:left;position:relative}.input-group label{color:#cbd5e1;margin-bottom:6px;margin-left:4px;font-size:.85rem;font-weight:600;display:block}.login-input{color:#f8fafc;box-sizing:border-box;background:#0f172a66;border:1px solid #ffffff1a;border-radius:12px;outline:none;width:100%;padding:14px 16px;font-size:1rem;transition:all .3s}.login-input::placeholder{color:#64748b}.login-input:focus{background:#0f172a99;border-color:#818cf8;box-shadow:0 0 0 4px #818cf826}.login-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1 0%,#a855f7 100%);border:none;border-radius:12px;margin-top:10px;padding:14px;font-size:1.05rem;font-weight:600;transition:all .3s;box-shadow:0 10px 25px -5px #6366f166}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 15px 30px -5px #6366f180}.login-button:active:not(:disabled){transform:translateY(1px);box-shadow:0 5px 15px -5px #6366f166}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{color:#94a3b8;margin-top:24px;font-size:.9rem}.login-footer a{color:#818cf8;font-weight:600;text-decoration:none;transition:color .2s}.login-footer a:hover{color:#c084fc;text-decoration:underline}@media (width<=480px){.login-card{width:calc(100% - 40px);margin:20px;padding:32px 24px}}.home-container{color:#0f172a;background-color:#f8fafc;min-height:100vh;font-family:Inter,sans-serif}.navbar{z-index:10;background-color:#fff;justify-content:space-between;align-items:center;padding:16px 48px;display:flex;position:sticky;top:0;box-shadow:0 4px 6px -1px #0000000d}.nav-logo{background:linear-gradient(90deg,#6366f1,#a855f7);-webkit-text-fill-color:transparent;letter-spacing:-1px;-webkit-background-clip:text;background-clip:text;margin:0;font-family:Outfit,sans-serif;font-size:2rem;font-weight:700}.logout-btn{color:#475569;cursor:pointer;background-color:#f1f5f9;border:none;border-radius:8px;padding:10px 20px;font-weight:600;transition:all .2s}.logout-btn:hover{color:#0f172a;background-color:#e2e8f0}.main-content{max-width:1200px;margin:0 auto;padding:40px 24px}.page-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.page-title{color:#1e293b;margin:0;font-size:1.75rem;font-weight:700}.add-room-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1 0%,#a855f7 100%);border:none;border-radius:10px;align-items:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 15px -3px #6366f166}.add-room-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px -3px #6366f180}.rooms-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;display:grid}.room-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;padding:24px;transition:all .3s;display:flex;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -2px #0000000d}.room-card:hover{border-color:#cbd5e1;transform:translateY(-4px);box-shadow:0 12px 20px -5px #00000014,0 8px 10px -6px #0000000a}.room-name{color:#0f172a;margin:0 0 8px;font-size:1.25rem;font-weight:700}.room-desc{color:#64748b;flex-grow:1;margin:0 0 24px;font-size:.95rem;line-height:1.5}.join-btn{color:#3b82f6;cursor:pointer;background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;width:100%;padding:10px 16px;font-weight:600;transition:all .2s}.join-btn:hover{color:#fff;background-color:#3b82f6;border-color:#3b82f6}.no-rooms{text-align:center;color:#64748b;background:#fff;border:1px dashed #cbd5e1;border-radius:16px;grid-column:1/-1;padding:64px 20px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background-color:#0f172a99;justify-content:center;align-items:center;animation:.2s ease-out forwards fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:20px;width:100%;max-width:450px;padding:32px;animation:.3s ease-out forwards slideUp;box-shadow:0 25px 50px -12px #00000040}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-header h3{color:#0f172a;margin:0;font-size:1.5rem;font-weight:700}.close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1;transition:color .2s}.close-btn:hover{color:#0f172a}.modal-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#475569;font-size:.9rem;font-weight:600}.form-group input,.form-group textarea{box-sizing:border-box;border:1px solid #cbd5e1;border-radius:10px;width:100%;padding:12px 16px;font-family:inherit;font-size:1rem;transition:all .2s}.form-group input:focus,.form-group textarea:focus{border-color:#818cf8;outline:none;box-shadow:0 0 0 3px #818cf833}.form-group textarea{resize:vertical;min-height:100px}.submit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1 0%,#a855f7 100%);border:none;border-radius:10px;margin-top:8px;padding:14px;font-size:1rem;font-weight:600;transition:opacity .2s}.submit-btn:hover{opacity:.9}.submit-btn:disabled{opacity:.7;cursor:not-allowed}@media (width<=640px){.navbar{padding:16px 24px}.modal-content{margin:16px;padding:24px}}.chat-container{background-color:#f8fafc;width:100%;height:100vh;font-family:Inter,sans-serif;display:flex;overflow:hidden}.chat-sidebar{z-index:5;background-color:#fff;border-right:1px solid #e2e8f0;flex-direction:column;width:280px;display:flex;box-shadow:2px 0 10px #00000005}.sidebar-header{border-bottom:1px solid #e2e8f0;padding:24px}.sidebar-header h2{background:linear-gradient(90deg,#6366f1,#a855f7);-webkit-text-fill-color:transparent;letter-spacing:-1px;-webkit-background-clip:text;background-clip:text;margin:0;font-family:Outfit,sans-serif;font-size:2rem;font-weight:700}.users-list-container{flex-grow:1;padding:24px;overflow-y:auto}.users-title{text-transform:uppercase;color:#94a3b8;letter-spacing:.5px;margin:0 0 16px;font-size:.85rem;font-weight:600}.users-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.user-item{border-radius:8px;align-items:center;gap:12px;padding:8px;transition:background-color .2s;display:flex}.user-item:hover{background-color:#f1f5f9}.user-avatar{color:#fff;background:linear-gradient(135deg,#818cf8 0%,#c084fc 100%);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;font-weight:600;display:flex}.current-user .user-avatar{background:linear-gradient(135deg,#10b981 0%,#34d399 100%)}.user-name{color:#334155;flex-grow:1;font-weight:500}.current-user .user-name{color:#0f172a;font-weight:600}.status-dot{background-color:#22c55e;border-radius:50%;width:8px;height:8px}.chat-main{background-color:#f8fafc;flex-direction:column;flex-grow:1;height:100%;display:flex}.chat-header{z-index:4;background-color:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:20px 32px;display:flex;box-shadow:0 2px 10px #00000005}.room-info{flex-direction:column;display:flex}.chat-room-name{color:#0f172a;margin:0;font-size:1.25rem;font-weight:600}.room-id{color:#94a3b8;margin-top:4px;font-size:.85rem}.exit-btn{color:#ef4444;cursor:pointer;background-color:#fee2e2;border:none;border-radius:8px;padding:10px 20px;font-weight:600;transition:all .2s}.exit-btn:hover{color:#b91c1c;background-color:#fecaca}.messages-container{flex-direction:column;flex-grow:1;gap:24px;padding:32px;display:flex;overflow-y:auto}.message-wrapper{gap:16px;max-width:75%;display:flex}.message-mine{flex-direction:row-reverse;align-self:flex-end}.message-avatar{color:#fff;background:linear-gradient(135deg,#94a3b8 0%,#cbd5e1 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-weight:600;display:flex}.message-content{flex-direction:column;gap:4px;display:flex}.message-mine .message-content{align-items:flex-end}.message-sender{color:#64748b;margin-left:4px;font-size:.85rem;font-weight:500}.message-bubble{border-radius:18px;padding:14px 18px;font-size:.95rem;line-height:1.5;box-shadow:0 2px 5px #0000000d}.message-other .message-bubble{color:#334155;background-color:#fff;border:1px solid #e2e8f0;border-top-left-radius:4px}.message-mine .message-bubble{color:#fff;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-top-right-radius:4px}.message-bubble p{margin:0}.message-time{color:#94a3b8;margin-top:4px;margin-right:4px;font-size:.75rem}.message-input-area{background-color:#fff;border-top:1px solid #e2e8f0;gap:16px;padding:24px 32px;display:flex}.message-input{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:99px;outline:none;flex-grow:1;padding:16px 24px;font-family:inherit;font-size:1rem;transition:all .2s}.message-input:focus{background-color:#fff;border-color:#818cf8;box-shadow:0 0 0 3px #818cf826}.send-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1 0%,#a855f7 100%);border:none;border-radius:99px;padding:0 32px;font-size:1rem;font-weight:600;transition:all .2s;box-shadow:0 4px 10px #6366f14d}.send-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 15px #6366f166}.send-btn:disabled{box-shadow:none;cursor:not-allowed;color:#f8fafc;background:#cbd5e1}@media (width<=768px){.chat-sidebar{transition:transform .3s;position:absolute;transform:translate(-100%)}}
