.home-page{background-color:var(--bg);flex-direction:column;min-height:100vh;display:flex}.home-header{background-color:var(--panel);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.home-logo{color:var(--accent);align-items:center;gap:.5rem;font-size:1.25rem;font-weight:700;display:flex}.home-content{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.home-hero{margin-bottom:2.5rem}.hero-icon{border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent),#00c49a);color:#fff;justify-content:center;align-items:center;width:120px;height:120px;margin:0 auto 1.5rem;display:flex}.home-hero h1{color:var(--text);margin-bottom:.75rem;font-size:2rem;font-weight:700}.home-hero p{color:var(--text-secondary);max-width:400px;margin:0 auto;font-size:1rem}.home-actions{flex-direction:column;gap:1rem;width:100%;max-width:320px;margin-bottom:3rem;display:flex}.btn-large{border-radius:var(--radius-lg);padding:1rem 2rem;font-size:1rem;font-weight:600}.btn-secondary{background-color:var(--panel);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background-color:var(--input);border-color:var(--accent);color:var(--accent)}.home-features{flex-wrap:wrap;justify-content:center;gap:2rem;max-width:700px;display:flex}.feature{text-align:center;flex:1;min-width:180px;max-width:200px;padding:1rem}.feature-icon{border-radius:var(--radius-full);width:56px;height:56px;color:var(--accent);background-color:#00a88426;justify-content:center;align-items:center;margin:0 auto .75rem;display:flex}.feature h3{color:var(--text);margin-bottom:.25rem;font-size:.9375rem;font-weight:600}.feature p{color:var(--text-secondary);font-size:.8125rem}.home-footer{text-align:center;border-top:1px solid var(--border);padding:1rem 2rem}.home-footer p{color:var(--text-secondary);margin:0;font-size:.8125rem}@media (max-width:600px){.home-header{padding:.75rem 1rem}.home-content{padding:1.5rem}.home-hero h1{font-size:1.5rem}.hero-icon{width:100px;height:100px}.hero-icon svg{width:48px;height:48px}.home-features{gap:1rem}.feature{min-width:100%}}.auth-page{background-color:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.auth-card{background-color:var(--panel);border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);padding:2rem;position:relative}.back-link{color:var(--text-secondary);transition:var(--transition);align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:.875rem;display:inline-flex}.back-link:hover{color:var(--accent)}.auth-header{text-align:center;margin-bottom:2rem}.auth-icon{border-radius:var(--radius-full);background:linear-gradient(135deg,var(--accent),#00c49a);color:#fff;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 1rem;display:flex}.auth-header h1{color:var(--text);margin-bottom:.5rem;font-size:1.5rem;font-weight:600}.auth-header p{color:var(--text-secondary);font-size:.9375rem}.auth-form{flex-direction:column;gap:1.25rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text);font-size:.875rem;font-weight:500}.form-hint{color:var(--text-secondary);font-size:.75rem}.error-alert{color:var(--danger);border-radius:var(--radius);text-align:center;background-color:#dc354526;padding:.75rem 1rem;font-size:.875rem}.btn-block{width:100%;padding:.875rem;font-size:1rem;font-weight:600}.auth-footer{text-align:center;border-top:1px solid var(--border);margin-top:1.5rem;padding-top:1.5rem}.auth-footer p{color:var(--text-secondary);font-size:.875rem}.auth-footer a{font-weight:500}@media (max-width:480px){.auth-card{padding:1.5rem}.auth-icon{width:64px;height:64px}.auth-header h1{font-size:1.25rem}}.chat-header{background-color:var(--panel);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.header-left{align-items:center;gap:.75rem;display:flex}.back-btn{border-radius:var(--radius);width:36px;height:36px;color:var(--text-secondary);background-color:var(--bg);border:1px solid var(--border);transition:var(--transition);justify-content:center;align-items:center;display:flex}.back-btn:hover{color:var(--accent);border-color:var(--accent);background-color:#00a8841a}.header-avatar{border-radius:var(--radius-full);background-color:var(--accent);color:#fff;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:600;display:flex}.header-info{flex-direction:column;display:flex}.header-title{color:var(--text);margin:0;font-size:1rem;font-weight:600}.header-status{color:var(--text-secondary);align-items:center;gap:.375rem;font-size:.75rem;display:flex}.status-dot{border-radius:var(--radius-full);background-color:var(--text-secondary);width:8px;height:8px}.header-status.online .status-dot{background-color:var(--accent)}.header-status.online{color:var(--accent)}.header-right{align-items:center;gap:.5rem;display:flex}.theme-toggle{border-radius:var(--radius-full);width:40px;height:40px;color:var(--text-secondary);transition:var(--transition);justify-content:center;align-items:center;display:flex}.theme-toggle:hover{background-color:var(--input);color:var(--text)}.message-bubble{flex-direction:column;max-width:65%;margin-bottom:.5rem;display:flex}.message-bubble.own{align-self:flex-end}.message-bubble.other{align-self:flex-start}.sender-name{color:var(--accent);margin-bottom:.25rem;padding-left:.75rem;font-size:.75rem;font-weight:600}.bubble-content{border-radius:var(--radius);min-width:80px;padding:.5rem 3.5rem .5rem .75rem;position:relative}.message-bubble.own .bubble-content{background-color:var(--bubble-user);border-top-right-radius:0}.message-bubble.other .bubble-content{background-color:var(--bubble-admin);box-shadow:var(--shadow);border-top-left-radius:0}.message-text{word-wrap:break-word;white-space:pre-wrap;margin:0;font-size:.9375rem;line-height:1.4}.message-time{color:var(--text-secondary);font-size:.6875rem;position:absolute;bottom:.375rem;right:.5rem}@media (max-width:480px){.message-bubble{max-width:85%}}.message-list{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;min-height:0;padding:1rem;display:flex;overflow:hidden auto}.message-list.empty{justify-content:center;align-items:center}.empty-state{text-align:center;color:var(--text-secondary);width:100%;padding:1rem}.empty-state p{margin-bottom:.25rem;font-size:1rem}.empty-state span{font-size:.875rem}.welcome-notification{background:linear-gradient(135deg,#e8f4fd 0%,#d1e8fa 100%);border:1px solid #b3d4f0;border-radius:12px;align-items:flex-start;gap:.75rem;margin-bottom:1rem;padding:1rem;display:flex;box-shadow:0 2px 8px #0078c81a}.welcome-icon{color:#fff;background:linear-gradient(135deg,#08c 0%,#06a 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.welcome-content{flex:1}.welcome-title{color:#06a;margin:0 0 .375rem;font-size:.9375rem;font-weight:600}.welcome-text{color:#4a6a8a;margin:0;font-size:.8125rem;line-height:1.5}.messages-container{flex-direction:column;margin-top:auto;display:flex}.typing-indicator{color:var(--text-secondary);align-items:center;gap:.25rem;padding:.5rem .75rem;font-size:.8125rem;display:flex}.typing-dot{background-color:var(--text-secondary);border-radius:var(--radius-full);width:6px;height:6px;animation:1.4s ease-in-out infinite typingBounce}.typing-dot:first-child{animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}.typing-text{margin-left:.5rem;font-style:italic}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}.message-input{background-color:var(--panel);border-top:1px solid var(--border);flex-shrink:0;padding:.75rem 1rem}.input-wrapper{align-items:center;gap:.75rem;display:flex}.message-input .form-input{border-radius:var(--radius-lg);flex:1}.send-button{border-radius:var(--radius-full);background-color:var(--accent);color:#fff;width:44px;height:44px;transition:var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:flex}.send-button:hover:not(:disabled){background-color:var(--accent-hover)}.send-button:disabled{opacity:.5;cursor:not-allowed}.chat-room-wrapper{background-color:var(--bg);flex:1;height:100%;display:flex;overflow:hidden}.chat-info-panel{color:#fff;background:linear-gradient(135deg,#0a8068 0%,#065446 100%);width:380px;min-width:380px;display:none;overflow:hidden}.info-panel-content{box-sizing:border-box;flex-direction:column;height:100%;padding:1.5rem;display:flex}.app-branding{text-align:center;margin-bottom:1.5rem}.app-logo{background:#ffffff26;border-radius:16px;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto .75rem;display:flex}.app-logo svg{width:32px;height:32px}.app-name{margin:0 0 .125rem;font-size:1.5rem;font-weight:700}.app-tagline{opacity:.85;margin:0;font-size:.875rem}.info-instructions{flex-direction:column;flex:1;display:flex}.info-instructions h2{opacity:.9;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1rem;font-size:.875rem;font-weight:600}.instruction-item{background:#ffffff1a;border-radius:10px;gap:.75rem;margin-bottom:.75rem;padding:.75rem;transition:background .2s;display:flex}.instruction-item:hover{background:#ffffff26}.instruction-icon{background:#fff3;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.instruction-icon svg{width:20px;height:20px}.instruction-text h3{margin:0 0 .125rem;font-size:.8125rem;font-weight:600}.instruction-text p{opacity:.85;margin:0;font-size:.75rem;line-height:1.3}.info-room-id{text-align:center;border-top:1px solid #ffffff26;margin-top:auto;padding-top:1rem}.info-room-id span{opacity:.8;margin-bottom:.375rem;font-size:.75rem;display:block}.info-room-id code{background:#ffffff26;border-radius:6px;margin-bottom:.5rem;padding:.5rem .75rem;font-family:monospace;font-size:1rem;font-weight:600;display:block}.copy-btn-small{color:#0a8068;background:#fff;border-radius:6px;padding:.375rem 1rem;font-size:.75rem;font-weight:500;transition:all .2s}.copy-btn-small:hover{background:#f0f0f0;transform:translateY(-1px)}.chat-room-main{flex-direction:column;flex:1;min-width:0;height:100%;display:flex;overflow:hidden}.chat-room{background-color:var(--bg);flex-direction:column;flex:1;max-width:100%;display:flex;position:relative;overflow:hidden}.chat-room.loading-state,.chat-room.error-state{justify-content:center;align-items:center}.loading-content,.error-content{text-align:center;padding:2rem}.loading-content .spinner{width:40px;height:40px;margin:0 auto 1rem}.loading-content p,.error-content p{color:var(--text-secondary);font-size:.9375rem}.error-content h2{color:var(--danger);margin-bottom:.5rem}.error-content .btn{margin-top:1rem}.chat-room:before{content:"";pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%239C92AC' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");position:absolute;inset:0}.chat-room>*{z-index:1;position:relative}.room-id-bar{background-color:var(--panel);border-top:1px solid var(--border);color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;gap:1rem;padding:.5rem 1rem;font-size:.8125rem;display:flex}.room-id-bar strong{color:var(--accent);font-family:monospace}.copy-btn{color:var(--accent);border-radius:var(--radius);transition:var(--transition);background-color:#00a8841a;padding:.25rem .75rem;font-size:.75rem;font-weight:500}.copy-btn:hover{background-color:#00a88433}@media (min-width:768px){.chat-info-panel{display:block}.room-id-bar.mobile-only{display:none}.chat-room-main{border-left:1px solid var(--border)}}@media (max-width:767px){.chat-room-wrapper{height:100%}.chat-info-panel{display:none}.chat-room .room-id-bar{padding-bottom:calc(.5rem + env(safe-area-inset-bottom,0px))}}.not-found{background-color:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.not-found-content{text-align:center;max-width:400px}.not-found-icon{border-radius:var(--radius-full);width:100px;height:100px;color:var(--danger);background-color:#dc354526;justify-content:center;align-items:center;margin:0 auto 1.5rem;display:flex}.not-found h1{color:var(--text);margin:0;font-size:4rem;font-weight:700;line-height:1}.not-found h2{color:var(--text);margin:.5rem 0 1rem;font-size:1.5rem;font-weight:600}.not-found p{color:var(--text-secondary);margin-bottom:.5rem;font-size:.9375rem}.not-found .hint{border-top:1px solid var(--border);margin-top:1.5rem;padding-top:1.5rem;font-size:.875rem}:root{--bg:#efeae2;--panel:#fff;--input:#f0f2f5;--border:#e9edef;--text:#111b21;--text-secondary:#667781;--accent:#00a884;--accent-hover:#008f70;--bubble-user:#dcf8c6;--bubble-admin:#fff;--danger:#dc3545;--radius:8px;--radius-lg:12px;--radius-full:9999px;--shadow:0 1px 3px #0000001a;--shadow-lg:0 2px 8px #00000026;--transition:all .2s ease}[data-theme=dark]{--bg:#0b141a;--panel:#111b21;--input:#1f2c34;--border:#2a3942;--text:#e9edef;--text-secondary:#8696a0;--accent:#00a884;--accent-hover:#00c49a;--bubble-user:#005c4b;--bubble-admin:#1f2c34}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;font-size:16px;overflow:hidden}body{background-color:var(--bg);color:var(--text);height:100%;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;overflow:hidden}#root{flex-direction:column;height:100%;display:flex}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-secondary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text)}.btn{border-radius:var(--radius);transition:var(--transition);justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.9375rem;font-weight:500;display:inline-flex}.btn-primary{background-color:var(--accent);color:#fff}.btn-primary:hover{background-color:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.form-input{background-color:var(--input);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);transition:var(--transition);padding:.875rem 1rem;font-size:.9375rem}.form-input:focus{border-color:var(--accent);outline:none}.form-input::placeholder{color:var(--text-secondary)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin}.spinner-small{border-width:2px;width:16px;height:16px}
