:root{color:#14242b;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#f6f1e7;font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0;overflow-x:hidden}#root{min-width:0}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled,textarea:disabled{cursor:not-allowed;opacity:.58}.app-shell{background-position:50%;background-size:cover;min-height:100vh;padding:18px}.entry-panel,.room-shell{width:min(1500px,100%);min-width:0;margin:0 auto}.entry-panel{background:#fffcf4eb;border:1px solid #19363e24;border-radius:8px;align-content:center;justify-items:start;gap:18px;max-width:460px;min-height:calc(100vh - 36px);padding:36px;display:grid;box-shadow:0 24px 80px #16272b2e}.brand-lockup,.room-brand,.panel-title,.header-stat,.topic-footnote,.form-actions,.result-box,.hint-box{align-items:center;display:flex}.brand-lockup{color:#b57b14;gap:12px}.brand-lockup h1,.room-brand h1{color:#14242b;margin:0;font-size:44px;line-height:1}.entry-copy{color:#49636b;margin:0;line-height:1.7}.segmented{background:#eef4f1;border:1px solid #165c5a2e;border-radius:8px;grid-template-columns:repeat(2,1fr);width:100%;padding:4px;display:grid}.segmented button{color:#49636b;background:0 0;border:0;border-radius:6px;min-height:38px;font-weight:700}.segmented .active{color:#fff;background:#0d766f;box-shadow:0 6px 16px #0d766f38}.entry-form{gap:14px;width:100%;display:grid}label{color:#2c4850;gap:8px;font-size:14px;font-weight:800;display:grid}input,textarea,select{color:#14242b;background:#ffffffd1;border:1px solid #14242b2e;border-radius:8px;outline:none;width:100%}input,select{min-height:44px;padding:0 12px}textarea{resize:vertical;min-height:112px;padding:14px;line-height:1.65}input:focus,textarea:focus,select:focus{border-color:#0d766f;box-shadow:0 0 0 3px #0d766f26}.primary-action,.secondary-action,.danger-action,.room-code{border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:44px;font-weight:850;display:inline-flex}.primary-action{color:#fff;background:linear-gradient(#16a085,#0b7169);box-shadow:0 10px 22px #0d766f40}.secondary-action{color:#6b4a12;background:#fff8ed;border:1px solid #b57b1447}.danger-action{color:#fff;background:linear-gradient(#ef6b59,#d74035);box-shadow:0 10px 22px #d740353d}.wide{width:100%}.error-text,.toast-error{color:#b42318;margin:0;font-weight:800}.toast-error{background:#ffece8f0;border:1px solid #b423182e;border-radius:8px;margin:12px 0;padding:10px 12px}.room-header{color:#fff6e8;background:#07363b;border-radius:8px;grid-template-columns:minmax(230px,1fr) auto auto;align-items:center;gap:14px;min-height:78px;padding:14px 18px;display:grid;box-shadow:0 22px 60px #0a26293d}.room-brand{gap:12px}.room-brand h1{color:#fff6e8;font-size:30px}.room-brand p{color:#ffd47a;margin:4px 0 0;font-weight:800}.room-code{color:#fff;background:#ffffff14;border:1px solid #fff3;padding:0 14px}.room-code strong{color:#ffd47a;font-size:18px}.header-stat{background:#ffffff14;border-radius:8px;justify-content:center;gap:8px;min-height:44px;padding:0 14px;font-weight:850}.game-grid{grid-template-columns:280px minmax(0,1fr) 300px;gap:12px;min-width:0;margin-top:12px;display:grid}.center-stack,.right-stack{align-content:start;gap:12px;min-width:0;display:grid}.panel{background:#fffcf4f0;border:1px solid #14242b1f;border-radius:8px;min-width:0;box-shadow:0 14px 40px #14242b1a}.panel-title{color:#0b575c;gap:8px;padding:14px 16px 0}.panel-title h2,.speaking-header h2{margin:0;font-size:17px}.roster-list{gap:8px;padding:14px;display:grid}.player-row{background:#ffffffad;border:1px solid #14242b14;border-radius:8px;grid-template-columns:26px 38px minmax(0,1fr);align-items:center;gap:10px;min-height:54px;padding:8px;display:grid}.player-row.self{background:#eef8f4;border-color:#0d766f66}.seat-number,.avatar{justify-content:center;align-items:center;font-weight:900;display:inline-flex}.seat-number{color:#fff;background:#173d48;border-radius:6px;width:24px;height:24px;font-size:13px}.avatar{color:#173d48;background:#f2c36b;border:2px solid #fff;border-radius:50%;width:38px;height:38px}.player-main{min-width:0}.player-main strong{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.online,.offline{font-size:12px}.online{color:#16825d}.offline{color:#8a96a0}.badges{flex-wrap:wrap;grid-column:2/-1;gap:5px;display:flex}.badge,.phase-chip{border:1px solid #0000;border-radius:6px;align-items:center;min-height:22px;padding:2px 7px;font-size:12px;font-weight:900;display:inline-flex}.badge.smart,.role-badge.smart{color:#8a5700;background:#fff0c2;border-color:#e2b44e}.badge.honest,.role-badge.honest{color:#0b6e67;background:#dff8f2;border-color:#8bd4c6}.badge.bluffer,.role-badge.bluffer{color:#b33125;background:#ffe4df;border-color:#f0a195}.badge.host{color:#3b4a52;background:#eef1f4;border-color:#cfd8df}.hint-box{color:#486068;background:#f5f7f1;border-radius:8px;gap:8px;margin:0 14px 14px;padding:12px;font-size:13px;line-height:1.55}.order-panel{padding-bottom:14px}.turn-track{gap:10px;padding:14px 16px 0;display:flex;overflow-x:auto}.turn-dot{color:#66787e;justify-items:center;gap:6px;min-width:84px;display:grid}.turn-dot span{background:#e5e9e7;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-weight:900;display:inline-flex}.turn-dot.current span{color:#fff;background:#f2b844;outline:3px solid #f2b8443d}.turn-dot strong{text-overflow:ellipsis;white-space:nowrap;color:#203238;max-width:82px;overflow:hidden}.topic-layout{grid-template-columns:minmax(0,1.45fr) minmax(260px,.9fr);gap:12px;min-width:0;display:grid}.topic-card,.identity-card,.speaking-panel,.action-panel,.score-panel{padding:18px}.overline{color:#0b575c;margin:0 0 8px;font-size:13px;font-weight:900}.topic-card h2{text-align:center;margin:28px 0;font-size:clamp(38px,5vw,78px);line-height:1.05}.topic-footnote{color:#5b6c72;background:#f5efe3;border-radius:8px;gap:8px;min-height:42px;padding:10px 12px}.role-badge{border:1px solid #d8dedc;border-radius:8px;align-items:center;width:fit-content;min-height:34px;padding:0 12px;font-size:18px;font-weight:950;display:inline-flex}.role-badge.unknown{color:#63747b;background:#eef1f4}.answer-box{color:#17464a;background:#edf8f5;border:1px solid #0d766f2e;border-radius:8px;min-height:96px;margin-top:18px;padding:14px;line-height:1.65}.answer-box p{margin:8px 0 0}.answer-box.hidden{color:#66787e;background:#f6f4ef;align-items:center;gap:10px;display:flex}.speaking-header{justify-content:space-between;align-items:start;gap:12px;display:flex}.phase-chip{color:#875300;background:#fff1c8;border-color:#e6c26c}.live-flow-card{color:#17464a;background:#edf8f5;border:1px solid #0d766f2e;border-radius:8px;align-items:flex-start;gap:12px;margin:16px 0 14px;padding:16px;display:flex}.live-flow-card svg{color:#0d766f;flex:none}.live-flow-card strong{font-size:22px;line-height:1.2;display:block}.live-flow-card p,.empty-line{color:#526971;margin:6px 0 0;line-height:1.65}.action-panel{gap:14px;display:grid}.accuse-box{gap:10px;display:grid}.result-box{color:#6a4300;background:#fff6dd;border-radius:8px;flex-direction:column;align-items:flex-start;gap:8px;padding:14px}.result-box h3,.result-box p{margin:0}.phase-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.phase-list li{color:#62747b;background:#eef1f4b3;border-radius:8px;padding:9px 10px;font-weight:800}.phase-list .active{color:#0b575c;background:#dff5ee}.score-table{gap:7px;padding-top:12px;display:grid}.score-row{border-bottom:1px solid #14242b14;justify-content:space-between;gap:10px;padding:8px 0;display:flex}.score-row span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}@media (width<=1160px){.game-grid{grid-template-columns:250px minmax(0,1fr)}.right-stack{grid-column:1/-1;grid-template-columns:1fr 1fr}}@media (width<=820px){body{min-width:0}.app-shell{padding:8px}.room-header,.game-grid,.topic-layout,.right-stack{grid-template-columns:minmax(0,1fr)}.room-header{align-items:stretch;gap:8px;min-height:0;padding:12px}.room-brand{gap:10px}.room-brand h1{font-size:28px}.room-brand p{font-size:13px}.room-code,.header-stat{width:100%;min-height:38px}.game-grid{gap:10px;margin-top:10px}.center-stack{order:1}.right-stack{order:2}.roster-panel{order:3}.panel-title{padding:12px 12px 0}.roster-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:12px}.player-row{grid-template-columns:24px minmax(0,1fr);align-content:start;gap:8px;min-height:72px}.avatar{display:none}.player-main{align-self:center}.badges{grid-column:1/-1}.turn-track{scrollbar-width:thin;overscroll-behavior-x:contain;gap:8px;padding:12px 12px 0}.turn-dot{min-width:68px}.turn-dot strong{max-width:66px;font-size:12px}.topic-card,.identity-card,.speaking-panel,.action-panel,.score-panel{padding:14px}.topic-card h2{overflow-wrap:anywhere;margin:20px 0;font-size:clamp(34px,13vw,52px)}.topic-footnote,.answer-box{font-size:14px}.answer-box{min-height:78px}textarea{min-height:104px}.speaking-header{flex-direction:column;align-items:stretch}.entry-panel{min-height:calc(100vh - 20px);padding:24px}}@media (width<=430px){.brand-lockup h1{font-size:40px}.entry-panel{min-height:calc(100vh - 16px);padding:22px}.roster-list{grid-template-columns:minmax(0,1fr)}.score-panel{padding-bottom:10px}}
