.app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-primary);color:var(--text-primary)}.app-header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:1rem 2rem;text-align:center}.app-header h1{margin:0;font-size:2rem;font-weight:700;color:var(--primary-color)}.subtitle{margin:.5rem 0 0;font-size:.9rem;color:var(--text-secondary);font-weight:400}.app-main{flex:1;display:flex;flex-direction:column}.app-footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);padding:1rem;text-align:center}.app-footer p{margin:0;font-size:.8rem}.app-footer a{color:var(--primary-color);text-decoration:none}.app-footer a:hover{text-decoration:underline}.join-room{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;min-height:60vh}.join-room-content{max-width:600px;width:100%}.join-room-content h2{text-align:center;margin-bottom:1rem;color:var(--text-primary)}.description{text-align:center;color:var(--text-secondary);margin-bottom:2rem;line-height:1.5}.join-options{display:grid;grid-template-columns:1fr auto 1fr;gap:2rem;align-items:start}.option{background-color:var(--bg-secondary);padding:2rem;border-radius:12px;border:1px solid var(--border-color);text-align:center}.option h3{margin-top:0;color:var(--text-primary)}.option p{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.4}.divider{display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--text-secondary);font-size:.9rem}.join-form{display:flex;flex-direction:column;gap:1rem}.form-group{width:100%}.form-input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-tertiary);color:var(--text-primary);font-size:.9rem}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-color-alpha)}.form-input::placeholder{color:var(--text-secondary)}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-align:center;text-decoration:none;display:inline-block}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:var(--bg-primary)}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:var(--border-color)}.btn-danger{background-color:var(--error-color);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--error-hover)}.btn-small{padding:.5rem 1rem;font-size:.8rem}.error-message{display:flex;align-items:center;gap:.5rem;background-color:var(--error-bg);color:var(--error-color);padding:1rem;border-radius:6px;border:1px solid var(--error-border);margin-top:1rem}.info-section{margin-top:2rem;background-color:var(--bg-secondary);padding:1.5rem;border-radius:8px;border:1px solid var(--border-color)}.info-section h3{margin-top:0;color:var(--text-primary)}.info-section ul{margin:0;padding-left:0;list-style:none}.info-section li{padding:.5rem 0;color:var(--text-secondary)}.info-section strong{color:var(--text-primary)}.install-prompt{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background-color:var(--bg-secondary);border-bottom:1px solid var(--primary-color);position:sticky;top:0;z-index:100}.install-prompt-icon{font-size:1.4rem;flex-shrink:0}.install-prompt-text{flex:1;display:flex;flex-direction:column;gap:.1rem;font-size:.85rem}.install-prompt-text strong{color:var(--text-primary)}.install-prompt-text span{color:var(--text-secondary)}.install-prompt-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.install-btn-primary{background-color:var(--primary-color);color:var(--bg-primary);border:none;border-radius:6px;padding:.4rem .9rem;font-size:.85rem;font-weight:600;cursor:pointer;min-height:36px}.install-btn-dismiss{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1rem;padding:.25rem .5rem;min-height:36px;min-width:36px}.install-btn-dismiss:hover{color:var(--text-primary)}.chat-room{flex:1;display:flex;flex-direction:column;height:100dvh;height:100vh}.connecting-screen,.error-screen,.loading-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-actions{display:flex;gap:1rem;margin-top:1rem}.chat-body{flex:1;display:flex;min-height:0;position:relative}.chat-pane{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0}.chat-content{flex:1;display:flex;flex-direction:column;min-height:0}@media (min-width: 768px){.polls-pane{width:0;overflow:hidden;transition:width .25s ease;border-left:1px solid transparent;display:flex;flex-direction:column;background:var(--bg-secondary, #12121f)}.polls-pane.polls-pane-open{width:50%;min-width:280px;max-width:520px;border-left-color:var(--border-color, #2a2a3e);overflow-y:auto}.has-active-polls .chat-pane{min-width:0}.polls-pane-backdrop{display:none}}@media (max-width: 767px){.polls-pane{position:fixed;bottom:0;left:0;right:0;max-height:70dvh;max-height:70vh;background:var(--bg-secondary, #12121f);border-top:1px solid var(--border-color, #2a2a3e);border-radius:16px 16px 0 0;z-index:200;display:flex;flex-direction:column;transform:translateY(110%);transition:transform .3s ease;overflow:hidden}.polls-pane.polls-pane-open{transform:translateY(0)}.polls-pane-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:199}}.polls-pane-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #2a2a3e);flex-shrink:0}.polls-pane-title{font-weight:600;font-size:.9rem}.polls-pane-close{background:transparent;border:none;color:var(--text-muted, #888);cursor:pointer;font-size:1rem;padding:.2rem .4rem;border-radius:4px}.polls-pane-close:hover{color:var(--text-primary, #fff)}.polls-pane-body{flex:1;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.75rem}.poll-toggle-btn{position:relative}.poll-toggle-btn.active{background:#7c3aed33!important;border-color:#7c3aed!important}.connection-warning{display:flex;align-items:center;gap:.5rem;background-color:var(--warning-bg);color:var(--warning-color);padding:.75rem 1rem;border-top:1px solid var(--warning-border)}.attach-button{background:none;border:1px solid var(--border-color, #444);border-radius:6px;color:var(--text-secondary, #aaa);cursor:pointer;font-size:1.1rem;padding:.4rem .6rem;transition:background .15s,color .15s;margin-right:.35rem}.attach-button:hover:not(:disabled){background:var(--bg-secondary, #2a2a2a);color:var(--text-primary, #eee)}.attach-button:disabled{opacity:.4;cursor:not-allowed}.transfer-progress-list{border-top:1px solid var(--border-color, #333);padding:.4rem .75rem;display:flex;flex-direction:column;gap:.3rem}.transfer-progress{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-secondary, #aaa);position:relative}.transfer-progress.transfer-complete{color:#4ade80}.transfer-progress.transfer-failed{color:#f87171}.transfer-icon{font-size:.95rem;flex-shrink:0}.transfer-info{display:flex;flex-direction:column;min-width:0}.transfer-filename{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.transfer-detail{font-size:.73rem;opacity:.75}.transfer-bar{flex:1;height:3px;background:var(--border-color, #333);border-radius:2px;overflow:hidden}.transfer-bar-fill{height:100%;background:#a78bfa;border-radius:2px;transition:width .4s ease}.file-message{display:flex;flex-direction:column;gap:.4rem}.file-message-image{max-width:min(320px,100%);max-height:260px;border-radius:8px;object-fit:contain;cursor:pointer;border:1px solid var(--border-color, #333)}.file-message-meta{display:flex;align-items:center;gap:.4rem;font-size:.85rem}.file-message-link{color:#a78bfa;text-decoration:none;word-break:break-all}.file-message-link:hover{text-decoration:underline}.file-message-size{color:var(--text-secondary, #777);font-size:.75rem}@media (max-width: 768px){.join-options{grid-template-columns:1fr;gap:1rem}.divider{writing-mode:horizontal-tb}.option{padding:1.5rem}.app-header,.join-room{padding:1rem}}.poll-card{background:var(--surface-2, #1e1e2e);border:1px solid rgba(124,58,237,.35);border-radius:12px;padding:.9rem 1rem}.poll-card.poll-closed{border-color:#ffffff1a;opacity:.85}.poll-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.poll-icon{font-size:1rem}.poll-question{font-weight:600;flex:1;font-size:.95rem}.poll-close-btn{background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:var(--text-muted, #999);font-size:.75rem;padding:.2rem .6rem;cursor:pointer}.poll-close-btn:hover{border-color:#ef4444;color:#ef4444}.poll-status-badge{font-size:.72rem;background:#ffffff14;border-radius:6px;padding:.15rem .5rem;color:var(--text-muted, #888)}.poll-options{display:flex;flex-direction:column;gap:.5rem}.poll-option{position:relative;display:flex;align-items:center;justify-content:space-between;padding:.55rem .75rem;border:1px solid rgba(124,58,237,.25);border-radius:8px;background:transparent;color:inherit;font-size:.9rem;cursor:pointer;overflow:hidden;text-align:left;width:100%;transition:border-color .15s}.poll-option:hover:not(:disabled){border-color:#7c3aedb3}.poll-option-readonly{cursor:default}.poll-option-voted{border-color:#7c3aed!important}.poll-option-bar{position:absolute;top:0;right:0;bottom:0;left:0;background:#7c3aed26;transition:width .3s ease;pointer-events:none}.poll-option-label{position:relative;z-index:1}.poll-option-count{position:relative;z-index:1;font-size:.78rem;color:var(--text-muted, #999);white-space:nowrap;margin-left:.5rem}.poll-footer{margin-top:.6rem;font-size:.78rem;color:var(--text-muted, #888)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-card{background:var(--surface, #1a1a2e);border:1px solid rgba(124,58,237,.4);border-radius:16px;padding:1.5rem;width:100%;max-width:420px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.modal-header h3{margin:0;font-size:1.1rem}.modal-label{display:block;font-size:.82rem;color:var(--text-muted, #999);margin-bottom:.35rem}.poll-option-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.4rem}.poll-option-row .form-input{flex:1}.poll-add-option{margin-top:.35rem;font-size:.85rem}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.25rem}.message-poll-inline{padding:.5rem 1rem}.message-poll-inline .poll-card{border-color:#ffffff1a}.poll-change-vote-btn{background:transparent;border:none;color:#7c3aed;font-size:.78rem;cursor:pointer;padding:0;margin-left:.5rem;text-decoration:underline}.poll-change-vote-btn:hover{color:#a78bfa}.poll-change-vote-cancel{color:var(--text-muted, #888)}.poll-option-clickable:hover{border-color:#7c3aedb3!important;cursor:pointer}.poll-budget-indicator{font-size:.78rem;color:var(--text-muted, #999);margin-bottom:.6rem}.poll-counters{display:flex;flex-direction:column;gap:.45rem;margin-bottom:.75rem}.poll-counter-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.45rem .6rem;border:1px solid rgba(124,58,237,.2);border-radius:8px;background:#7c3aed0a}.poll-counter-label{flex:1;font-size:.9rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.poll-counter-controls{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.counter-btn{width:28px;height:28px;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:transparent;color:inherit;font-size:1.1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,border-color .1s}.counter-btn:not(:disabled):hover{background:#7c3aed40;border-color:#7c3aed}.counter-btn:disabled{opacity:.3;cursor:default}.counter-value{width:1.6rem;text-align:center;font-size:1rem;font-weight:600}.poll-cast-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.poll-budget-remaining{font-size:.8rem;color:var(--text-muted, #999)}.poll-budget-remaining.budget-spent{color:#4ade80}.poll-cast-actions{display:flex;gap:.5rem}.poll-results{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.poll-result-row{display:flex;flex-direction:column;gap:.25rem}.poll-result-label{font-size:.88rem;display:flex;align-items:center;gap:.4rem}.poll-my-badge{background:#7c3aed4d;border:1px solid #7c3aed;border-radius:4px;padding:0 .3rem;font-size:.72rem;color:#a78bfa;white-space:nowrap;flex-shrink:0}.poll-result-bar-wrap{display:flex;align-items:center;gap:.5rem}.poll-result-bar-track{flex:1;height:8px;background:#ffffff14;border-radius:4px;overflow:hidden}.poll-result-bar-fill{height:100%;background:#7c3aed;border-radius:4px;transition:width .35s ease}.poll-result-mine .poll-result-bar-fill{background:#a78bfa}.poll-result-stat{font-size:.75rem;color:var(--text-muted, #999);white-space:nowrap;min-width:90px;text-align:right}.poll-budget-row{margin-top:1rem;display:flex;flex-direction:column;gap:.35rem}.poll-budget-hint{font-weight:400;color:var(--text-muted, #888)}.poll-budget-controls{display:flex;align-items:center;gap:.5rem;margin-top:.25rem}.budget-step{width:30px;height:30px;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:transparent;color:inherit;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.budget-step:not(:disabled):hover{background:#7c3aed40;border-color:#7c3aed}.budget-step:disabled{opacity:.3;cursor:default}.budget-value{width:2rem;text-align:center;font-size:1.1rem;font-weight:600}.poll-budget-desc{margin:0;font-size:.78rem;color:var(--text-muted, #888)}.message-link{color:#a78bfa;text-decoration:underline;word-break:break-all}.message-link:hover{color:#c4b5fd}:root{--bg-primary: #0f0f0f;--bg-secondary: #1a1a1a;--bg-tertiary: #2a2a2a;--text-primary: #ffffff;--text-secondary: #a0a0a0;--text-tertiary: #707070;--primary-color: #7c3aed;--primary-hover: #6d28d9;--primary-color-alpha: rgba(124, 58, 237, .2);--border-color: #333333;--border-hover: #444444;--error-color: #ff4757;--error-hover: #ff3838;--error-bg: rgba(255, 71, 87, .1);--error-border: rgba(255, 71, 87, .2);--warning-color: #ffa726;--warning-bg: rgba(255, 167, 38, .1);--warning-border: rgba(255, 167, 38, .2);--success-color: #2ed573;--success-bg: rgba(46, 213, 115, .1);--success-border: rgba(46, 213, 115, .2);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Open Sans", "Helvetica Neue", sans-serif}*,*:before,*:after{box-sizing:border-box}*{margin:0}html,body{height:100%}body{font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;background-color:var(--bg-primary);color:var(--text-primary)}#root{height:100dvh;height:100vh;isolation:isolate}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}.room-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.room-info{flex:1}.room-title{font-size:1.25rem;font-weight:600;margin:0;color:var(--text-primary)}.room-stats{display:flex;gap:1.5rem;margin-top:.5rem;font-size:.875rem;color:var(--text-secondary)}.room-stats span{display:flex;align-items:center;gap:.375rem}.my-nickname{color:var(--accent-primary, #7c6af7);font-weight:500}.room-actions{display:flex;gap:.75rem}.members-bar{display:flex;align-items:center;gap:.5rem;padding:.4rem 1rem;background:var(--bg-secondary, #1e1e2e);border-top:1px solid var(--border-color, #2a2a3e);font-size:.78rem;color:var(--text-secondary)}.members-bar-label{font-weight:600;color:var(--text-primary);white-space:nowrap}.members-bar-names{color:var(--text-secondary)}.nickname-prompt{display:flex;justify-content:center;align-items:center;padding:3rem 1rem}.nickname-prompt-card{background:var(--bg-secondary, #1e1e2e);border:1px solid var(--border-color, #2a2a3e);border-radius:12px;padding:2rem;max-width:400px;width:100%;text-align:center}.nickname-prompt-card h2{margin-bottom:.5rem}.nickname-prompt-card p{color:var(--text-secondary);margin-bottom:1.5rem}.nickname-prompt-form{display:flex;flex-direction:column;gap:1rem}.message-list{flex:1;overflow-y:auto;padding:1rem;min-height:0}.messages-container{display:flex;flex-direction:column;gap:1rem}.message{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;max-width:80%;align-self:flex-start}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.sender{font-weight:600;color:var(--text-primary);font-size:.875rem}.timestamp{font-size:.75rem;color:var(--text-tertiary);font-family:var(--font-mono)}.message-content{color:var(--text-primary);line-height:1.4;word-wrap:break-word}.message-invalid{opacity:.6;border-color:var(--error-border)}.round-indicator{text-align:center;margin:1rem 0}.round-indicator span{background-color:var(--bg-tertiary);color:var(--text-secondary);padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.round-status{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;margin:1rem 0;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;font-size:.875rem;color:var(--text-secondary)}.round-status.active{background-color:var(--primary-color-alpha);border-color:#7c3aed4d;color:var(--primary-color)}.round-status.waiting{background-color:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-color)}.empty-messages{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-icon{font-size:3rem;margin-bottom:1rem}.empty-messages h3{color:var(--text-primary);margin-bottom:.5rem}.privacy-reminder{margin-top:2rem;background-color:var(--bg-secondary);padding:1.5rem;border-radius:8px;border:1px solid var(--border-color);text-align:left;max-width:400px;margin-left:auto;margin-right:auto}.privacy-reminder h4{color:var(--primary-color);margin-bottom:1rem}.privacy-reminder ul{list-style:none;padding:0}.privacy-reminder li{padding:.25rem 0;color:var(--text-secondary)}.send-message{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);padding:1rem}.member-count-bar{display:flex;align-items:center;gap:.375rem;margin-bottom:.75rem;font-size:.8rem;color:var(--text-secondary)}.member-count-icon{font-size:.85rem}.member-count-text{font-weight:600;color:var(--text-secondary)}.member-count-hint{color:var(--text-tertiary);font-style:italic}.queued-message-indicator{display:flex;align-items:flex-start;gap:.75rem;background-color:var(--warning-bg);border:1px solid var(--warning-border);border-radius:8px;padding:1rem;margin-bottom:1rem}.indicator-icon{font-size:1.25rem;color:var(--warning-color);flex-shrink:0}.indicator-content{flex:1}.indicator-title{font-weight:600;color:var(--warning-color);margin-bottom:.25rem}.indicator-text{color:var(--text-primary);margin-bottom:.25rem;font-style:italic}.indicator-time{font-size:.75rem;color:var(--text-secondary);font-family:var(--font-mono)}.message-form{width:100%}.message-input-container{display:flex;flex-direction:column;gap:.75rem}.message-input{width:100%;min-height:44px;max-height:120px;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-tertiary);color:var(--text-primary);resize:none;font-family:inherit;line-height:1.4}.message-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-color-alpha)}.message-input::placeholder{color:var(--text-secondary)}.message-input:disabled{opacity:.6;cursor:not-allowed}.input-controls{display:flex;justify-content:space-between;align-items:center}.input-info{display:flex;align-items:center;gap:1rem;font-size:.75rem}.counter-warning{color:var(--warning-color)}.counter-over{color:var(--error-color);font-weight:600}.typing-indicator{display:flex;align-items:center;color:var(--primary-color)}.typing-dots{display:flex;gap:2px}.typing-dots span{width:4px;height:4px;background-color:var(--primary-color);border-radius:50%;animation:typing 1.4s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-10px);opacity:1}}.send-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background-color:var(--primary-color);color:var(--bg-primary);border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease}.send-button:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-1px)}.send-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.send-help{margin-top:1rem}.help-details{font-size:.875rem}.help-details summary{cursor:pointer;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.help-details summary:hover{color:var(--text-primary)}.help-content{margin-top:1rem;color:var(--text-secondary);line-height:1.4}.help-content p{margin-bottom:.75rem}.help-content ul{padding-left:1rem}.help-content li{margin-bottom:.5rem}.help-content strong{color:var(--text-primary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:100%;max-width:500px;max-height:80vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 0}.modal-header h3{margin:0;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:var(--text-primary)}.modal-content{padding:1.5rem}.invite-options{display:flex;flex-direction:column;gap:1.5rem}.invite-option{display:flex;flex-direction:column;gap:.5rem}.invite-option label{font-weight:600;color:var(--text-primary);font-size:.875rem}.invite-link-container{display:flex;gap:.5rem}.invite-link-input{flex:1;padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-tertiary);color:var(--text-primary);font-family:var(--font-mono);font-size:.75rem}.invite-option small{color:var(--text-secondary);font-size:.75rem}input,textarea,select{font-size:16px}.send-message,.app-footer{padding-bottom:calc(1rem + env(safe-area-inset-bottom))}.btn,button{min-height:44px;min-width:44px}@media (hover: none){.btn-primary:hover:not(:disabled),.send-button:hover:not(:disabled),.btn-secondary:hover:not(:disabled){transform:none}}@media (max-width: 768px){.room-header{padding:1rem}.room-stats,.room-actions{flex-direction:column;gap:.5rem}.message{max-width:95%}.message-list,.send-message{padding:.75rem}.input-controls{flex-direction:column;gap:.75rem;align-items:stretch}.send-button{align-self:flex-end}.modal{margin:1rem;max-width:calc(100vw - 2rem)}.invite-link-container{flex-direction:column}}
