@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Poppins:wght@400;500;600;700&display=swap";@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{transform:scale(.98)}to{transform:scale(1)}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:#0f1729;color:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%;display:flex;flex-direction:column}.app{height:100dvh;display:flex;flex-direction:column;color:#fff;background:#0f1729;font-family:Inter,system-ui,sans-serif;overflow:hidden}.font-poppins{font-family:Poppins,sans-serif}.font-inter{font-family:Inter,sans-serif}.toast{position:fixed;left:50%;bottom:calc(100px + env(safe-area-inset-bottom));transform:translate(-50%);background:#000c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:12px 24px;border-radius:296px;font-size:12px;font-weight:500;color:#fff;z-index:1000;animation:toastSlideUp .3s ease-out;white-space:nowrap}@keyframes toastSlideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.glass-effect{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.button-primary{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.button-primary:disabled{cursor:not-allowed;opacity:.5}.button-primary{background:#18bcd0;color:#fff}.button-primary:hover:not(:disabled){background:#14a3b8}.button-primary:active:not(:disabled){transform:scale(.98)}.button-primary{font-size:12px;padding:6px 12px}.button-secondary{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.button-secondary:disabled{cursor:not-allowed;opacity:.5}.button-secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.button-secondary:hover:not(:disabled){background:#ffffff26}.button-secondary{font-size:12px;padding:6px 12px}.button-medium{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.button-medium:disabled{cursor:not-allowed;opacity:.5}.button-medium{background:#18bcd0;color:#fff}.button-medium:hover:not(:disabled){background:#14a3b8}.button-medium:active:not(:disabled){transform:scale(.98)}.button-medium{font-size:12px;padding:8px 16px}.button-large{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.button-large:disabled{cursor:not-allowed;opacity:.5}.button-large{background:#18bcd0;color:#fff}.button-large:hover:not(:disabled){background:#14a3b8}.button-large:active:not(:disabled){transform:scale(.98)}.button-large{font-size:14px;padding:12px 24px}.input-base{border-radius:12px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;font-family:Inter,sans-serif;outline:none;transition:all .15s ease-out}.input-base:focus{border-color:#18bcd0;background:#ffffff26}.input-base::placeholder{color:#fff9}.input-base{padding:8px 12px;font-size:14px}.card{border-radius:16px;border:1px solid rgba(255,255,255,.2);background:#252c3a;padding:16px}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.grid-center{display:grid;place-items:center}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.header{height:63px;background:#252c3a;display:flex;align-items:center;justify-content:space-between;padding:0 12px;position:relative;flex-shrink:0}.header__title{font-family:Poppins,sans-serif;font-weight:700;font-size:16px;color:#fff;text-align:center;line-height:1.35;position:absolute;left:50%;transform:translate(-50%)}.header__lang-switcher{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:12px;padding:4px 6px;cursor:pointer;outline:none;min-width:80px}.header__lang-switcher:hover{background:#ffffff26}.header__lang-switcher:focus{border-color:#fff6}.header__lang-switcher option{background:#1a1a2e;color:#fff}.header__spacer{width:80px}.header__left{position:absolute;left:16px;display:flex;align-items:center;gap:8px}.header__right{position:absolute;right:16px;display:flex;align-items:center;gap:8px}.header__back-btn{background:transparent;border:none;color:#fff;font-size:16px;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;transition:opacity .15s ease-out}.header__back-btn:hover{opacity:.8}.header__back-btn:active{opacity:.6}.header__icon-btn{background:transparent;border:none;color:#fff;font-size:20px;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;transition:opacity .15s ease-out}.header__icon-btn:hover{opacity:.8}.chat-header{height:63px;background:#252c3a;display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0}.chat-header__back{background:transparent;border:none;color:#fff;font-size:16px;cursor:pointer;padding:8px;margin-left:-8px;display:flex;align-items:center;gap:6px;transition:opacity .15s ease-out}.chat-header__back:hover{opacity:.8}.chat-header__title{font-family:Poppins,sans-serif;font-weight:700;font-size:16px;color:#fff;position:absolute;left:50%;transform:translate(-50%)}.chat-header__members{background:transparent;border:none;color:#fff;font-size:20px;cursor:pointer;padding:8px;margin-right:-8px;transition:opacity .15s ease-out}.chat-header__members:hover{opacity:.8}.header__controls,.header__button,.header__username-section,.header__auth-section,.username-input,.auth-buttons{display:none}.home-screen{display:flex;flex-direction:column;flex:1;background:#0f1729;overflow:hidden;position:relative}.home-screen__content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 24px 140px}.home-screen__scanner{width:250px;height:250px;background:#000;border:2px solid #ffffff;border-radius:20px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.home-screen__scanner .scanner__video{width:100%;height:100%;object-fit:cover;border-radius:18px}.home-screen__scanner .scanner__video--hidden{display:none}.home-screen__scanner .scanner__overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.home-screen__scanner .scanner__frame{width:80%;height:80%;border:2px solid rgba(255,255,255,.5);border-radius:12px;animation:scan-pulse 2s ease-in-out infinite}.home-screen__scanner .scanner__status{position:absolute;bottom:12px;left:50%;transform:translate(-50%);font-size:10px;color:#fff9;white-space:nowrap}.home-screen__scanner .scanner__error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#ef4444e6;color:#fff;padding:8px 12px;border-radius:8px;font-size:12px;text-align:center;max-width:90%}.home-screen__prompt{margin-top:24px;text-align:center}.home-screen__prompt-title{font-family:Poppins,sans-serif;font-weight:600;font-size:12px;color:#fff;letter-spacing:.6px;margin-bottom:8px}.home-screen__prompt-link{font-family:Poppins,sans-serif;font-weight:400;font-size:10px;color:#fff;text-decoration:underline;cursor:pointer;letter-spacing:.5px;background:none;border:none;padding:0}.home-screen__prompt-link:hover{opacity:.8}.home-screen__qr-icon{margin-top:16px;width:24px;height:24px;opacity:.8}.home-screen__qr-icon svg{width:100%;height:100%;fill:#fff}.home-screen__manual-entry{margin-top:24px;width:100%;max-width:300px}.home-screen__manual-entry .manual-entry__form{display:flex;gap:8px}.home-screen__manual-entry .manual-entry__input{flex:1;padding:12px 16px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;font-size:14px;text-align:center;letter-spacing:.15em;font-weight:500;outline:none;transition:all .15s ease-out}.home-screen__manual-entry .manual-entry__input::placeholder{color:#fff9;letter-spacing:normal}.home-screen__manual-entry .manual-entry__input:focus{border-color:#18bcd0;background:#ffffff26}.home-screen__manual-entry .manual-entry__input:disabled{opacity:.5;cursor:not-allowed}.home-screen__manual-entry .manual-entry__button{padding:12px 16px;background:#18bcd0;border:none;border-radius:12px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease-out;white-space:nowrap}.home-screen__manual-entry .manual-entry__button:hover:not(:disabled){background:#14a3b8}.home-screen__manual-entry .manual-entry__button:active:not(:disabled){transform:scale(.98)}.home-screen__manual-entry .manual-entry__button:disabled{opacity:.5;cursor:not-allowed}.home-screen__chatrooms-bar{position:absolute;bottom:0;left:0;right:0;background:#000;padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom))}.home-screen__chatrooms-bar-title{font-family:Poppins,sans-serif;font-weight:600;font-size:12px;color:#fff;text-align:center;letter-spacing:.6px;margin-bottom:12px}.home-screen__chatrooms-bar-list{display:flex;gap:8px;justify-content:center;overflow-x:auto;padding-bottom:6px}.home-screen__chatrooms-bar-list::-webkit-scrollbar{display:none}.home-screen__room-thumb{width:54px;height:54px;border-radius:8px;overflow:hidden;background:#e5e5e5;position:relative;cursor:pointer;transition:transform .15s ease-out;flex-shrink:0}.home-screen__room-thumb:hover{transform:scale(1.05)}.home-screen__room-thumb:active{transform:scale(.95)}.home-screen__room-thumb:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#c8e6c9,#a5d6a7,#81c784)}.home-screen__room-thumb:after{content:"📍";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:20px}.home-screen__room-thumb img{width:100%;height:100%;object-fit:cover}.home-screen__empty-rooms{text-align:center;padding:12px;color:#fff9;font-size:12px}.home-screen__section,.home-screen__tip{display:none}@keyframes scan-pulse{0%,to{opacity:.5}50%{opacity:1}}@media (max-width: 375px){.home-screen__scanner{width:220px;height:220px}.home-screen__manual-entry{max-width:280px}}.room-card{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#252c3a;border:1px solid rgba(255,255,255,.2);border-radius:16px;transition:all .15s ease-out;cursor:pointer}.room-card:hover{border-color:#18bcd0;background:#ffffff0d}.room-card:active{transform:scale(.98)}.room-card__info{flex:1;min-width:0}.room-card__code{font-family:Poppins,sans-serif;font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.room-card__date{font-size:12px;color:#fff9}.room-card__button{padding:8px 16px;background:#18bcd0;color:#fff;border:none;border-radius:12px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease-out;white-space:nowrap;margin-left:16px}.room-card__button:hover{background:#14a3b8}.room-card__button:active{transform:scale(.95)}.join-screen{flex:1;display:grid;grid-template-rows:auto 1fr auto;gap:12px;padding:16px;color:#fffc}.join-screen__header{text-align:center}.join-screen__header h1{font-size:20px;margin:0}.join-screen__header p{font-size:12px;opacity:.9;margin-top:6px}.join-screen__camera-container{display:grid;place-items:center;position:relative;border-radius:20px;overflow:hidden;border:1px solid rgba(255,255,255,.15);background:#ffffff0a;min-height:280px}.join-screen__video{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(40%)}.join-screen__video--scanning{filter:none}.join-screen__video--hidden{display:none}.join-screen__scan-overlay{position:absolute;top:12%;right:10%;bottom:12%;left:10%;border:2px dashed rgba(255,255,255,.5);border-radius:16px;pointer-events:none}.join-screen__status{position:absolute;left:12px;bottom:12px;font-size:12px;background:#00000059;border:1px solid rgba(255,255,255,.2);padding:4px 8px;border-radius:8px}.join-screen__error{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:16px;text-align:center;font-size:14px;background:linear-gradient(0deg,#00000073,#00000059)}.join-screen__input-section{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.join-screen__code-input{border-radius:12px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;font-family:Inter,sans-serif;outline:none;transition:all .15s ease-out}.join-screen__code-input:focus{border-color:#18bcd0;background:#ffffff26}.join-screen__code-input::placeholder{color:#fff9}.join-screen__code-input{font-size:16px;letter-spacing:.12em;padding:8px 12px}.join-screen__join-button{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.join-screen__join-button:disabled{cursor:not-allowed;opacity:.5}.join-screen__join-button{background:#18bcd0;color:#fff}.join-screen__join-button:hover:not(:disabled){background:#14a3b8}.join-screen__join-button:active:not(:disabled){transform:scale(.98)}.join-screen__join-button{font-size:14px;padding:12px 24px;white-space:nowrap}.join-screen__join-button:disabled{background:#ffffff40;color:#d1d5db;cursor:not-allowed}.join-screen__tip{font-size:12px;opacity:.8;margin-top:4px;text-align:center}.join-screen__note{font-size:10px;opacity:.7;margin-top:2px;text-align:center}.main-screen{flex:1;display:grid;place-items:center;color:#fffc;text-align:center;padding:16px}.main-screen__container{max-width:520px}.main-screen__greeting{margin-bottom:12px}.main-screen__manual-entry{margin:16px 0;padding:12px;border-radius:12px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.main-screen__manual-entry h3{margin:0 0 8px;font-size:16px;color:#fff;text-align:center}.main-screen__code-form{display:flex;gap:6px;margin-bottom:6px}.main-screen__code-input{flex:1;padding:8px;border:2px solid rgba(255,255,255,.2);border-radius:12px;background:#ffffffe6;color:#333;font-size:14px;font-weight:600;text-align:center;letter-spacing:2px;outline:none;transition:all .2s}.main-screen__code-input:focus{border-color:#667eea99;box-shadow:0 0 0 3px #667eea1a}.main-screen__code-input:disabled{opacity:.5;cursor:not-allowed}.main-screen__code-input::placeholder{letter-spacing:normal;font-weight:400}.main-screen__code-button{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.main-screen__code-button:disabled{cursor:not-allowed;opacity:.5}.main-screen__code-button{background:#18bcd0;color:#fff}.main-screen__code-button:hover:not(:disabled){background:#14a3b8}.main-screen__code-button:active:not(:disabled){transform:scale(.98)}.main-screen__code-button{font-size:12px;padding:8px 16px;white-space:nowrap;min-width:120px}.main-screen__code-hint{text-align:center;font-size:12px;opacity:.8;margin:0}.main-screen__room-code{font-size:12px;opacity:.9;margin-top:8px}.main-screen__room-code code{color:#fff}.main-screen__status{margin-top:12px;padding:8px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;font-size:14px}.main-screen__rooms-section{margin-top:16px;text-align:left}.main-screen__rooms-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.main-screen__rooms-header h3{font-size:14px;font-weight:700}.main-screen__refresh-button{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.main-screen__refresh-button:disabled{cursor:not-allowed;opacity:.5}.main-screen__refresh-button{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.main-screen__refresh-button:hover:not(:disabled){background:#ffffff26}.main-screen__refresh-button{padding:.5rem;width:36px;height:36px;font-size:1.25rem;display:flex;align-items:center;justify-content:center;border-radius:8px}.main-screen__refresh-button:hover:not(:disabled){transform:rotate(90deg)}.main-screen__refresh-button:active:not(:disabled){transform:rotate(180deg)}.main-screen__refresh-button:disabled{opacity:.5}.main-screen__rooms-list{display:grid;gap:6px}.main-screen__empty-state{font-size:12px;opacity:.8}.main-screen__room-item{display:flex;align-items:center;justify-content:space-between;padding:8px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;border-radius:12px}.main-screen__room-info .room-code{font-size:14px;color:#fff9}.main-screen__room-info .room-date{font-size:10px;opacity:.75}.main-screen__room-button{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.main-screen__room-button:disabled{cursor:not-allowed;opacity:.5}.main-screen__room-button{background:#18bcd0;color:#fff}.main-screen__room-button:hover:not(:disabled){background:#14a3b8}.main-screen__room-button:active:not(:disabled){transform:scale(.98)}.main-screen__room-button{font-size:12px;padding:6px 12px}.main-screen__actions{display:flex;gap:8px;justify-content:center;margin-top:12px;flex-wrap:wrap}.main-screen__action-button{font-size:12px;padding:6px 12px}.main-screen__action-button--primary{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.main-screen__action-button--primary:disabled{cursor:not-allowed;opacity:.5}.main-screen__action-button--primary{background:#18bcd0;color:#fff}.main-screen__action-button--primary:hover:not(:disabled){background:#14a3b8}.main-screen__action-button--primary:active:not(:disabled){transform:scale(.98)}.main-screen__action-button--secondary{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.main-screen__action-button--secondary:disabled{cursor:not-allowed;opacity:.5}.main-screen__action-button--secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.main-screen__action-button--secondary:hover:not(:disabled){background:#ffffff26}.main-screen__action-button--admin{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.main-screen__action-button--admin:disabled{cursor:not-allowed;opacity:.5}.main-screen__action-button--admin{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.main-screen__action-button--admin:hover:not(:disabled){background:#ffffff26}.main-screen__action-button--admin{background:#ffc1071a;border-color:#ffc1074d;color:#ffab00}.main-screen__action-button--admin:hover{background:#ffc10733}.main-screen__admin-section{display:flex;justify-content:center;margin-top:8px}.main-screen__location-info{font-size:10px;opacity:.75;margin-top:8px}.main-screen__auth-error{font-size:12px;margin-top:8px;color:#fecaca}.main-screen__auth-section{margin-top:16px;display:flex;gap:8px;justify-content:center}.main-screen__auth-button{font-size:12px;padding:8px 16px}.main-screen__auth-button--primary{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.main-screen__auth-button--primary:disabled{cursor:not-allowed;opacity:.5}.main-screen__auth-button--primary{background:#18bcd0;color:#fff}.main-screen__auth-button--primary:hover:not(:disabled){background:#14a3b8}.main-screen__auth-button--primary:active:not(:disabled){transform:scale(.98)}.main-screen__auth-button--secondary{border-radius:12px;border:none;cursor:pointer;font-weight:600;font-family:Inter,sans-serif;transition:all .15s ease-out}.main-screen__auth-button--secondary:disabled{cursor:not-allowed;opacity:.5}.main-screen__auth-button--secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.main-screen__auth-button--secondary:hover:not(:disabled){background:#ffffff26}.install-help-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease-out;z-index:2000}.install-help-modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.install-help-modal__content{width:min(92vw,480px);max-height:80vh;overflow:auto;background:#111827eb;border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:16px;box-shadow:0 20px 25px #0003;transform:scale(.98);animation:popIn .2s ease-out forwards}.install-help-modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.install-help-modal__header h2{font-size:16px;font-weight:700}.install-help-modal__close-button{background:transparent;border:none;color:#fff;font-size:20px;cursor:pointer;padding:0;line-height:1}.install-help-modal__instructions{font-size:14px;line-height:1.55;color:#fff9;padding-left:16px}.install-help-modal__instructions li{margin-bottom:6px}.install-help-modal__instructions b{font-weight:700}.install-help-modal__platform-section{margin:8px 0}.install-help-modal__platform-title{font-size:14px;line-height:1.55;color:#fff9;margin:8px 0}.install-help-modal__fallback{font-size:14px;line-height:1.55;color:#fff9}.install-help-modal__divider{border:none;border-top:1px solid rgba(255,255,255,.12);margin:12px 0}.install-help-modal__details{font-size:12px;color:#fffc}.install-help-modal__details summary{cursor:pointer;margin-bottom:8px}.install-help-modal__details ul{margin-top:8px;padding-left:16px}.install-help-modal__details li{margin-bottom:4px}.chat-room{display:flex;flex-direction:column;height:100vh;height:100dvh;background:#0f1729;position:relative}.chat-room__header{height:63px;background:#252c3a;display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0;position:relative}.chat-room__back-btn{background:transparent;border:none;color:#fff;font-size:14px;cursor:pointer;padding:8px;margin-left:-8px;display:flex;align-items:center;gap:6px;transition:opacity .15s ease-out;font-family:Inter,sans-serif}.chat-room__back-btn:hover{opacity:.8}.chat-room__info{position:absolute;left:50%;transform:translate(-50%);text-align:center}.chat-room__title{font-family:Poppins,sans-serif;font-weight:700;font-size:16px;color:#fff;margin:0;line-height:1.35}.chat-room__meta{display:none}.chat-room__members-btn{background:transparent;border:none;color:#fff;font-size:20px;cursor:pointer;padding:8px;margin-right:-8px;transition:opacity .15s ease-out}.chat-room__members-btn:hover{opacity:.8}.chat-room__warning{padding:12px;background:#f59e0b33;color:#f59e0b;text-align:center;font-size:12px;font-weight:500;border-bottom:1px solid rgba(245,158,11,.3)}.chat-room__members-sidebar{position:fixed;top:0;right:0;width:280px;height:100vh;background:#252c3a;z-index:100;display:flex;flex-direction:column;animation:slideInRight .2s ease-out}.chat-room__members-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid rgba(255,255,255,.2)}.chat-room__members-header h3{margin:0;font-family:Poppins,sans-serif;font-weight:600;font-size:14px;color:#fff}.chat-room__members-header button{background:transparent;border:none;font-size:20px;cursor:pointer;color:#fff9;padding:6px}.chat-room__members-header button:hover{color:#fff}.chat-room__members-loading{padding:24px;text-align:center;color:#fff9;font-size:12px}.chat-room__members-list{flex:1;overflow-y:auto;padding:8px}.chat-room__member{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;transition:background .15s ease-out}.chat-room__member:hover{background:#ffffff0d}.chat-room__member-name{flex:1;font-weight:500;color:#fff;font-size:14px}.chat-room__member-badge{font-size:10px;color:#18bcd0;font-weight:600;background:#18bcd026;padding:4px 8px;border-radius:8px}.chat-room__messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.chat-room__loading,.chat-room__error,.chat-room__empty{text-align:center;padding:24px;color:#fff9;font-size:14px}.chat-room__error{color:#ef4444}.chat-room__date-separator{text-align:center;margin:16px 0;color:#fff9;font-size:12px;font-weight:500}.chat-room__message{display:flex;gap:12px;max-width:85%;animation:messageSlideIn .2s ease-out}.chat-room__message--own{align-self:flex-end;flex-direction:row-reverse}.chat-room__message--other{align-self:flex-start}.chat-room__message-avatar{width:40px;height:40px;border-radius:50%;background:#fff;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center}.chat-room__message-avatar img{width:100%;height:100%;object-fit:cover}.chat-room__message-avatar:after{content:"😺";font-size:24px}.chat-room__message-avatar--has-image:after{display:none}.chat-room__message--own .chat-room__message-avatar{display:none}.chat-room__message-content{display:flex;flex-direction:column;gap:6px}.chat-room__message-sender{font-family:Inter,sans-serif;font-weight:500;font-size:14px;color:#fff;padding-left:4px}.chat-room__message--own .chat-room__message-sender{display:none}.chat-room__message-bubble{padding:8px 12px;max-width:300px}.chat-room__message--other .chat-room__message-bubble{background:#a4a4a44d;border-radius:4px 16px 16px}.chat-room__message--own .chat-room__message-bubble{background:#18bcd0;border-radius:16px 16px 4px}.chat-room__message-text{font-family:Inter,sans-serif;font-weight:400;font-size:16px;line-height:1.35;color:#fff;word-wrap:break-word}.chat-room__message-time{display:none}.chat-room__input-form{padding:24px;padding-bottom:calc(24px + env(safe-area-inset-bottom));display:flex;justify-content:center}.chat-room__input-container{display:flex;align-items:center;gap:4px;background:#fff;border-radius:296px;padding:8px 8px 8px 16px;width:100%;max-width:343px;box-shadow:0 4px 20px #0000004d}.chat-room__input{flex:1;border:none;background:transparent;font-family:Inter,sans-serif;font-size:14px;color:#1a1a1a;outline:none;line-height:20px}.chat-room__input::placeholder{color:#a3a3a3}.chat-room__send-btn{width:40px;height:40px;border-radius:50%;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease-out;color:#1a1a1a;font-size:20px}.chat-room__send-btn:hover:not(:disabled){background:#0000000d}.chat-room__send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-room__send-btn:before{content:"🎤";font-size:18px}.chat-room__send-btn--has-text:before{content:"➤"}.chat-room__home-indicator{height:34px;display:flex;align-items:center;justify-content:center}.chat-room__home-indicator:after{content:"";width:134px;height:5px;background:#1a1a1a;border-radius:100px}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@media (max-width: 768px){.chat-room__members-sidebar{width:100%}.chat-room__message{max-width:90%}.chat-room__input-container{max-width:100%}}.admin-panel{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;display:flex;align-items:center;justify-content:center}.admin-panel__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.admin-panel__content{position:relative;width:90%;max-width:800px;max-height:90vh;background:#252c3a;border:1px solid rgba(255,255,255,.2);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}.admin-panel__header{display:flex;justify-content:space-between;align-items:center;padding:24px;background:#18bcd0;color:#fff}.admin-panel__header h2{font-family:Poppins,sans-serif;margin:0;font-size:20px;font-weight:700}.admin-panel__header-actions{display:flex;align-items:center;gap:12px}.admin-panel__admin-email{font-size:12px;opacity:.9;padding:8px 12px;background:#fff3;border-radius:296px}.admin-panel__logout{background:#fff3;border:none;color:#fff;padding:8px 12px;border-radius:12px;cursor:pointer;font-size:12px;font-weight:500;transition:all .15s ease-out}.admin-panel__logout:hover{background:#ffffff4d}.admin-panel__close{background:#fff3;border:none;color:#fff;font-size:20px;width:36px;height:36px;border-radius:50%;cursor:pointer;transition:all .15s ease-out}.admin-panel__close:hover{background:#ffffff4d}.admin-panel__section{padding:24px;border-bottom:1px solid rgba(255,255,255,.2)}.admin-panel__section:last-child{border-bottom:none;flex:1;overflow-y:auto}.admin-panel__section h3{font-family:Poppins,sans-serif;margin:0 0 12px;font-size:14px;color:#fff}.admin-panel__section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.admin-panel__section-header h3{margin:0}.admin-panel__form{display:flex;flex-direction:column;gap:12px}.admin-panel__form-row{display:flex;gap:8px}.admin-panel__input{flex:1;padding:12px;background:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:12px;font-size:14px;color:#fff;outline:none;transition:all .15s ease-out}.admin-panel__input::placeholder{color:#fff9}.admin-panel__input:focus{border-color:#18bcd0;background:#ffffff1f}.admin-panel__btn{padding:12px 24px;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease-out;white-space:nowrap}.admin-panel__btn:disabled{opacity:.5;cursor:not-allowed}.admin-panel__btn--primary{background:#18bcd0;color:#fff}.admin-panel__btn--primary:hover:not(:disabled){background:#14a3b8}.admin-panel__btn--secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.admin-panel__btn--secondary:hover:not(:disabled){background:#ffffff26}.admin-panel__btn--danger{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.admin-panel__btn--danger:hover:not(:disabled){background:#ef44444d}.admin-panel__btn--small{padding:8px 12px;font-size:12px}.admin-panel__loading,.admin-panel__empty{padding:24px;text-align:center;color:#fff9}.admin-panel__rooms{display:flex;flex-direction:column;gap:8px}.admin-panel__room{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#ffffff08;border:1px solid rgba(255,255,255,.2);border-radius:12px;transition:all .15s ease-out}.admin-panel__room:hover{background:#ffffff0f;border-color:#18bcd0}.admin-panel__room-info{flex:1}.admin-panel__room-code{font-family:Poppins,sans-serif;font-weight:600;font-size:14px;color:#fff;margin-bottom:4px}.admin-panel__room-meta{display:flex;gap:8px;font-size:12px;color:#fff9;margin-bottom:4px}.admin-panel__room-date{font-size:10px;color:#fff9}.admin-panel__room-actions{display:flex;gap:8px}.admin-panel__qr-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1100}.admin-panel__qr-content{background:#252c3a;border:1px solid rgba(255,255,255,.2);padding:24px;border-radius:16px;text-align:center;max-width:90%}.admin-panel__qr-content h3{font-family:Poppins,sans-serif;margin:0 0 24px;color:#fff}.admin-panel__qr-image{max-width:280px;width:100%;height:auto;margin-bottom:24px;border-radius:12px;background:#fff}.admin-panel__qr-actions{display:flex;gap:12px;justify-content:center}.admin-panel__login-desc{text-align:center;color:#fff9;margin-bottom:24px;line-height:1.6}.admin-panel__login-form{display:flex;flex-direction:column;gap:12px;max-width:400px;margin:0 auto}.admin-panel__error{padding:12px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:12px;color:#ef4444;text-align:center;font-size:12px}.admin-panel__guest-note{text-align:center;color:#fff9;font-size:12px;margin-top:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,.2)}@media (max-width: 768px){.admin-panel__content{width:95%;max-height:95vh}.admin-panel__form-row{flex-direction:column}.admin-panel__room{flex-direction:column;align-items:flex-start;gap:12px}.admin-panel__room-actions{width:100%;justify-content:flex-end}}.admin-page{min-height:100vh;min-height:100dvh;background:#0f1729;display:flex;flex-direction:column}.admin-page__header{height:63px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:#252c3a;position:sticky;top:0;z-index:10}.admin-page__header h1{font-family:Poppins,sans-serif;font-size:16px;font-weight:700;margin:0;color:#fff;position:absolute;left:50%;transform:translate(-50%)}.admin-page__back-button{padding:8px 12px;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:12px;font-size:12px;font-weight:500;color:#fffc;cursor:pointer;transition:all .15s ease-out}.admin-page__back-button:hover{background:#ffffff1a;border-color:#18bcd0;color:#18bcd0}.admin-page__spacer{width:80px}.admin-page__user{display:flex;align-items:center;gap:12px}.admin-page__email{font-size:12px;color:#fff9}.admin-page__logout-button{padding:8px 12px;background:#ef4444;color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease-out}.admin-page__logout-button:hover{opacity:.9}.admin-page__content{flex:1;max-width:800px;width:100%;margin:0 auto;padding:24px 16px}.admin-login{max-width:400px;margin:24px auto;padding:24px;background:#252c3a;border:1px solid rgba(255,255,255,.2);border-radius:16px}.admin-login h2{font-family:Poppins,sans-serif;margin-top:0;margin-bottom:8px;color:#fff}.admin-login__desc{color:#fff9;margin-bottom:24px;font-size:12px}.admin-login__form{display:flex;flex-direction:column;gap:12px}.admin-login__input{padding:12px 16px;background:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:12px;font-size:14px;color:#fff;transition:all .15s ease-out}.admin-login__input::placeholder{color:#fff9}.admin-login__input:focus{outline:none;border-color:#18bcd0;background:#ffffff1f}.admin-login__input:disabled{opacity:.5;cursor:not-allowed}.admin-login__error{padding:12px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:12px}.admin-login__button{padding:12px;background:#18bcd0;color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease-out}.admin-login__button:hover:not(:disabled){background:#14a3b8}.admin-login__button:disabled{opacity:.5;cursor:not-allowed}.admin-login__note{margin-top:24px;padding-top:24px;border-top:1px solid rgba(255,255,255,.2);font-size:12px;color:#fff9;text-align:center}.admin-section{margin-bottom:24px;padding:24px;background:#252c3a;border:1px solid rgba(255,255,255,.2);border-radius:16px}.admin-section h2{font-family:Poppins,sans-serif;margin-top:0;margin-bottom:16px;color:#fff;font-size:16px}.admin-section__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.admin-section__header h2{margin:0}.admin-section__refresh-button{padding:8px;width:36px;height:36px;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:8px;font-size:16px;color:#fff9;cursor:pointer;transition:all .15s ease-out;display:flex;align-items:center;justify-content:center}.admin-section__refresh-button:hover:not(:disabled){background:#ffffff1a;border-color:#18bcd0;color:#18bcd0}.admin-section__refresh-button:disabled{opacity:.5;cursor:not-allowed}.admin-section__loading,.admin-section__empty{text-align:center;padding:24px;color:#fff9}.admin-form__row{display:flex;gap:8px;margin-bottom:12px}.admin-form__input{flex:1;padding:12px 16px;background:#ffffff14;border:1px solid rgba(255,255,255,.2);border-radius:12px;font-size:14px;color:#fff;transition:all .15s ease-out}.admin-form__input::placeholder{color:#fff9}.admin-form__input:focus{outline:none;border-color:#18bcd0}.admin-form__button{padding:12px 24px;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s ease-out;white-space:nowrap}.admin-form__button--primary{background:#18bcd0;color:#fff}.admin-form__button--primary:hover:not(:disabled){background:#14a3b8}.admin-form__button--secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.admin-form__button--secondary:hover:not(:disabled){background:#ffffff26}.admin-form__button:disabled{opacity:.5;cursor:not-allowed}.admin-rooms{display:flex;flex-direction:column;gap:8px}.admin-room{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#ffffff08;border:1px solid rgba(255,255,255,.2);border-radius:12px;transition:all .15s ease-out}.admin-room:hover{border-color:#18bcd0;background:#ffffff0d}.admin-room__info{flex:1}.admin-room__code{font-family:Poppins,sans-serif;font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.admin-room__meta{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:#fff9;margin-bottom:4px}.admin-room__date{font-size:10px;color:#fff9}.admin-room__actions{display:flex;gap:8px}.admin-room__button{padding:8px 12px;border:none;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s ease-out}.admin-room__button--qr{background:#18bcd0;color:#fff}.admin-room__button--qr:hover{background:#14a3b8}.admin-room__button--delete{background:#ef4444;color:#fff}.admin-room__button--delete:hover{opacity:.9}.qr-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.qr-modal__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.qr-modal__content{position:relative;z-index:1;background:#252c3a;padding:24px;border-radius:16px;max-width:400px;width:100%;text-align:center;border:1px solid rgba(255,255,255,.2)}.qr-modal__content h3{font-family:Poppins,sans-serif;margin-top:0;margin-bottom:24px;color:#fff}.qr-modal__image{width:280px;height:280px;margin:0 auto 24px;border-radius:12px;background:#fff}.qr-modal__actions{display:flex;gap:8px;justify-content:center}.qr-modal__button{padding:12px 24px;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block;transition:all .15s ease-out}.qr-modal__button--primary{background:#18bcd0;color:#fff}.qr-modal__button--primary:hover{background:#14a3b8}.qr-modal__button--secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.qr-modal__button--secondary:hover{background:#ffffff26}.install-banner{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;color:#fff;border-left:none;border-right:none;animation:slideUp .28s ease-out}.install-banner__copy{display:flex;flex-direction:column;gap:4px}.install-banner__label{margin:0;font-weight:700;font-size:16px}.install-banner__text{margin:0;font-size:12px;color:#fffc}.install-banner__link{font-size:12px;border:none;background:transparent;color:#18bcd0;text-decoration:underline;font-weight:600;cursor:pointer;padding:0}.install-banner__link:hover{color:#fffffff2}.install-banner__actions{display:flex;align-items:center;gap:8px}.install-banner__dismiss{font-size:12px;border:none;background:#ffffff14;color:#fff;border-radius:8px;padding:6px 8px;cursor:pointer}.install-banner__dismiss:hover{background:#ffffff1f}@media (max-width: 640px){.install-banner{flex-direction:column;align-items:flex-start}.install-banner__actions{width:100%;justify-content:space-between}.install-banner__link{padding-top:6px}}
