:root{color:#0f172a;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 0 0,#60a5fa2e,#0000 34%),radial-gradient(circle at 100% 0,#3b82f624,#0000 28%),linear-gradient(#f7faff 0%,#edf3fb 100%);font-family:Inter,Hiragino Sans,Yu Gothic UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}h1,h2,p{margin-top:0}h1{margin-bottom:6px;font-size:clamp(2rem,3vw,2.75rem)}h2{margin-bottom:4px}button,input,textarea{font:inherit}a{color:inherit}#root{min-height:100vh}.app-shell{max-width:1100px;min-height:100dvh;margin:0 auto;padding:24px 16px 36px}.app-header{justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:18px;display:flex}.eyebrow{color:#64748b;text-transform:uppercase;letter-spacing:.12em;margin:0 0 6px;font-size:.72rem;font-weight:700}.subtle{color:#64748b}.subtle.compact{margin-bottom:0;font-size:.88rem}.route-tabs{flex-wrap:wrap;gap:8px;display:flex}.route-tabs button,.primary,.secondary,.danger,.reaction-picker-button{font:inherit;cursor:pointer;border:none;border-radius:10px;padding:10px 16px;transition:transform .15s,opacity .15s,background-color .15s,border-color .15s}.primary.compact,.secondary.compact{padding:8px 12px}.route-tabs button{color:#0f172a;background:#e2e8f0}.route-tabs button.active,.primary{color:#fff;background:#2563eb}.secondary{color:#0f172a;background:#fff;border:1px solid #cbd5e1}.danger{color:#fff;background:#dc2626}.ghost{color:#dc2626;background:0 0;border:1px solid #fecaca}.page-grid{display:grid}.panel,.chat-surface,.join-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff0;border:1px solid #dbe4ef;border-radius:16px;box-shadow:0 12px 28px #0f172a0f}.panel,.join-card{padding:22px}.chat-surface{padding:14px}.chat-surface.compact{padding:12px}.admin-panel{min-height:70vh}.panel-header,.chat-topbar{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.join-panel{min-height:70vh;box-shadow:none;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.join-card{width:min(420px,100%)}.entry-form,.login-form{gap:16px;display:grid}.login-form{grid-template-columns:minmax(0,1fr) auto;align-items:end}label{color:#0f172a;gap:8px;font-weight:600;display:grid}input,textarea{width:100%;font:inherit;box-sizing:border-box;color:#0f172a;background:#fff;border:1px solid #cbd5e1;border-radius:10px;padding:11px 13px}textarea{resize:none;min-height:56px}.error-text{color:#b91c1c;margin:0 0 12px;font-weight:700}.error-text.compact{margin-top:16px;margin-bottom:0}.chat-layout{flex-direction:column;gap:12px;min-height:calc(100dvh - 60px);display:flex}.chat-topbar.compact{align-items:center;min-height:24px;margin-bottom:0}.chat-feed,.admin-list{gap:10px;display:grid}.chat-feed{flex:auto;align-content:start;min-height:0;overflow-y:auto}.message-row{align-items:flex-end;gap:8px;display:flex}.message-row.mine{justify-content:flex-end}.message-row.other{justify-content:flex-start}.message-stack{flex-direction:column;align-items:stretch;gap:4px;width:fit-content;min-width:50%;max-width:min(78%,640px);display:flex}.message-stack.mine{align-self:flex-end}.message-stack.other{align-self:flex-start}.message-bubble{-webkit-user-select:none;user-select:none;touch-action:pan-y;border:1px solid #0000;border-radius:14px;min-width:0;padding:10px 12px}.message-bubble.mine{color:#fff;background:linear-gradient(#2d6df6 0%,#1f5be2 100%);box-shadow:0 8px 18px #2563eb24}.message-bubble.other{color:#0f172a;background:#f1f5f9;border-color:#dbe4ef}.message-meta{color:#94a3b8;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;font-size:.7rem;display:grid}.message-meta.mine{justify-content:flex-end;display:flex}.message-meta.other time{justify-self:end}.message-meta.mine time{text-align:right;justify-self:auto}.message-meta strong,.message-meta time{display:block}.message-text{white-space:pre-wrap;word-break:break-word;margin-bottom:0}.reaction-summary{flex-wrap:wrap;gap:4px;width:100%;display:flex}.reaction-chip{color:#0f172a;background:#fffc;border:1px solid #94a3b842;border-radius:999px;align-items:center;gap:4px;padding:2px 7px;font-size:.76rem;line-height:1.15;display:inline-flex}.message-bubble.mine .reaction-chip{color:#fff;background:#ffffff2e;border-color:#ffffff29}.message-stack.mine .reaction-summary{justify-content:flex-end}.composer{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;display:grid;position:sticky;bottom:0}.back-link{color:#475569;font:inherit;cursor:pointer;background:0 0;border:none;padding:0;font-size:.84rem}.connection-indicator{justify-content:center;align-items:center;min-width:20px;min-height:20px;margin-left:auto;font-size:.95rem;display:inline-flex}.connection-indicator.online{animation:1.8s ease-in-out infinite slow-pulse}.connection-indicator.offline{opacity:.95}.avatar{background:#dbeafe;border:1px solid #94a3b847;border-radius:50%;flex:none;place-items:center;display:grid;overflow:hidden}.avatar.small{width:32px;height:32px}.avatar.medium{width:40px;height:40px}.avatar img{object-fit:cover;width:100%;height:100%;display:block}.avatar span{color:#1d4ed8;font-size:.86rem;font-weight:700}.reaction-picker{z-index:1000;background:#fffffff5;border:1px solid #dbe4ef;border-radius:14px;grid-template-columns:repeat(6,1fr);gap:6px;width:264px;padding:8px;display:grid;position:fixed;transform:translate(-50%);box-shadow:0 16px 34px #0f172a1f}.reaction-picker.top{transform:translate(-50%,-100%)}.reaction-picker.bottom{transform:translate(-50%)}.reaction-picker-button{color:#0f172a;background:#f8fafc;border:1px solid #e2e8f0;place-items:center;padding:10px 0;font-size:1rem;line-height:1;display:grid}.empty-state{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:14px;padding:20px}.empty-state.compact{padding:16px}.admin-actions{gap:12px;margin-bottom:12px;display:flex}.admin-description{margin-bottom:0;line-height:1.45}.admin-table-wrap{background:#fff;border:1px solid #dbe4ef;border-radius:14px;overflow-x:auto}.admin-log-table{border-collapse:collapse;table-layout:fixed;width:100%;min-width:980px;font-size:.9rem}.admin-log-table th,.admin-log-table td{vertical-align:top;border-bottom:1px solid #e2e8f0;padding:9px 10px}.admin-log-table th{color:#475569;text-align:left;white-space:nowrap;background:#f8fafc;font-size:.82rem;font-weight:700}.admin-log-table tbody tr:last-child td{border-bottom:none}.admin-sort-button{color:inherit;font:inherit;font-weight:inherit;cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:0;display:inline-flex}.admin-sort-indicator{color:#64748b;font-size:.78rem}.admin-cell{line-height:1.35}.admin-cell-time,.admin-cell-reactions,.admin-cell-action{white-space:nowrap}.admin-cell-ip{white-space:nowrap;font-size:.84rem}.admin-cell-participant,.admin-cell-comment{white-space:pre-line}.admin-cell-participant strong,.admin-cell-participant span,.admin-cell-comment span{display:block}.admin-comment-text{word-break:break-word}.admin-device-id{color:#64748b;margin-top:4px;font-size:.72rem}.admin-cell-reactions{text-align:center;font-weight:700}.admin-cell-action{text-align:right}.admin-delete-button{padding:6px 10px;font-size:.8rem}.admin-mono{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace}.admin-col-time{width:88px}.admin-col-ip{width:150px}.admin-col-participant{width:132px}.admin-col-comment{width:400px}.admin-col-reactions{width:88px}.admin-col-action{width:74px}button:disabled{cursor:not-allowed;opacity:.55}button:hover:not(:disabled){transform:translateY(-1px)}@media (width<=900px){.app-header,.panel-header,.admin-actions{flex-direction:column}.login-form,.composer{grid-template-columns:1fr}.reaction-picker{width:min(264px,100vw - 24px)}.connection-indicator{margin-left:0}}@keyframes slow-pulse{0%,to{opacity:.35}50%{opacity:1}}
