:root{--bg: #050505;--bg-gradient: linear-gradient(170deg, #050505 0%, #0a0a12 40%, #080810 100%);--surface: rgba(255, 255, 255, .04);--surface-solid: #111114;--surface-hover: rgba(255, 255, 255, .07);--surface-border: rgba(255, 255, 255, .08);--text-primary: #f0f0f0;--text-secondary: rgba(255, 255, 255, .45);--text-tertiary: rgba(255, 255, 255, .25);--accent: #E8FF5A;--accent-soft: #d4eb52;--accent-dim: rgba(232, 255, 90, .08);--accent-glow: rgba(232, 255, 90, .25);--live: #FF4757;--live-dim: rgba(255, 71, 87, .12);--danger: #FF4757;--border: rgba(255, 255, 255, .06);--radius-card: 16px;--radius-btn: 12px;--radius-pill: 100px;--font: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--keyboard-offset: 0px;--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-top: env(safe-area-inset-top, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;background:var(--bg);color:var(--text-primary);font-family:var(--font);font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{min-height:100dvh;background:var(--bg-gradient);background-attachment:fixed;overflow-x:hidden}#app{min-height:100dvh}.page{min-height:100dvh;max-width:480px;margin:0 auto;padding:0 20px;padding-top:var(--safe-top)}.card{background:var(--surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--surface-border);border-radius:var(--radius-card);padding:20px;margin-bottom:12px;transition:border-color .2s,background .2s}.card:hover{border-color:#ffffff1f;background:var(--surface-hover)}.input{display:block;width:100%;padding:14px 16px;background:#ffffff08;border:1px solid var(--surface-border);border-radius:var(--radius-btn);color:var(--text-primary);font-size:16px;font-family:var(--font);outline:none;transition:border-color .2s,box-shadow .2s;margin-bottom:12px}.input:focus{border-color:#e8ff5a66;box-shadow:0 0 0 3px #e8ff5a14}.input::placeholder{color:var(--text-tertiary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:13px 22px;border:1px solid var(--surface-border);border-radius:var(--radius-btn);background:var(--surface);color:var(--text-primary);font-size:15px;font-family:var(--font);font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.btn:hover:not(:disabled){background:var(--surface-hover);border-color:#ffffff26;transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0) scale(.98)}.btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.btn--accent{background:var(--accent);color:#0a0a0a;border-color:transparent;font-weight:600;box-shadow:0 0 20px #e8ff5a26}.btn--accent:hover:not(:disabled){background:var(--accent-soft);box-shadow:0 0 30px #e8ff5a40;transform:translateY(-1px)}.btn--danger{background:transparent;color:var(--danger);border-color:#ff47574d}.btn--danger:hover:not(:disabled){background:#ff475714;border-color:#ff475780}.btn--full{width:100%}.btn--small{padding:7px 14px;font-size:13px;border-radius:8px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:10px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.icon-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.icon-btn--active{color:var(--accent)}.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;letter-spacing:.3px}.badge--live{background:var(--live-dim);color:var(--live)}.live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--live);box-shadow:0 0 8px var(--live);animation:pulse-dot 1.5s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;box-shadow:0 0 8px var(--live)}50%{opacity:.5;box-shadow:0 0 4px var(--live)}}.toast{position:fixed;bottom:calc(100px + var(--safe-bottom));left:50%;transform:translate(-50%) translateY(20px);background:var(--surface-solid);color:var(--text-primary);border:1px solid var(--surface-border);border-radius:var(--radius-pill);padding:10px 24px;font-size:14px;font-weight:500;z-index:1000;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none;white-space:nowrap;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 32px #0006}.toast--visible{opacity:1;transform:translate(-50%) translateY(0)}.landing{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;position:relative;overflow:hidden}.landing:before{content:"";position:absolute;top:20%;left:50%;transform:translate(-50%,-50%);width:400px;height:400px;background:radial-gradient(circle,rgba(232,255,90,.06) 0%,transparent 70%);pointer-events:none}.landing__content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;gap:8px;position:relative;z-index:1}.landing__logo{display:flex;flex-direction:column;align-items:center;gap:16px;margin-bottom:12px}.landing__icon{width:64px;height:64px;border-radius:20px;background:var(--accent-dim);border:1px solid rgba(232,255,90,.15);display:flex;align-items:center;justify-content:center;box-shadow:0 0 40px #e8ff5a1a}.landing__title{font-size:40px;font-weight:700;letter-spacing:-1.5px;background:linear-gradient(135deg,#fff,#ffffffb3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing__tagline{font-size:18px;font-weight:500;color:var(--text-primary);letter-spacing:-.3px}.landing__subtitle{font-size:15px;color:var(--text-secondary);margin-bottom:40px;line-height:1.5}.landing__cta{width:100%;max-width:320px}.landing__features{display:flex;gap:24px;margin-top:48px;padding:0 8px}.landing__feature{flex:1;text-align:center}.landing__feature-icon{width:40px;height:40px;border-radius:12px;background:var(--surface);border:1px solid var(--surface-border);display:flex;align-items:center;justify-content:center;margin:0 auto 8px;color:var(--accent)}.landing__feature-text{font-size:12px;color:var(--text-secondary);line-height:1.4}.landing__footer{padding:24px 0;font-size:12px;color:var(--text-tertiary);padding-bottom:calc(24px + var(--safe-bottom));letter-spacing:1px;text-transform:uppercase}.login{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}.login__content{width:100%;max-width:380px}.login__title{font-size:28px;font-weight:700;margin-bottom:32px;text-align:center;letter-spacing:-.5px}.login__form{width:100%}.login__label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:8px;font-weight:500;letter-spacing:.2px}.login__hint{font-size:14px;color:var(--text-secondary);margin-bottom:24px;text-align:center;word-break:break-all;line-height:1.5}.login__error{color:var(--danger);font-size:14px;margin-bottom:12px}.login__loading{font-size:14px;color:var(--text-secondary);text-align:center;margin-bottom:12px}.otp-inputs{display:flex;gap:8px;justify-content:center;margin-bottom:24px}.otp-input{width:48px;height:60px;text-align:center;font-size:24px;font-weight:600;font-family:var(--font);background:#ffffff08;border:1px solid var(--surface-border);border-radius:var(--radius-btn);color:var(--text-primary);outline:none;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none}.otp-input:focus{border-color:#e8ff5a66;box-shadow:0 0 0 3px #e8ff5a14}.login__resend{display:block;width:100%;background:none;border:none;color:var(--accent);font-size:14px;font-family:var(--font);font-weight:500;cursor:pointer;padding:12px 0;text-align:center;transition:opacity .15s}.login__resend:hover{opacity:.8}.login__resend:disabled{color:var(--text-tertiary);cursor:not-allowed}.login__back{display:block;margin-top:32px;background:none;border:none;color:var(--text-secondary);font-size:14px;font-family:var(--font);cursor:pointer;text-align:center;width:100%;transition:color .15s}.login__back:hover{color:var(--text-primary)}.dashboard{padding-top:calc(24px + var(--safe-top));padding-bottom:calc(24px + var(--safe-bottom))}.dashboard__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.dashboard__title{font-size:26px;font-weight:700;letter-spacing:-.5px}.dashboard__user{display:flex;align-items:center;gap:12px}.dashboard__name{font-size:13px;color:var(--text-secondary)}.dashboard__logout{background:none;border:none;color:var(--text-tertiary);font-size:13px;font-family:var(--font);cursor:pointer;transition:color .15s}.dashboard__logout:hover{color:var(--text-primary)}.dashboard__loading{text-align:center;color:var(--text-secondary);padding:60px 0;font-size:14px}.dashboard__live-card{border-color:#ff475733;background:#ff475708;position:relative;overflow:hidden}.dashboard__live-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--live),transparent)}.dashboard__live-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.dashboard__listeners{display:flex;align-items:center;gap:5px;font-size:14px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.dashboard__room-title{font-size:18px;font-weight:600;margin-bottom:14px;letter-spacing:-.3px}.dashboard__url-row{display:flex;align-items:center;gap:8px;margin-bottom:14px}.dashboard__url{flex:1;font-size:13px;color:var(--text-tertiary);background:#0000004d;padding:10px 14px;border-radius:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:SF Mono,Fira Code,monospace}.dashboard__rec-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.dashboard__rec-status{font-size:14px;color:var(--text-secondary)}.dashboard__actions{display:flex;gap:8px}.dashboard__actions .btn{flex:1}.dashboard__waiting-card{border-color:var(--surface-border)}.dashboard__archive{margin-top:32px}.dashboard__section-title{font-size:13px;font-weight:600;margin-bottom:14px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.dashboard__archive-item{display:flex;align-items:center;justify-content:space-between}.dashboard__archive-info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.dashboard__archive-title{font-size:15px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard__archive-date{font-size:12px;color:var(--text-tertiary)}.dashboard__archive-actions{display:flex;gap:2px;flex-shrink:0}.dashboard__create-form{margin-top:12px}.dashboard__create-actions{display:flex;gap:8px;margin-top:4px}.dashboard__create-actions .btn{flex:1}.dashboard__create-btn{margin-top:16px}.join{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}.join__content{width:100%;max-width:380px}.join__loading{text-align:center;color:var(--text-secondary);padding:60px 0}.join__error-state{text-align:center}.join__error-msg{color:var(--text-secondary);margin-bottom:24px}.join__room-info{text-align:center;margin-bottom:36px}.join__status{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;border-radius:var(--radius-pill);font-size:13px;font-weight:600;margin-bottom:20px;letter-spacing:.3px}.join__status--live{background:var(--live-dim);color:var(--live)}.join__status--scheduled{background:var(--accent-dim);color:var(--accent)}.join__status--ended{background:var(--surface);color:var(--text-secondary)}.join__title{font-size:26px;font-weight:700;margin-bottom:8px;letter-spacing:-.5px}.join__host{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.join__count{font-size:13px;color:var(--text-tertiary)}.join__form{width:100%}.join__waiting-msg,.join__ended-msg{text-align:center;font-size:15px;color:var(--text-secondary);padding:24px 0}.room{display:flex;flex-direction:column;height:100dvh;padding:0;overflow:hidden;background:var(--bg)}.room-header{flex-shrink:0;padding:14px 20px;padding-top:calc(14px + var(--safe-top));background:#0a0a0acc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}.room-header__top{display:flex;align-items:center;gap:10px;margin-bottom:8px}.room-header__live{display:flex;align-items:center;gap:6px;flex-shrink:0}.live-text{font-size:12px;font-weight:700;color:var(--live);text-transform:uppercase;letter-spacing:1px}.room-header__title{flex:1;font-size:15px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.2px}.room-header__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:10px;background:transparent;color:var(--text-secondary);cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:all .15s}.room-header__close:hover{background:var(--surface-hover);color:var(--text-primary)}.room-header__bottom{display:flex;align-items:center;gap:12px}.room-header__timer{font-size:13px;color:var(--text-tertiary);font-variant-numeric:tabular-nums;font-family:SF Mono,Fira Code,monospace}.room-header__controls{display:flex;gap:6px;flex:1}.room-header__rec{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border:1px solid var(--surface-border);border-radius:var(--radius-pill);background:transparent;color:var(--text-secondary);font-size:11px;font-weight:600;font-family:var(--font);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .15s;letter-spacing:.5px}.room-header__rec--active{color:var(--live);border-color:#ff47574d;background:var(--live-dim)}.rec-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:currentColor}.room-header__rec--active .rec-dot{box-shadow:0 0 6px var(--live);animation:pulse-dot 1s ease-in-out infinite}.room-header__end{padding:4px 12px;border:1px solid rgba(255,71,87,.25);border-radius:var(--radius-pill);background:transparent;color:var(--danger);font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .15s}.room-header__end:hover{background:var(--live-dim)}.room-header__count{display:flex;align-items:center;gap:5px;font-size:14px;color:var(--text-secondary);flex-shrink:0;margin-left:auto;font-variant-numeric:tabular-nums}.room__body{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.speaker-grid{display:flex;gap:20px;padding:24px 20px;justify-content:center;flex-wrap:wrap;flex-shrink:0}.speaker{display:flex;flex-direction:column;align-items:center;gap:8px;width:76px}.speaker__avatar{position:relative;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#e8ff5a14,#e8ff5a05);border:2px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:all .3s ease}.speaker__avatar--speaking{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-dim),0 0 20px #e8ff5a26;animation:speaker-ring 1.2s ease-in-out infinite alternate}@keyframes speaker-ring{0%{box-shadow:0 0 0 3px var(--accent-dim),0 0 15px #e8ff5a1a}to{box-shadow:0 0 0 6px var(--accent-dim),0 0 25px #e8ff5a33}}.speaker__initial{font-size:22px;font-weight:600;color:var(--text-primary);-webkit-user-select:none;user-select:none}.speaker__muted{position:absolute;bottom:-2px;right:-2px;width:20px;height:20px;border-radius:50%;background:var(--surface-solid);border:1px solid var(--surface-border);display:flex;align-items:center;justify-content:center}.speaker__name{font-size:12px;color:var(--text-secondary);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;display:flex;flex-direction:column;align-items:center;gap:3px}.speaker__badge{display:inline-block;font-size:9px;font-weight:700;color:var(--accent);background:var(--accent-dim);padding:2px 6px;border-radius:var(--radius-pill);letter-spacing:1px}.pinned-comment{display:flex;align-items:center;gap:10px;padding:12px 20px;background:var(--accent-dim);border-top:1px solid rgba(232,255,90,.08);border-bottom:1px solid rgba(232,255,90,.08);flex-shrink:0}.pinned-comment__icon{color:var(--accent);flex-shrink:0}.pinned-comment__content{flex:1;min-width:0;font-size:14px}.pinned-comment__name{font-weight:600;margin-right:6px;color:var(--accent)}.pinned-comment__body{color:var(--text-secondary)}.pinned-comment__unpin{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:50%;background:transparent;color:var(--text-secondary);cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:color .15s}.pinned-comment__unpin:hover{color:var(--text-primary)}.comment-feed-wrapper{flex:1;position:relative;overflow:hidden;min-height:0}.comment-feed{height:100%;overflow-y:auto;padding:8px 20px;-ms-overflow-style:none;scrollbar-width:none}.comment-feed::-webkit-scrollbar{display:none}.comment-item{padding:5px 0;font-size:14px;line-height:1.5;animation:comment-in .25s ease-out}.comment-item--pinned{background:var(--accent-dim);margin:2px -10px;padding:5px 10px;border-radius:8px}@keyframes comment-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.comment-item__name{font-weight:600;margin-right:6px;color:var(--accent);font-size:13px}.comment-item__body{color:#fffc;word-break:break-word}.comment-item__reaction{font-size:20px}.comment-feed__new{position:absolute;bottom:8px;left:50%;transform:translate(-50%);padding:7px 18px;border:1px solid var(--surface-border);border-radius:var(--radius-pill);background:var(--surface-solid);color:var(--text-primary);font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;z-index:5;animation:comment-in .2s ease-out;-webkit-tap-highlight-color:transparent;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 4px 16px #0000004d}.hand-raise-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px;margin-bottom:6px;border:1px solid var(--surface-border);border-radius:var(--radius-btn);background:transparent;color:var(--text-secondary);font-size:14px;font-weight:500;font-family:var(--font);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .2s}.hand-raise-btn--active{background:var(--accent-dim);color:var(--accent);border-color:#e8ff5a33;box-shadow:0 0 16px #e8ff5a14}.hand-raise-btn__icon{font-size:18px}.hand-raise-list{margin:0 20px;padding:12px 14px;background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius-card);flex-shrink:0;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.hand-raise-list__title{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.hand-raise-list__item{display:flex;align-items:center;justify-content:space-between;padding:6px 0}.hand-raise-list__name{font-size:14px;font-weight:500}.hand-raise-list__actions{display:flex;gap:6px}.hand-raise-list__accept{padding:5px 12px;border:none;border-radius:8px;background:var(--accent);color:#0a0a0a;font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .15s}.hand-raise-list__accept:hover{box-shadow:0 0 12px #e8ff5a33}.hand-raise-list__reject{padding:5px 12px;border:1px solid var(--surface-border);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:12px;font-family:var(--font);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all .15s}.room__bottom{flex-shrink:0;padding:10px 20px;padding-bottom:calc(10px + var(--safe-bottom) + var(--keyboard-offset));background:#0a0a0ad9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);transition:padding-bottom .15s}.reaction-bar__reactions{display:flex;gap:6px;justify-content:center;margin-bottom:10px}.reaction-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;border-radius:14px;background:var(--accent-dim);color:var(--accent);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.reaction-btn:hover{background:#e8ff5a1f;box-shadow:0 0 12px #e8ff5a1a}.reaction-btn:active{transform:scale(.9)}.reaction-btn--bounce{animation:reaction-bounce .4s ease-out}@keyframes reaction-bounce{0%{transform:scale(1)}25%{transform:scale(.75)}55%{transform:scale(1.25)}to{transform:scale(1)}}.reaction-bar__form{display:flex;gap:8px}.reaction-bar__input{flex:1;padding:12px 16px;background:#ffffff0a;border:1px solid var(--surface-border);border-radius:var(--radius-btn);color:var(--text-primary);font-size:15px;font-family:var(--font);outline:none;min-width:0;transition:border-color .2s,box-shadow .2s}.reaction-bar__input:focus{border-color:#e8ff5a4d;box-shadow:0 0 0 2px #e8ff5a0f}.reaction-bar__input::placeholder{color:var(--text-tertiary)}.reaction-bar__send{padding:12px 18px;border:none;border-radius:var(--radius-btn);background:var(--accent);color:#0a0a0a;font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:all .15s}.reaction-bar__send:hover{box-shadow:0 0 16px #e8ff5a33}.reaction-bar__send:disabled{opacity:.25;cursor:not-allowed;box-shadow:none}.room__reconnecting{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);padding:18px 32px;background:var(--surface-solid);border:1px solid var(--surface-border);border-radius:var(--radius-card);font-size:15px;color:var(--text-primary);z-index:100;animation:comment-in .2s ease-out;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 16px 48px #00000080}.not-found{display:flex;align-items:center;justify-content:center;text-align:center}.not-found__content{display:flex;flex-direction:column;align-items:center;gap:12px}.not-found__code{font-size:72px;font-weight:700;color:var(--text-tertiary);letter-spacing:-2px}.not-found__text{font-size:16px;color:var(--text-secondary);margin-bottom:16px}@media(min-width:481px){.room{max-width:480px;margin:0 auto;border-left:1px solid var(--border);border-right:1px solid var(--border)}}
