:root{--bg:#f8f5f2;--surface:#fffdfb;--text:#2e2a28;--muted:#746a65;--line:#e7ddd6;--accent:#d95f5f;--accent-soft:#f7e4df;--ok:#1f8a70;--warning:#f2c96b}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body,html{margin:0;padding:0;min-height:100%;background:radial-gradient(circle at top,#fff8f2 0,var(--bg) 48%,#efe7e1 100%);color:var(--text);font-family:Noto Sans SC,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}body{min-width:320px;overflow-x:hidden}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.page{min-height:100dvh;padding:calc(16px + env(safe-area-inset-top)) calc(16px + env(safe-area-inset-right)) calc(20px + env(safe-area-inset-bottom)) calc(16px + env(safe-area-inset-left))}.container{width:min(1100px,100%);margin:0 auto}.title{margin:0;font-size:clamp(28px,5vw,36px);line-height:1.1}.subtitle{margin:8px 0 0;color:var(--muted);line-height:1.5}.panel{background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:0 16px 40px rgba(80,55,35,.06)}.btn{border:0;border-radius:12px;cursor:pointer;padding:10px 16px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;font-size:14px;line-height:1.2;text-align:center;white-space:normal}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{background:var(--accent-soft);color:#5c3933}.input,.select,.textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:11px 12px;min-height:46px;font-size:16px;line-height:1.4;background:#fff;color:var(--text)}.textarea{min-height:110px;resize:vertical}.grid{display:grid;grid-gap:16px;gap:16px}.room-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.room-card{padding:16px;display:flex;flex-direction:column;gap:12px}.room-card-header{display:flex;gap:10px;align-items:flex-start;justify-content:space-between;flex-wrap:wrap}.room-surface{color:#4f4540;line-height:1.6;min-height:52px;word-break:break-word}.muted{color:var(--muted)}.modal-mask{background:rgba(35,22,13,.45);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100}.global-loading,.modal-mask{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:16px}.global-loading{z-index:160;background:rgba(35,22,13,.24);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.global-loading-card{min-width:156px;max-width:min(280px,100%);display:grid;justify-items:center;grid-gap:12px;gap:12px;padding:18px 20px;border:1px solid rgba(92,57,51,.12);border-radius:18px;background:rgba(255,253,251,.96);box-shadow:0 16px 40px rgba(80,55,35,.14)}.global-loading-spinner{width:30px;height:30px;border-radius:50%;border:3px solid rgba(217,95,95,.18);border-top:3px solid var(--accent);animation:spin .85s linear infinite}.global-loading-text{text-align:center;line-height:1.45;color:#5f4b42}.modal{width:min(460px,100%);padding:18px}.row,.row-between{display:flex;gap:10px;align-items:center;min-width:0;flex-wrap:wrap}.row-between{justify-content:space-between}.row-between>*,.row>*{min-width:0}.badge{border-radius:999px;padding:4px 10px;background:#f2e9e3;color:#634f45;font-size:12px;max-width:100%;white-space:normal;word-break:break-word}.game-shell{display:grid;grid-template-columns:280px minmax(0,1fr);grid-gap:16px;gap:16px;align-items:start}.sidebar{padding:14px;height:-moz-fit-content;height:fit-content;position:-webkit-sticky;position:sticky;top:16px}.chat{min-width:0;padding:16px;gap:14px}.chat,.message-list{display:flex;flex-direction:column}.message-list{height:min(58dvh,620px);overflow:auto;padding-right:4px;gap:10px;overscroll-behavior:contain}.msg{max-width:min(560px,100%);border-radius:12px;padding:10px 12px;background:#f6f1ed;line-height:1.5;word-break:break-word}.msg-system{background:#fff1ef;border:1px solid #f0d4ce}.msg-header{font-size:12px;color:var(--muted);margin-bottom:4px}.pill-ok{background:#e8f7f3;color:#0f6e57}.player-item{border:1px solid var(--line);border-radius:10px;padding:8px 10px;line-height:1.5;word-break:break-word}.player-turn{border-color:#f3c9bd;background:#fff7f4}.surface-box{border:2px dashed #efcfc8;border-radius:16px;padding:16px}.clue-panel{padding:12px;border-color:#d8e5ef;background:#f8fbfe}.clue-list{display:grid;grid-gap:8px;gap:8px;margin-top:10px}.clue-item{border:1px solid #dbe6ee;border-radius:12px;padding:10px 12px;background:#fff}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:16px;gap:16px}.chat-compose,.form-grid,.hero-actions,.hero-header,.lobby-toolbar,.status-strip,.turn-alert{min-width:0}.hero-actions{justify-content:flex-end}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px}.field-stack{display:grid;grid-gap:6px;gap:6px}.field-stack label{color:var(--muted);font-size:13px}.status-strip{display:flex;flex-wrap:wrap;gap:8px}.turn-alert{display:grid;grid-gap:6px;gap:6px;padding:12px 14px;border-radius:14px;background:#f2e9e3;border:1px solid transparent}.turn-alert strong{font-size:16px;line-height:1.3}.turn-alert-active{background:#fff6df;border-color:var(--warning);box-shadow:0 0 0 3px hsla(42,84%,68%,.18);animation:turnPulse 1.8s ease-in-out infinite}.chat-compose{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:10px;gap:10px;align-items:end}.chat-compose-actions{display:flex;gap:10px;align-items:center}.chat-compose .btn{min-width:88px}.invite-float{bottom:calc(10px + env(safe-area-inset-bottom))}.app-version,.invite-float{position:fixed;right:12px;max-width:calc(100vw - 24px)}.app-version{bottom:calc(48px + env(safe-area-inset-bottom));z-index:30;padding:6px 10px;border:1px solid rgba(92,57,51,.14);border-radius:999px;background:rgba(255,253,251,.88);box-shadow:0 10px 26px rgba(80,55,35,.1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#6e5b52;font-size:12px;line-height:1.2;letter-spacing:.02em;pointer-events:none}@keyframes turnPulse{0%,to{transform:translateY(0);box-shadow:0 0 0 0 hsla(42,84%,68%,.18)}50%{transform:translateY(-1px);box-shadow:0 0 0 5px hsla(42,84%,68%,.12)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:900px){.game-shell{grid-template-columns:1fr}.sidebar{position:static}.message-list{height:min(46dvh,460px)}.chat-compose,.form-grid{grid-template-columns:1fr}.chat-compose-actions{width:100%}.chat-compose-actions .btn{flex:1 1}}@media (max-width:640px){.page{padding:calc(12px + env(safe-area-inset-top)) calc(12px + env(safe-area-inset-right)) calc(16px + env(safe-area-inset-bottom)) calc(12px + env(safe-area-inset-left))}.panel{border-radius:16px}.title{font-size:24px}.muted,.subtitle{font-size:14px}.admin-grid,.room-grid{grid-template-columns:1fr}.modal{padding:16px}.btn,.hero-actions,.lobby-toolbar,.status-strip{width:100%}.badge{font-size:11px}.message-list{height:min(42dvh,380px)}.app-version{right:10px;bottom:calc(44px + env(safe-area-inset-bottom));font-size:11px}}