:root{color:#17324d;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 0 0,#fff4bf 0 16%,#0000 17%),radial-gradient(circle at 100% 0,#c8f1ff 0 14%,#0000 15%),linear-gradient(#f7fbff 0%,#eef7ff 100%);font-family:Hiragino Sans,Noto Sans JP,Yu Gothic UI,Yu Gothic,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,4vw,3rem)}h2{margin-bottom:4px}button,input,textarea{font:inherit}a{color:inherit}#root{min-height:100vh}.app-shell{max-width:1180px;min-height:100dvh;margin:0 auto;padding:24px 16px 40px;display:grid}.app-hero{gap:18px;margin-bottom:18px;display:grid}.app-hero-card{background:#fff;border:4px solid #17324d;border-radius:28px;padding:28px 24px;box-shadow:0 18px #c8dff5}.app-badge{color:#fff;background:#17324d;border-radius:999px;align-items:center;gap:8px;margin:0 0 14px;padding:8px 14px;font-size:.95rem;font-weight:700;display:inline-flex}.app-title{margin-bottom:10px}.app-copy{color:#36536f;max-width:780px;margin-bottom:0;font-size:clamp(1rem,2.2vw,1.15rem)}.eyebrow{color:#fff;letter-spacing:.04em;background:#17324d;border-radius:999px;align-items:center;margin:0 0 10px;padding:6px 12px;font-size:.8rem;font-weight:700;display:inline-flex}.subtle{color:#47637e}.subtle.compact{margin-bottom:0;font-size:.95rem;line-height:1.6}.route-tabs{flex-wrap:wrap;gap:12px;display:flex}.route-tabs button,.primary,.secondary,.danger,.reaction-picker-button{font:inherit;cursor:pointer;border:none;border-radius:20px;padding:12px 18px;transition:transform .15s,opacity .15s,background-color .15s,border-color .15s,box-shadow .15s}.primary.compact,.secondary.compact{padding:10px 14px}.route-tabs button{color:#17324d;background:#fff;border:3px solid #17324d;font-weight:800}.route-tabs button.active,.primary{color:#17324d;background:#ffdf61;border:3px solid #17324d;font-weight:800}.secondary{color:#17324d;background:#c8f1ff;border:3px solid #17324d;font-weight:800}.danger{color:#17324d;background:#ff9d8b;border:3px solid #17324d;font-weight:800}.danger.ghost{color:#17324d;background:#fff4f1}.page-grid{min-height:100%;display:grid}.landing-panel{align-content:center;justify-items:start;gap:20px;min-height:70vh;display:grid}.landing-copy{max-width:720px}.landing-actions{flex-wrap:wrap;gap:12px;display:flex}.panel,.chat-surface,.join-card{background:#fff;border:4px solid #17324d;border-radius:28px;box-shadow:0 18px #c8dff5}.panel,.join-card{padding:24px 22px}.chat-surface{padding:16px}.chat-surface.compact{padding:14px}.admin-panel{min-height:70vh}.panel-header,.chat-topbar{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px;display:flex}.join-panel{min-height:calc(100dvh - 64px);box-shadow:none;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.join-card{width:min(460px,100%)}.entry-form,.login-form{gap:16px;display:grid}.login-form{grid-template-columns:minmax(0,1fr) auto;align-items:end}label{color:#17324d;gap:10px;font-weight:700;display:grid}input,textarea{width:100%;font:inherit;box-sizing:border-box;color:#17324d;background:#fff;border:3px solid #17324d;border-radius:18px;padding:12px 14px}textarea{resize:none;min-height:64px}.error-text{color:#9a241d;background:#ffe7e5;border-radius:18px;margin:0 0 12px;padding:12px 14px;font-weight:700}.error-text.compact{margin-top:16px;margin-bottom:0}.chat-layout{flex-direction:column;gap:14px;min-height:calc(100dvh - 120px);display:flex}.chat-topbar.compact{align-items:center;min-height:36px;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:3px solid #17324d;border-radius:24px;min-width:0;padding:12px 14px}.message-bubble.mine{color:#17324d;background:#ffdf61;box-shadow:0 8px #17324d14}.message-bubble.other{color:#17324d;background:#c8f1ff}.message-meta{color:#5b7895;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;font-size:.78rem;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:#17324d;background:#ffffffeb;border:2px solid #17324d;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:#17324d;background:#fff9;border-color:#17324d}.message-stack.mine .reaction-summary{justify-content:flex-end}.composer{z-index:2;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;display:grid;position:sticky;bottom:0}.back-link{color:#17324d;font:inherit;cursor:pointer;background:#fff;border:3px solid #17324d;border-radius:18px;padding:10px 14px;font-size:.92rem;font-weight:800}.connection-indicator{color:#17324d;background:#fff;border:3px solid #17324d;border-radius:18px;justify-content:center;align-items:center;gap:8px;min-height:44px;padding:10px 14px;font-size:.95rem;font-weight:800;display:inline-flex}.connection-indicator.online{background:#e5f9ec}.connection-indicator.offline{background:#ffe7e5}.avatar{background:#dbeafe;border:3px solid #17324d;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:#17324d;font-size:.86rem;font-weight:700}.reaction-picker{z-index:1000;background:#fffffffa;border:3px solid #17324d;border-radius:22px;grid-template-columns:repeat(6,1fr);gap:6px;width:264px;padding:8px;display:grid;position:fixed;transform:translate(-50%);box-shadow:0 18px #c8dff5f2}.reaction-picker.top{transform:translate(-50%,-100%)}.reaction-picker.bottom{transform:translate(-50%)}.reaction-picker-button{color:#17324d;background:#fff7d1;border:2px solid #17324d;place-items:center;padding:10px 0;font-size:1rem;line-height:1;display:grid}.empty-state{background:#f7fbff;border:3px dashed #17324d;border-radius:20px;padding:20px}.empty-state.compact{padding:16px}.admin-actions{flex-wrap:wrap;gap:12px;margin-bottom:14px;display:flex}.admin-description{margin-bottom:0;line-height:1.45}.admin-list{margin-top:18px}.admin-table-wrap{background:#fff;border:3px solid #17324d;border-radius:20px;overflow-x:auto}.admin-log-table{border-collapse:collapse;table-layout:fixed;width:100%;min-width:980px;font-size:.84rem}.admin-log-table th,.admin-log-table td{vertical-align:top;border-bottom:2px solid #d7e6f5;padding:9px 10px}.admin-log-table th{color:#17324d;text-align:left;white-space:nowrap;background:#fff7d1;font-size:.8rem;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:#47637e;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:#47637e;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);box-shadow:0 8px #17324d14}@media (width<=900px){.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}}
