/* werewolf-game.css — 狼人杀子应用 */
.werewolf-page{--ww-accent:#646b78;display:flex;flex-direction:column;background:linear-gradient(180deg,#f6f7f8,#eceef1);color:var(--c-text,#34363a);font-family:var(--font,-apple-system,"PingFang SC",sans-serif);overflow:hidden}.ww-header{display:flex;align-items:flex-start;gap:10px;flex:0 0 auto;padding:calc(14px + env(safe-area-inset-top,0px)) 18px 12px}.ww-header>div{flex:1}.ww-header h1{margin:1px 0 0;font-size:26px;line-height:1.15}.ww-kicker{font-size:10px;letter-spacing:.12em;color:var(--c-sub,#888);font-weight:700}.ww-back{width:38px;height:38px;border:0;border-radius:50%;background:transparent;color:inherit;font-size:24px}.ww-main{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:6px 18px calc(24px + env(safe-area-inset-bottom,0px))}.ww-hero{text-align:center;padding:28px 16px 20px}.ww-moon{width:76px;height:76px;margin:0 auto 18px;border-radius:50%;display:grid;place-items:center;background:#5b626e;color:#fff;font-size:32px;box-shadow:0 14px 34px rgba(48,53,61,.25)}.ww-eyebrow{margin:0;color:#7d8490;font-size:12px;font-weight:700;letter-spacing:.1em}.ww-hero h2{margin:7px 0 5px;font-size:30px}.ww-hero>p:last-child{margin:0;color:var(--c-sub,#777);font-size:13px}.ww-panel,.ww-account,.ww-room-status,.ww-role-card{background:var(--c-bg,#fff);border:1px solid var(--c-border,rgba(0,0,0,.06));border-radius:16px;box-shadow:0 4px 18px rgba(28,31,35,.05)}.ww-panel{padding:16px;margin-bottom:14px}.ww-panel h3,.ww-login-card h3{margin:0 0 7px;font-size:17px}.ww-panel>p,.ww-login-card>p{color:var(--c-sub,#777);font-size:13px;line-height:1.6}.ww-primary,.ww-secondary{min-height:46px;border:0;border-radius:12px;padding:0 18px;font-weight:700;font-size:14px}.ww-primary{background:#555d69;color:#fff}.ww-secondary{background:var(--c-bg,#fff);border:1px solid var(--c-border-m,rgba(0,0,0,.12));color:var(--c-text,#333)}.ww-primary:disabled,.ww-secondary:disabled{opacity:.4}.ww-login-card .ww-primary{width:100%;margin-top:10px;background:#111;color:#fff}.ww-account{display:flex;align-items:center;gap:12px;padding:13px;margin-bottom:12px}.ww-account>div{flex:1;display:flex;flex-direction:column}.ww-account b{font-size:15px}.ww-account span,.ww-seat small,.ww-friend small{color:var(--c-sub,#888);font-size:11px;margin-top:2px}.ww-account button{border:0;background:transparent;color:#66707e}.ww-avatar{width:42px;height:42px;flex:0 0 42px;border-radius:50%;overflow:hidden;display:grid;place-items:center;background:#d8dce2;color:#5c6470;font-weight:700}.ww-avatar img{width:100%;height:100%;object-fit:cover}.ww-room-status{padding:15px;margin-bottom:20px}.ww-room-status>div:first-child{display:flex;justify-content:space-between;color:var(--c-sub,#777);font-size:13px}.ww-room-status b{color:var(--c-text,#333);font-size:16px}.ww-slot-dots{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-top:12px}.ww-slot-dots i{height:5px;border-radius:5px;background:#e3e5e9}.ww-slot-dots i.filled{background:#687180}.ww-section-head h3{margin:0;font-size:17px}.ww-section-head p{margin:4px 0 11px;font-size:12px;color:var(--c-sub,#888)}.ww-friend-list{display:flex;flex-direction:column;gap:8px}.ww-friend{width:100%;display:flex;align-items:center;gap:11px;padding:10px 12px;border:1px solid transparent;border-radius:14px;background:var(--c-bg,#fff);color:inherit;text-align:left}.ww-friend>span:nth-child(2){flex:1;display:flex;flex-direction:column}.ww-friend.selected{border-color:#77808d;background:#f3f4f6}.ww-friend>i{color:#7c8490}.ww-empty{padding:24px;text-align:center;color:var(--c-sub,#888);font-size:13px}.ww-actions{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:16px}.ww-loading{height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.ww-loading h2{font-size:20px;margin:18px 0 5px}.ww-loading p{font-size:12px;color:var(--c-sub,#888)}.ww-spinner{width:30px;height:30px;border:3px solid rgba(90,98,110,.18);border-top-color:#606875;border-radius:50%;animation:ww-spin .8s linear infinite}@keyframes ww-spin{to{transform:rotate(360deg)}}.ww-role-card{text-align:center;padding:28px 20px;margin:16px 0}.ww-role-icon{width:70px;height:70px;border-radius:50%;display:grid;place-items:center;margin:0 auto 17px;background:#59616d;color:#fff;font-size:28px}.ww-role-card>p{margin:0;color:var(--c-sub,#888);font-size:12px}.ww-role-card h2{font-size:32px;margin:4px 0 15px}.ww-role-rule{padding:14px;border-radius:12px;background:#f2f3f5;font-size:13px;line-height:1.65;text-align:left}.ww-secret{margin-top:12px;padding:12px;border:1px solid #d6c8c8;background:#f7eeee;border-radius:12px;font-size:13px}.ww-bottom-button{width:100%;margin-top:10px}.ww-night{padding-top:6px}.ww-night-title{text-align:center;padding:15px}.ww-night-title>i{font-size:44px;color:#5e6673}.ww-night-title h2{margin:9px 0}.ww-night-wait{text-align:center;padding:30px 5px}.ww-night-wait p{font-weight:700;margin:12px 0 3px}.ww-night-wait small{color:var(--c-sub,#888)}.ww-pulse{width:18px;height:18px;border-radius:50%;margin:auto;background:#67707e;box-shadow:0 0 0 0 rgba(103,112,126,.45);animation:ww-pulse 1.4s infinite}@keyframes ww-pulse{70%{box-shadow:0 0 0 15px transparent}}.ww-stage-done{padding:9px 12px;margin-bottom:8px;border-radius:10px;background:rgba(89,115,92,.1);color:#58725b;font-size:12px}.ww-stage-done i{margin-right:7px}.ww-target-grid{display:flex;flex-direction:column;gap:7px;margin:12px 0}.ww-target{display:flex;align-items:center;gap:10px;padding:8px;border-radius:12px;border:1px solid var(--c-border,rgba(0,0,0,.07))}.ww-target span{flex:1}.ww-target .ww-avatar{width:38px;height:38px;flex-basis:38px}.ww-target input{accent-color:#606977}.ww-panel textarea,.ww-user-turn textarea{width:100%;box-sizing:border-box;min-height:82px;padding:11px;border:1px solid var(--c-border-m,rgba(0,0,0,.12));border-radius:11px;background:var(--c-bg,#fff);color:inherit;font:inherit;resize:none;margin:7px 0}.ww-panel>.ww-primary,.ww-user-turn>.ww-primary{width:100%}.ww-victim{padding:10px;border-radius:10px;background:#f3f4f6}.ww-option{display:flex;align-items:center;gap:8px;padding:10px 0;font-size:13px}.ww-option input{accent-color:#606977}.ww-field{display:flex;flex-direction:column;gap:7px;font-size:12px;color:var(--c-sub,#777);margin-bottom:12px}.ww-field select{height:42px;border:1px solid var(--c-border-m,rgba(0,0,0,.12));border-radius:10px;background:var(--c-bg,#fff);color:inherit;padding:0 10px}.ww-dawn{text-align:center;padding:32px 10px}.ww-sun{font-size:45px;color:#d4a851}.ww-dawn p{font-size:12px;color:var(--c-sub,#777);margin:8px 0}.ww-dawn h2{font-size:25px;margin:0 0 8px}.ww-dawn small{color:var(--c-sub,#888)}.ww-seat-list{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ww-seat{display:flex;align-items:center;gap:8px;padding:9px;border-radius:12px;background:var(--c-bg,#fff)}.ww-seat>span{min-width:0;display:flex;flex-direction:column}.ww-seat .ww-avatar{width:34px;height:34px;flex-basis:34px}.ww-seat b{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ww-seat.dead{opacity:.45;filter:grayscale(1)}.ww-progress{text-align:center;color:var(--c-sub,#888);font-size:11px;margin-bottom:10px}.ww-speeches{display:flex;flex-direction:column;gap:10px}.ww-speech{display:flex;align-items:flex-start;gap:9px}.ww-speech .ww-avatar{width:34px;height:34px;flex-basis:34px}.ww-speech>div{padding:9px 11px;border-radius:4px 13px 13px;background:var(--c-bg,#fff);box-shadow:0 2px 9px rgba(0,0,0,.04)}.ww-speech b{font-size:11px;color:var(--c-sub,#777)}.ww-speech p{margin:4px 0 0;font-size:13px;line-height:1.55}.ww-user-turn{margin-top:14px;padding:15px;border-radius:15px;background:var(--c-bg,#fff);box-shadow:0 4px 18px rgba(0,0,0,.05)}.ww-user-turn h3{margin:0}.ww-speaking{padding:28px;text-align:center;color:var(--c-sub,#777);font-size:12px}.ww-dots{display:flex;justify-content:center;gap:4px;margin-bottom:9px}.ww-dots i{width:6px;height:6px;border-radius:50%;background:#78818e;animation:ww-dot 1s infinite}.ww-dots i:nth-child(2){animation-delay:.15s}.ww-dots i:nth-child(3){animation-delay:.3s}@keyframes ww-dot{50%{transform:translateY(-5px)}}.ww-private-hint{margin-top:0!important;padding:9px;border-radius:9px;background:#f2f3f5}.ww-private-hint i{margin-right:5px}.ww-exile{text-align:center;padding:24px}.ww-exile-avatar .ww-avatar{width:72px;height:72px;margin:auto}.ww-exile p{margin:10px 0 2px;color:var(--c-sub,#777);font-size:12px}.ww-exile h2{margin:0;font-size:25px}.ww-result{text-align:center;padding:24px 15px;margin-bottom:14px;border-radius:16px;background:#555d69;color:#fff}.ww-result>i{font-size:38px}.ww-result p{font-size:11px;opacity:.75;margin:9px 0 2px}.ww-result h2{font-size:28px;margin:0 0 6px}.ww-result span{font-size:12px;opacity:.85}.ww-result.good{background:#667565}.ww-reveal-list>div{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--c-border,rgba(0,0,0,.06))}.ww-reveal-list>div:last-child{border:0}.ww-reveal-list>div>span{display:flex;flex:1;justify-content:space-between;align-items:center}.ww-reveal-list small{color:#737b86}.ww-reveal-list .ww-avatar{width:34px;height:34px;flex-basis:34px}.ww-report-log{max-height:260px;overflow:auto}.ww-report-log p{font-size:12px!important;color:var(--c-text,#333)!important;border-left:2px solid #a5aab2;padding-left:9px}.ww-report-log span{display:block;font-size:9px;color:var(--c-sub,#888);margin-bottom:2px}
:root.theme-dark .werewolf-page{background:linear-gradient(180deg,#17191d,#101114)}:root.theme-dark .ww-role-rule,:root.theme-dark .ww-victim,:root.theme-dark .ww-private-hint{background:#25282d}:root.theme-dark .ww-friend.selected{background:#24272c}:root.theme-dark .ww-slot-dots i{background:#30333a}
@media(max-width:360px){.ww-actions{grid-template-columns:1fr}.ww-main{padding-left:14px;padding-right:14px}}
.ww-wolf-chat{padding:13px;border-radius:12px;background:#f3eeee;border:1px solid #e4d7d7}.ww-wolf-chat b{font-size:13px}.ww-wolf-chat p{font-size:13px;line-height:1.6;margin:6px 0}.ww-wolf-chat small{display:block;padding-top:8px;border-top:1px solid rgba(100,60,60,.12);color:#796d6d;line-height:1.5}
:root.theme-dark .ww-wolf-chat{background:#2b2426;border-color:#413437}
.ww-wolf-votes{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0}.ww-wolf-votes>div{min-width:0;padding:11px;border-radius:11px;background:#f4f1f2;border:1px solid #e7dde0;display:flex;flex-direction:column;gap:4px}.ww-wolf-votes span{font-size:10px;color:#8a777d}.ww-wolf-votes b{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ww-wolf-votes small{font-size:11px;line-height:1.45;color:#756b6e;word-break:break-word}.ww-wolf-thinking{margin-top:8px;padding:8px!important;border:0!important;border-radius:8px;background:rgba(100,60,70,.07)}.ww-wolf-agreement{margin:10px 0;padding:9px 11px;border-radius:9px;text-align:center;font-size:12px;font-weight:700}.ww-wolf-agreement.agreed{background:rgba(83,117,88,.12);color:#58755c}.ww-wolf-agreement.split{background:rgba(145,102,72,.12);color:#896548}.ww-wolf-chat+.ww-wolf-agreement+.ww-primary{width:100%}
:root.theme-dark .ww-wolf-votes>div{background:#272225;border-color:#403438}:root.theme-dark .ww-wolf-votes small,:root.theme-dark .ww-wolf-votes span{color:#b6a6aa}

/* 固定头像比例，避免名单中的通用 flex 规则把头像拉成椭圆 */
.werewolf-page .ww-avatar{position:relative;width:42px;height:42px;min-width:42px;max-width:42px;min-height:42px;max-height:42px;flex:0 0 42px;aspect-ratio:1/1;display:block!important;overflow:hidden;border-radius:50%;background:#d8dce2;color:#5c6470;font-size:15px;font-weight:700;line-height:1;text-align:center}
.werewolf-page .ww-avatar img{display:block;width:100%;height:100%;min-width:100%;max-width:100%;object-fit:cover;border-radius:inherit}
.werewolf-page .ww-avatar>.ww-avatar-fallback{position:absolute;inset:0;width:100%;height:100%;margin:0!important;padding:0;display:flex!important;align-items:center!important;justify-content:center!important;color:inherit;font:inherit;line-height:1;text-align:center;transform:none}
.ww-reveal-list>div>.ww-avatar,.ww-ready-list>div>.ww-avatar{flex:0 0 34px;width:34px;height:34px;min-width:34px;max-width:34px;min-height:34px;max-height:34px;font-size:13px}
.ww-exile-avatar .ww-avatar{flex:0 0 72px;width:72px;height:72px;min-width:72px;max-width:72px;min-height:72px;max-height:72px;margin:auto}
.ww-exile-avatar .ww-avatar>.ww-avatar-fallback{font-size:24px}

.ww-ready-hero{text-align:center;padding:18px 10px 22px}.ww-ready-hero p{margin:0;color:var(--c-sub,#888);font-size:11px;font-weight:700;letter-spacing:.1em}.ww-ready-hero h2{margin:5px 0;font-size:27px}.ww-ready-hero span{font-size:12px;color:var(--c-sub,#888)}
.ww-ready-list>div{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--c-border,rgba(0,0,0,.06))}.ww-ready-list>div:last-child{border-bottom:0}.ww-ready-copy{min-width:0;flex:1;display:flex;flex-direction:column}.ww-ready-copy b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.ww-ready-copy small{margin-top:2px;color:var(--c-sub,#888);font-size:10px}.ww-ready-list>div>i{color:#66806a;font-size:12px}

.ww-spinner{margin-left:auto;margin-right:auto}.ww-vote-wait{display:flex;flex-direction:column;align-items:center}.ww-vote-wait .ww-spinner{order:0}.ww-vote-wait p{order:1}
.ww-vote-speeches{margin-bottom:14px}.ww-vote-speeches>h3{margin:0 0 10px;font-size:15px}.ww-vote-speeches .ww-speeches{max-height:300px;overflow-y:auto;padding-right:2px}
.ww-vote-result,.ww-last-words{padding:15px;margin-bottom:14px;border-radius:15px;background:var(--c-bg,#fff);box-shadow:0 4px 18px rgba(0,0,0,.05)}.ww-vote-result h3,.ww-last-words h3{margin:0 0 10px;font-size:15px}.ww-vote-result>div{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--c-border,rgba(0,0,0,.06));font-size:13px}.ww-vote-result>div:last-child{border-bottom:0}.ww-vote-result>div>b{color:#69717d}.ww-last-words p{font-size:13px;line-height:1.65;color:var(--c-sub,#666)}.ww-last-words .ww-primary{width:100%}
.ww-reveal-copy{display:flex!important;flex:1;justify-content:space-between;align-items:center;min-width:0}

/* 大厅子页面统一使用标题返回，不显示独立返回箭头 */
.ww-heading{min-width:0;flex:1;padding:0;border:0;background:transparent;color:inherit;text-align:left}
.ww-heading:active{opacity:.58}
.ww-header .ww-kicker{letter-spacing:.04em;text-transform:none}
.ww-history{min-height:36px;padding:0 2px;border:0;background:transparent;color:var(--c-sub,#777);font-size:12px;display:flex;align-items:center;gap:5px;white-space:nowrap}
.ww-history:active{opacity:.55}

.ww-room-intro{padding:12px 2px 18px}
.ww-room-intro p{margin:0 0 5px;color:var(--c-sub,#888);font-size:12px}
.ww-room-intro h2{margin:0;font-size:22px}
.ww-room-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ww-room-card{min-height:178px;padding:15px;border:1px solid var(--c-border,rgba(0,0,0,.07));border-radius:16px;background:var(--c-bg,#fff);color:inherit;text-align:left;box-shadow:0 4px 18px rgba(28,31,35,.05);display:flex;flex-direction:column;align-items:flex-start}
.ww-room-card:active{transform:scale(.98)}
.ww-room-count{padding:6px 9px;border-radius:9px;background:var(--c-surface-2,#f0f1f3);color:#68717e;font-size:12px;font-weight:700}
.ww-room-card h3{margin:16px 0 5px;font-size:17px}
.ww-room-card p{min-height:34px;margin:0 0 13px;color:var(--c-sub,#888);font-size:11px;line-height:1.5}
.ww-room-card b{margin-top:auto;color:var(--c-sub,#999);font-size:11px}
.ww-room-card.available{border-color:#727b88}
.ww-room-card.available .ww-room-count{background:#5a626f;color:#fff}
.ww-room-card.available b{color:#59626f}

.ww-history-list{display:flex;flex-direction:column;gap:10px;padding-top:5px}
.ww-history-card{width:100%;padding:15px;border:1px solid var(--c-border,rgba(0,0,0,.07));border-radius:15px;background:var(--c-bg,#fff);color:inherit;font:inherit;text-align:left;box-shadow:0 4px 18px rgba(28,31,35,.05)}
.ww-history-card:active{transform:scale(.985)}
.ww-history-card>div{display:flex;justify-content:space-between;gap:10px;align-items:center}
.ww-history-card>div b{font-size:12px;color:#68717e}
.ww-history-card time{color:var(--c-sub,#999);font-size:10px}
.ww-history-card h3{margin:12px 0 4px;font-size:17px}
.ww-history-card p{margin:0 0 12px;color:var(--c-sub,#777);font-size:12px}
.ww-history-card>span{font-size:10px;color:var(--c-sub,#999)}
.ww-history-empty{height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--c-sub,#888)}
.ww-history-empty>i{font-size:34px}
.ww-history-empty h2{margin:16px 0 5px;color:var(--c-text,#333);font-size:20px}
.ww-history-empty p{margin:0;font-size:12px}
.ww-seer-reveal{text-align:center;padding:8px 2px 2px}
.ww-seer-reveal-icon{width:64px;height:64px;margin:0 auto 13px;border-radius:50%;display:grid;place-items:center;background:#667565;color:#fff;font-size:25px}
.ww-seer-reveal.is-wolf .ww-seer-reveal-icon{background:#66545a}
.ww-seer-reveal>p{margin:0;color:var(--c-sub,#888);font-size:11px}
.ww-seer-reveal>h3{margin:5px 0 12px;font-size:17px}
.ww-seer-reveal>strong{display:block;font-size:30px}
.ww-seer-reveal>small{display:block;margin:8px 0 18px;color:var(--c-sub,#888);font-size:11px}
.ww-seer-reveal>.ww-primary{width:100%}
.ww-report-log .ww-legacy-log{border-left:0;padding:12px;text-align:center;color:var(--c-sub,#888)!important}
:root.theme-dark .ww-room-card,:root.theme-dark .ww-history-card{background:var(--c-surface,#191b1f)}
@media(max-width:360px){.ww-room-grid{grid-template-columns:1fr}.ww-room-card{min-height:145px}}
