:root{color:#eef2f8;background:#11141a;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(135deg,rgba(176,54,68,.14),transparent 28%),linear-gradient(225deg,rgba(55,129,117,.12),transparent 34%),#11141a}button,input,select,textarea{font:inherit}button{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:0 14px;border:1px solid #c84f62;border-radius:8px;background:#c84f62;color:#fff;cursor:pointer;font-weight:700;overflow:hidden;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease,transform .18s ease}button:after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 0 38%,rgba(255,255,255,.18) 48%,transparent 58% 100%);opacity:0;transform:translate(-120%)}button:not(:disabled):hover{box-shadow:0 10px 24px #00000038;transform:translateY(-1px)}button:not(:disabled):hover:after{animation:buttonSheen .68s ease}button:disabled{cursor:not-allowed;opacity:.48}button.ghost{border-color:#374151;background:#1b2029;color:#d7deea}button.selected{border-color:#52b3a5;background:#1e5b55}.iconOnly{width:42px;padding:0}.wide{width:100%}input,select,textarea{width:100%;border:1px solid #313947;border-radius:8px;background:#171b23;color:#eef2f8;outline:none}input,select{height:42px;padding:0 12px}textarea{min-height:96px;padding:12px;resize:vertical}textarea:disabled{cursor:not-allowed;opacity:.58}label{display:grid;gap:8px;color:#aeb8c8;font-size:13px;font-weight:700}.entry{position:relative;display:grid;min-height:100dvh;padding:32px;overflow:hidden;background:linear-gradient(180deg,#080a101a,#080a10e6),linear-gradient(115deg,rgba(82,179,165,.16),transparent 42%),linear-gradient(245deg,rgba(200,79,98,.14),transparent 44%),#0d1016;isolation:isolate}.entry:before{content:"";position:absolute;inset:0;z-index:-2;background:linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(180deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:74px 74px;-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.72),transparent 88%);mask-image:linear-gradient(180deg,rgba(0,0,0,.72),transparent 88%)}.entry:after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(13,16,22,.08),transparent 34%,transparent 64%,rgba(13,16,22,.36)),linear-gradient(0deg,rgba(13,16,22,.86),transparent 42%);pointer-events:none}.entryBackdrop{position:absolute;inset:0;overflow:hidden;pointer-events:none}.entryMoon{position:absolute;top:54px;right:9%;display:grid;width:86px;height:86px;place-items:center;border:1px solid rgba(240,189,97,.38);border-radius:50%;background:linear-gradient(145deg,#ffffff73,#f0bd612e),#d8c992;color:#5a4633;box-shadow:0 0 48px #f0bd6133,inset -12px -10px 24px #593b2a38;animation:entryMoonFloat 5.6s ease-in-out infinite}.entryTable{position:absolute;left:50%;top:50%;width:540px;height:540px;transform:translate(-50%,-45%)}.entryTable:before{content:"";position:absolute;inset:9%;border:1px solid rgba(82,179,165,.18);border-radius:50%;background:radial-gradient(circle at 50% 50%,rgba(82,179,165,.2),transparent 34%),radial-gradient(circle at 50% 50%,rgba(18,26,34,.92),rgba(11,13,18,.06) 64%,transparent 68%);filter:blur(1px)}.entryTableTop{position:absolute;inset:116px;display:flex;align-items:center;justify-content:center;gap:12px;border:2px solid rgba(82,179,165,.58);border-radius:50%;background:linear-gradient(145deg,rgba(255,255,255,.08),transparent 42%),#19212a;box-shadow:0 0 74px #52b3a538,inset 0 0 44px #0000006b;animation:tableBreath 3.2s ease-in-out infinite}.entryRoleCard{display:grid;width:76px;height:108px;place-items:center;border:1px solid rgba(238,242,248,.22);border-radius:8px;color:#f7efe5;font-size:28px;font-weight:950;box-shadow:0 18px 32px #00000047;animation:entryCardFloat 3.4s ease-in-out infinite}.entryRoleCard.wolf{background:linear-gradient(160deg,#773340,#321720);transform:translateY(14px) rotate(-12deg)}.entryRoleCard.seer{background:linear-gradient(160deg,#365f78,#172733);transform:translateY(-6px);animation-delay:.18s}.entryRoleCard.witch{background:linear-gradient(160deg,#486f5f,#172a24);transform:translateY(14px) rotate(12deg);animation-delay:.36s}.entrySeat{position:absolute;width:34px;height:52px;border:1px solid rgba(238,242,248,.56);border-radius:14px 14px 6px 6px;background:linear-gradient(180deg,#ffffffe0,#aeb8c8ad);box-shadow:0 0 24px #52b3a53d;animation:seatFlicker 2.8s ease-in-out infinite}.entrySeat:after{content:"";position:absolute;left:8px;right:8px;top:8px;height:9px;border-radius:999px;background:#1b20295c}.entrySeat.seat1{left:50%;top:2%;transform:translate(-50%)}.entrySeat.seat2{left:79%;top:12%;transform:translate(-50%) rotate(36deg);animation-delay:90ms}.entrySeat.seat3{left:96%;top:40%;transform:translate(-50%,-50%) rotate(72deg);animation-delay:.18s}.entrySeat.seat4{left:88%;top:73%;transform:translate(-50%,-50%) rotate(124deg);animation-delay:.27s}.entrySeat.seat5{left:64%;top:94%;transform:translate(-50%,-50%) rotate(164deg);animation-delay:.36s}.entrySeat.seat6{left:36%;top:94%;transform:translate(-50%,-50%) rotate(-164deg);animation-delay:.45s}.entrySeat.seat7{left:12%;top:73%;transform:translate(-50%,-50%) rotate(-124deg);animation-delay:.54s}.entrySeat.seat8{left:4%;top:40%;transform:translate(-50%,-50%) rotate(-72deg);animation-delay:.63s}.entrySeat.seat9{left:21%;top:12%;transform:translate(-50%) rotate(-36deg);animation-delay:.72s}.entryPanel{display:grid;position:relative;z-index:1;width:min(1120px,100%);min-height:calc(100dvh - 64px);grid-template-columns:minmax(0,1fr) minmax(320px,390px);align-items:end;gap:44px;margin:auto}.entryPanel h1,.topbar h1{margin:0;letter-spacing:0}.entryPanel h1{font-size:62px;line-height:1.02;text-shadow:0 18px 40px rgba(0,0,0,.42)}.entryCopy{display:grid;gap:18px;max-width:620px;padding-bottom:58px}.lead{color:#b7c0cf;line-height:1.7}.entryCopy .lead{max-width:440px;color:#dde4ef;font-size:18px;font-weight:650}.entryBadges{display:flex;flex-wrap:wrap;gap:10px}.entryBadges span{display:inline-flex;align-items:center;gap:7px;min-height:34px;padding:0 12px;border:1px solid rgba(82,179,165,.28);border-radius:999px;background:#0f161e94;color:#dce8e7;font-size:13px;font-weight:850}.entryControls{display:grid;gap:14px;padding:18px;border:1px solid rgba(82,179,165,.24);border-radius:8px;background:linear-gradient(180deg,#1b2029d6,#0f1219e6),#0f1219d6;box-shadow:0 24px 70px #00000052,inset 0 1px #ffffff14;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.entryPrimary{min-height:52px;font-size:17px}.entryActions{display:grid;gap:10px}.entryJoin{display:grid;grid-template-columns:minmax(0,1fr) 88px}.entryJoin button{border-color:#52b3a57a;background:#1b2029e0}.roomBrowser{display:grid;gap:10px;padding-top:4px}.roomBrowserHeader{display:flex;align-items:center;justify-content:space-between;gap:10px;color:#eef2f8;font-size:14px}.emptyRooms{margin:0;color:#8f9bac;font-size:13px}.roomList{display:grid;gap:8px;max-height:300px;overflow:auto;padding-right:2px}.roomListItem{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;min-height:58px;padding:10px 12px;border-color:#52b3a557;background:#171b23e6;color:#eef2f8;text-align:left}.roomListItem.locked{border-color:#343c49;background:#171b238f}.roomListItem span{display:grid;gap:3px;min-width:0}.roomListItem span:last-child{justify-items:end;text-align:right}.roomListItem strong,.roomListItem b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.roomListItem em,.roomListItem small{overflow:hidden;color:#9aa6b8;font-size:12px;font-style:normal;font-weight:750;text-overflow:ellipsis;white-space:nowrap}.eyebrow{margin:0 0 8px;color:#52b3a5;font-size:12px;font-weight:800;text-transform:uppercase}.entryActions,.joinLine,.composerActions,.topActions,.actionLine,.presetRow{display:flex;gap:10px}.entry .entryActions{display:grid;gap:10px}.entry .entryJoin{display:grid;grid-template-columns:minmax(0,1fr) 88px}.topActions{align-items:center;flex-wrap:wrap;justify-content:flex-end}.topHeaderControls{display:flex;align-items:center;flex-wrap:wrap;gap:10px;justify-content:flex-end}.mobileNav{display:none}.joinLine input{min-width:0}.appShell{display:grid;min-height:100vh;grid-template-rows:auto 1fr;--phase: #52b3a5;--phase-strong: #f0bd61;--phase-soft: rgba(82, 179, 165, .14);background:linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(180deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:44px 44px}.phase-night{--phase: #6f8df0;--phase-strong: #e7bf68;--phase-soft: rgba(111, 141, 240, .16)}.phase-day{--phase: #55c7aa;--phase-strong: #f0bd61;--phase-soft: rgba(85, 199, 170, .15)}.phase-vote{--phase: #d7657a;--phase-strong: #f0bd61;--phase-soft: rgba(215, 101, 122, .16)}.phase-last_words{--phase: #8aa0a8;--phase-strong: #f0bd61;--phase-soft: rgba(138, 160, 168, .15)}.phase-shoot{--phase: #f0bd61;--phase-strong: #d7657a;--phase-soft: rgba(240, 189, 97, .15)}.phase-ended{--phase: #b9c2d1;--phase-strong: #f0bd61;--phase-soft: rgba(185, 194, 209, .12)}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 24px;border-bottom:1px solid color-mix(in srgb,var(--phase) 42%,#2a313d);background:linear-gradient(90deg,var(--phase-soft),rgba(17,20,26,.92) 38%),#11141ae6;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.topbar h1{font-size:24px}.roomStats{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.roomStats span{display:inline-flex;align-items:center;gap:6px;min-height:34px;padding:0 10px;border:1px solid #313947;border-radius:8px;background:#171b23;color:#cbd5e3;font-size:13px;font-weight:800}.mainGrid{display:grid;grid-template-columns:280px minmax(0,1fr) 360px;gap:16px;padding:16px}.sidebar,.chatPanel{display:grid;align-content:start;gap:16px}.panel,.chatPanel{border:1px solid color-mix(in srgb,var(--phase) 18%,#2d3441);border-radius:8px;background:#141820e6;box-shadow:0 18px 45px #0000002e}.panel{padding:18px}.compact{padding:14px}.panelTitle{display:flex;align-items:center;gap:8px;margin-bottom:14px;color:#f5f7fb;font-weight:800}.panelTitle small{margin-left:auto;color:#52b3a5}.seatList,.feed{display:grid;gap:10px}.profileAvatar{--profile-color: var(--phase);display:inline-grid;place-items:center;flex:0 0 auto;width:34px;height:34px;border:1px solid color-mix(in srgb,var(--profile-color) 62%,#3d4858);border-radius:50%;background:radial-gradient(circle at 32% 24%,rgba(255,255,255,.3),transparent 24px),color-mix(in srgb,var(--profile-color) 34%,#18202b);color:#f6f8fb;font-size:15px;font-weight:950;line-height:1;box-shadow:inset 0 0 0 1px #ffffff14,0 0 18px color-mix(in srgb,var(--profile-color) 20%,transparent)}.profileAvatar.small{width:28px;height:28px;font-size:13px}.profileAvatar.large{width:46px;height:46px;font-size:18px}.profileAvatar.humanFallback,.profileAvatar.aiFallback{color:var(--phase)}.seat{position:relative;display:grid;grid-template-columns:30px minmax(0,1fr) auto;align-items:center;gap:8px;min-height:38px;padding:8px;border:1px solid #2f3744;border-radius:8px;background:#171b23;overflow:hidden;transition:border-color .18s ease,transform .18s ease}.seat:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--phase);opacity:.7}.seat.dead{opacity:.55}.seatMeta{display:grid;gap:2px;min-width:0}.seatMeta strong,.seatMeta em{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seatMeta em{color:#f0bd61;font-size:11px;font-style:normal;font-weight:850}.seat small,.capLine span,.identityBand span{color:#9aa6b8}.notesPanel{gap:12px}.noteList{display:grid;gap:10px}.noteLine{grid-template-columns:72px minmax(0,1fr);align-items:center;gap:8px}.noteLine span{min-width:0;overflow:hidden;color:#d9e1ec;text-overflow:ellipsis;white-space:nowrap}.noteLine input{height:36px}.capLine{display:flex;justify-content:space-between;padding:8px 0;border-top:1px solid #2c3440}.toggleLine{display:flex;grid-template-columns:none;align-items:center;gap:10px;min-height:34px;color:#c5cedc}.toggleLine input{width:18px;height:18px;padding:0;accent-color:#52b3a5}.stage{min-width:0}.roleGrid{display:grid;grid-template-columns:repeat(3,minmax(120px,1fr));gap:14px}.lobbyPanel{display:grid;gap:16px}.simpleSetting{display:grid;gap:8px}.simpleSetting>span,.advancedConfig summary{color:#aeb8c8;font-size:13px;font-weight:850}.personaPackGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.personaPackButton{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;min-width:0;min-height:70px;padding:10px;text-align:left}.personaPackText{display:grid;gap:4px;min-width:0}.personaPackText strong,.personaPackText small{overflow:hidden;text-overflow:ellipsis}.personaPackText strong{color:#f5f7fb}.personaPackText small{color:#aeb8c8;font-size:12px;line-height:1.35}.personaAvatars{display:flex;flex-direction:row-reverse;padding-left:10px}.personaAvatars .profileAvatar{margin-left:-10px;border-color:#fff3}.lobbyPanel .presetRow{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin:0}.lobbyPanel .presetRow button{min-width:0}.advancedConfig{display:grid;gap:14px;padding-top:2px}.advancedConfig summary{cursor:pointer;list-style:none;min-height:38px;display:flex;align-items:center;justify-content:space-between;border:1px solid #303947;border-radius:8px;padding:0 12px;background:#171b23}.advancedConfig summary::-webkit-details-marker{display:none}.advancedConfig summary:after{content:"+";color:#52b3a5;font-size:18px;font-weight:900}.advancedConfig[open] summary:after{content:"-"}.advancedConfig[open] .roleGrid{margin-top:12px}.advancedConfig[open] .sliderGrid{margin-top:14px}.stepper input{text-align:center}.presetRow{flex-wrap:wrap;margin:18px 0}.sliderGrid{display:grid;grid-template-columns:repeat(2,minmax(160px,1fr));gap:16px}.sliderGrid label{color:#c5cedc}.sliderGrid b{color:#52b3a5}.boardPanel{display:grid;gap:16px}.phaseScene{position:relative;display:grid;grid-template-columns:176px minmax(0,1fr) auto;align-items:center;gap:18px;min-height:164px;padding:18px;border:1px solid color-mix(in srgb,var(--phase) 45%,#303947);border-radius:8px;background:linear-gradient(120deg,color-mix(in srgb,var(--phase) 18%,#151a21),#141820f5 58%),#151a21;box-shadow:inset 0 1px #ffffff0d;overflow:hidden}.phaseScene:after{content:"";position:absolute;inset:auto 0 0;height:3px;background:linear-gradient(90deg,transparent,var(--phase),var(--phase-strong),transparent);animation:phaseTrace 3.2s ease-in-out infinite}.sceneArt{position:relative;width:156px;height:126px;border:1px solid color-mix(in srgb,var(--phase) 28%,#303947);border-radius:8px;background:#111720;overflow:hidden}.sceneSky{position:absolute;inset:0;background:linear-gradient(155deg,color-mix(in srgb,var(--phase) 32%,transparent),transparent 44%),repeating-linear-gradient(115deg,rgba(255,255,255,.075) 0 1px,transparent 1px 18px);animation:sceneDrift 7s linear infinite}.sceneTableTop{position:absolute;left:34px;top:30px;display:grid;place-items:center;width:88px;height:66px;border:2px solid color-mix(in srgb,var(--phase) 70%,#eef2f8);border-radius:50%;background:linear-gradient(160deg,rgba(255,255,255,.06),transparent 45%),#1a222d;box-shadow:0 0 28px color-mix(in srgb,var(--phase) 26%,transparent),inset 0 0 18px #00000047;animation:tableBreath 2.8s ease-in-out infinite}.sceneTableTop span{display:grid;place-items:center;width:50px;height:50px;border-radius:50%;background:color-mix(in srgb,var(--phase) 18%,#121720);color:var(--phase-strong)}.sceneSeats i{position:absolute;width:13px;height:20px;border:1px solid color-mix(in srgb,var(--phase) 62%,#dbe3ee);border-radius:8px 8px 4px 4px;background:#dbe3ee;box-shadow:0 0 14px color-mix(in srgb,var(--phase) 36%,transparent);animation:seatFlicker 2.4s ease-in-out infinite}.sceneSeats i.fallen{opacity:.28;transform:rotate(68deg);animation:none}.sceneSeats i:nth-child(1){left:72px;top:9px}.sceneSeats i:nth-child(2){right:28px;top:24px;animation-delay:90ms}.sceneSeats i:nth-child(3){right:16px;top:62px;animation-delay:.18s}.sceneSeats i:nth-child(4){right:42px;bottom:10px;animation-delay:.27s}.sceneSeats i:nth-child(5){left:72px;bottom:4px;animation-delay:.36s}.sceneSeats i:nth-child(6){left:42px;bottom:10px;animation-delay:.45s}.sceneSeats i:nth-child(7){left:16px;top:62px;animation-delay:.54s}.sceneSeats i:nth-child(8){left:28px;top:24px;animation-delay:.63s}.sceneSeats i:nth-child(9){left:72px;top:53px;animation-delay:.72s}.sceneCopy{position:relative;display:grid;gap:6px;min-width:0}.sceneCopy span{color:var(--phase-strong);font-size:12px;font-weight:900;text-transform:uppercase}.sceneCopy h2{margin:0;color:#f5f7fb;font-size:28px;line-height:1.16}.sceneCopy p{margin:0;max-width:680px;color:#b7c3d3;line-height:1.55}.sceneMeter{position:relative;display:grid;place-items:center;gap:2px;width:74px;height:92px;border:1px solid color-mix(in srgb,var(--phase) 35%,#303947);border-radius:8px;background:#11161eb8;color:var(--phase-strong)}.sceneMeter b{color:#f5f7fb;font-size:24px;line-height:1}.sceneMeter small{color:#aeb8c8;max-width:100%;font-weight:800;letter-spacing:0;line-height:1;overflow:hidden;text-overflow:clip;white-space:nowrap}.phaseRail{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.phaseStep{position:relative;display:grid;gap:6px;min-width:0;padding:10px;border:1px solid #2f3744;border-radius:8px;background:#151a21;color:#8f9caf;overflow:hidden;transition:border-color .18s ease,color .18s ease,transform .18s ease}.phaseStep span{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:999px;background:#222a35;color:#b7c0cf;font-size:12px;font-weight:900}.phaseStep b{overflow:hidden;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.phaseStep.done{border-color:#2f665f;color:#b7e7df}.phaseStep.active{border-color:#f0bd61;background:color-mix(in srgb,var(--phase-strong) 11%,#151a21);color:#f8d790;transform:translateY(-2px)}.phaseStep.active span{background:#f0bd61;color:#171b23}.thinkingCard{display:grid;gap:10px;padding:12px 14px;border:1px solid #2f665f;border-radius:8px;background:#1f5c542e;animation:panelEnter .24s ease both}.thinkingLine{display:flex;justify-content:space-between;gap:12px;color:#dbeeea;font-weight:800}.thinkingLine b{color:#52b3a5}.thinkingNote,.phaseHint{margin:0;color:#aeb8c8;font-size:13px;line-height:1.5}.thinkingTrack{height:8px;overflow:hidden;border-radius:999px;background:#202832}.thinkingFill{height:100%;border-radius:inherit;background:#52b3a5;transition:width .22s ease}.thinkingFill.indeterminate{width:34%;animation:thinkingSlide 1.15s ease-in-out infinite}@keyframes thinkingSlide{0%{transform:translate(-110%)}to{transform:translate(320%)}}@keyframes buttonSheen{0%{opacity:0;transform:translate(-120%)}24%{opacity:1}to{opacity:0;transform:translate(120%)}}@keyframes entryMoonFloat{0%,to{translate:0 0}50%{translate:0 8px}}@keyframes entryCardFloat{0%,to{translate:0 0}50%{translate:0 -8px}}@keyframes phaseTrace{0%,to{opacity:.35;transform:translate(-22%)}50%{opacity:1;transform:translate(22%)}}@keyframes sceneDrift{0%{background-position:0 0,0 0}to{background-position:44px 0,64px 0}}@keyframes tableBreath{0%,to{box-shadow:0 0 22px color-mix(in srgb,var(--phase) 20%,transparent),inset 0 0 18px #00000047}50%{box-shadow:0 0 38px color-mix(in srgb,var(--phase) 36%,transparent),inset 0 0 18px #00000047}}@keyframes seatFlicker{0%,to{opacity:.74}50%{opacity:1}}@keyframes panelEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes roleDeal{0%{opacity:0;transform:rotateX(8deg) translateY(8px)}to{opacity:1;transform:rotateX(0) translateY(0)}}@keyframes roleFlash{0%{transform:translate(-120%)}to{transform:translate(120%)}}@keyframes seatArrive{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes targetLock{0%,to{opacity:.48;transform:scale(.96)}50%{opacity:1;transform:scale(1)}}@keyframes speakingPulse{0%,to{opacity:.72}50%{opacity:1}}@keyframes feedIn{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}@keyframes winnerRise{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.identityBand{position:relative;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;min-height:54px;padding:12px 14px;border:1px solid color-mix(in srgb,var(--phase) 34%,#3a4554);border-radius:8px;background:linear-gradient(100deg,color-mix(in srgb,var(--phase) 22%,#171b23),#171b23 58%),#171b23;overflow:hidden;animation:roleDeal .32s ease both}.identityBand:after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,transparent,rgba(255,255,255,.12),transparent);transform:translate(-120%);animation:roleFlash 1.1s ease .16s both}.identityBand strong{position:relative;font-size:24px;z-index:1}.identityBand b{position:relative;color:#f0bd61;z-index:1}.identityBand span{position:relative;z-index:1}.role-werewolf{border-color:#8b3f4d;background:linear-gradient(100deg,#70213085,#171b23 58%)}.role-seer,.role-guard{border-color:#44877d}.role-witch{border-color:#6e6bb3;background:linear-gradient(100deg,#453f826b,#171b23 58%)}.role-hunter{border-color:#9a7340;background:linear-gradient(100deg,#744d1f6b,#171b23 58%)}.roleBrief{display:flex;align-items:center;gap:10px;min-height:44px;padding:10px 12px;border:1px solid #2f665f;border-radius:8px;background:#1f5c5424;color:#cfe8e4;font-size:13px;font-weight:700;line-height:1.45}.roleBrief svg{flex:0 0 auto;color:#52b3a5}.privateBox{display:grid;gap:6px;padding:12px 14px;border:1px solid #355b67;border-radius:8px;background:#1c485238;animation:panelEnter .26s ease both}.privateBox strong{color:#89d0d8}.privateBox p{margin:0;color:#d5e4ea;line-height:1.5}.table{display:grid;grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:12px}.avatar{position:relative;display:grid;min-height:112px;padding:14px;border-color:#343d4b;background:linear-gradient(180deg,rgba(255,255,255,.035),transparent 42%),#171b23;color:#eef2f8;isolation:isolate;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease,transform .18s ease;animation:seatArrive .28s ease both}.avatar:nth-child(2){animation-delay:35ms}.avatar:nth-child(3){animation-delay:70ms}.avatar:nth-child(4){animation-delay:105ms}.avatar:nth-child(5){animation-delay:.14s}.avatar:nth-child(6){animation-delay:175ms}.avatar:nth-child(7){animation-delay:.21s}.avatar:nth-child(8){animation-delay:245ms}.avatar:nth-child(9){animation-delay:.28s}.avatar:nth-child(10){animation-delay:315ms}.avatar:nth-child(11){animation-delay:.35s}.avatar:nth-child(12){animation-delay:385ms}.avatar:before{content:"";position:absolute;inset:8px;border:1px solid transparent;border-radius:6px;pointer-events:none;z-index:-1}.avatar>.profileAvatar{display:inline-grid;place-items:center;justify-self:center;width:46px;height:46px}.avatar>.profileAvatar.humanFallback,.avatar>.profileAvatar.aiFallback{border-color:#3d4858;background:linear-gradient(145deg,rgba(255,255,255,.12),transparent 46%),#202734;color:var(--phase)}.avatar:not(:disabled):hover{border-color:color-mix(in srgb,var(--phase) 62%,#dbe3ee);transform:translateY(-3px)}.avatar.targeted{border-color:#52b3a5;background:linear-gradient(180deg,color-mix(in srgb,var(--phase) 22%,transparent),transparent 58%),#1a332f;box-shadow:0 0 0 1px color-mix(in srgb,var(--phase) 60%,transparent),0 16px 34px color-mix(in srgb,var(--phase) 20%,transparent);transform:translateY(-4px)}.avatar.targeted:before{border-color:color-mix(in srgb,var(--phase) 72%,#eef2f8);animation:targetLock 1.1s ease-in-out infinite}.avatar.speaking{border-color:#f0bd61;box-shadow:inset 0 0 0 1px #f0bd6180}.avatar.speaking:after{content:"正在发言";position:absolute;top:8px;right:8px;padding:3px 7px;border-radius:999px;background:#f0bd612e;color:#f8d790;font-size:11px;font-weight:900;animation:speakingPulse 1.2s ease-in-out infinite}.avatar:disabled{border-color:#2b333e;background:#151922}.avatar.speaking:disabled{border-color:#806333}.avatar.deadSeat .profileAvatar{color:#7f8b9b;filter:grayscale(1)}.avatar small{color:#a8b2c1}.skipNotice{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:0 12px;border:1px solid #313947;border-radius:8px;background:#171b23;color:#c9d3e2;font-weight:800}.actionChoices{display:flex;flex:1 1 220px;gap:8px}.actionChoices button{flex:1 1 0;min-width:0}.targetPreview{display:flex;align-items:center;gap:10px;min-height:48px;padding:0 14px;border:1px dashed #3d4858;border-radius:8px;background:#0f131abd;color:#aeb8c8;font-weight:800;transition:border-color .18s ease,background .18s ease,color .18s ease}.targetPreview svg{color:var(--phase)}.targetPreview.locked{border-style:solid;border-color:color-mix(in srgb,var(--phase) 70%,#dbe3ee);background:color-mix(in srgb,var(--phase) 15%,#111720);color:#eef2f8;animation:panelEnter .18s ease both}.chatPanel{min-height:0;padding:14px}.feed{position:relative;align-content:start;max-height:calc(100vh - 288px);overflow-x:hidden;overflow-y:auto;padding:2px 4px 2px 13px;scrollbar-color:color-mix(in srgb,var(--phase) 45%,#596170) rgba(15,19,26,.2);scrollbar-width:thin}.boardPanel,.sidebar,.chatPanel,.stage>.panel{scrollbar-color:color-mix(in srgb,var(--phase) 45%,#596170) rgba(15,19,26,.2);scrollbar-width:thin}.feed:before{content:"";position:absolute;inset:8px auto 8px 4px;width:1px;background:linear-gradient(180deg,transparent,color-mix(in srgb,var(--phase) 42%,#475365) 14%,color-mix(in srgb,var(--phase) 18%,#303947) 86%,transparent);pointer-events:none}.feed::-webkit-scrollbar,.boardPanel::-webkit-scrollbar,.sidebar::-webkit-scrollbar,.chatPanel::-webkit-scrollbar,.stage>.panel::-webkit-scrollbar{width:8px;height:8px}.feed::-webkit-scrollbar-track,.boardPanel::-webkit-scrollbar-track,.sidebar::-webkit-scrollbar-track,.chatPanel::-webkit-scrollbar-track,.stage>.panel::-webkit-scrollbar-track{border-radius:999px;background:#0f131a33}.feed::-webkit-scrollbar-thumb,.boardPanel::-webkit-scrollbar-thumb,.sidebar::-webkit-scrollbar-thumb,.chatPanel::-webkit-scrollbar-thumb,.stage>.panel::-webkit-scrollbar-thumb{border:2px solid rgba(15,19,26,.84);border-radius:999px;background:color-mix(in srgb,var(--phase) 48%,#5b6472);background-clip:padding-box}.event{position:relative;margin:0;padding:4px 8px 4px 10px;border:0;border-radius:8px;background:linear-gradient(90deg,rgba(82,179,165,.08),transparent 78%);color:#9fb0c4;font-size:13px;font-weight:750;line-height:1.5;animation:feedIn .22s ease both}.event:before{content:"";position:absolute;left:-12px;top:50%;width:7px;height:7px;border:1px solid color-mix(in srgb,var(--phase) 70%,#dbe3ee);border-radius:999px;background:#151a21;box-shadow:0 0 0 3px #11161ef2;transform:translateY(-50%)}.message{position:relative;padding:10px;border:1px solid #303947;border-radius:8px;background:#171b23;animation:feedIn .24s ease both}.message:before{content:"";position:absolute;left:-12px;top:18px;width:7px;height:7px;border-radius:999px;background:#f0bd61;box-shadow:0 0 0 3px #11161ef2,0 0 14px #f0bd6147}.messageHeader{display:flex;align-items:center;justify-content:space-between;gap:8px}.messageAuthor{display:inline-flex;align-items:center;min-width:0;gap:8px}.messageAuthor>span:last-child{display:grid;gap:2px;min-width:0}.messageAuthor strong{overflow:hidden;color:#f0bd61;text-overflow:ellipsis;white-space:nowrap}.messageAuthor em{overflow:hidden;color:#9fb0c4;font-size:11px;font-style:normal;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.messageHeader .messageBadge{flex:0 0 auto}.message.wolfMessage{border-color:#6b3641;background:#3d1820db}.message.wolfMessage:before{background:#d7657a;box-shadow:0 0 0 3px #11161ef2,0 0 14px #d7657a47}.messageBadge{padding:2px 6px;border:1px solid #c84f62;border-radius:999px;color:#f0a6b1;font-size:11px;font-weight:800}.message p{margin:6px 0 0;color:#dde4ef;line-height:1.55}.composer{display:grid;gap:10px;margin-top:12px}.wolfComposer{padding:12px;border:1px solid #6b3641;border-radius:8px;background:#3d18208f}.wolfHeader{display:grid;gap:4px}.wolfHeader strong{color:#f0a6b1}.wolfHeader span{color:#c8a0a8;font-size:13px;line-height:1.45}.composerActions{justify-content:flex-end}.status{margin:0;color:#f0bd61;line-height:1.5}.voiceHint{margin:10px 0 0;color:#aeb8c8;font-size:13px;line-height:1.45}.winner{padding:16px;border:1px solid #f0bd61;border-radius:8px;background:#f0bd611a;color:#f8d790;font-size:22px;font-weight:900;text-align:center;animation:winnerRise .52s ease both}.reviewPanel{display:grid;gap:12px;padding:16px;border:1px solid #4d5969;border-radius:8px;background:#171b23}.reviewPanel h2{margin:0;font-size:20px}.reviewSection{display:grid;gap:6px;padding-top:10px;border-top:1px solid #2d3441}.reviewSection strong{color:#f0bd61}.reviewSection p{margin:0;color:#d9e1ec;line-height:1.55}@media(max-width:1120px){.mainGrid{grid-template-columns:240px minmax(0,1fr)}.chatPanel{grid-column:1 / -1}.feed{max-height:360px}}@media(max-width:760px){.entryActions,.joinLine{align-items:stretch;flex-direction:column}.entry{min-height:100dvh;padding:16px}.entryPanel{min-height:calc(100dvh - 32px);grid-template-columns:1fr;align-content:space-between;gap:18px}.entryCopy{gap:12px;max-width:100%;padding:18px 0 0}.entryCopy .lead{max-width:320px;font-size:15px;line-height:1.55}.entryBadges{gap:8px}.entryBadges span{min-height:30px;padding:0 10px;font-size:12px}.entryControls{gap:12px;padding:14px}.entry .entryActions,.entry .entryJoin{display:grid}.entry .entryJoin{grid-template-columns:minmax(0,1fr) 82px}.entryMoon{top:24px;right:22px;width:58px;height:58px}.entryTable{left:50%;top:49%;width:360px;height:360px;opacity:.72}.entryTableTop{inset:78px;gap:8px}.entryRoleCard{width:50px;height:72px;font-size:20px}.entrySeat{width:23px;height:35px;border-radius:10px 10px 5px 5px}.entrySeat:after{left:6px;right:6px;top:6px;height:7px}.appShell{height:100dvh;grid-template-rows:auto minmax(0,1fr) auto;overflow:hidden}.appShell.phase-lobby{grid-template-rows:auto minmax(0,1fr)}.topbar{display:grid;grid-template-columns:minmax(0,1fr);align-items:center;gap:8px 12px;padding:12px 14px 10px}.topTitle{min-width:0}.topbar h1{overflow:hidden;font-size:21px;line-height:1.12;text-overflow:ellipsis;white-space:nowrap}.topbar .eyebrow{margin-bottom:4px}.topHeaderControls{display:contents}.topActions{grid-column:1 / -1;grid-row:2;display:flex;align-items:center;flex-direction:row;flex-wrap:wrap;gap:8px;justify-content:flex-start;overflow:visible;padding:0}.roomStats{grid-column:1 / -1;grid-row:3;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;justify-content:stretch}.topActions>button,.roomStats span{min-height:34px;padding:0 10px;font-size:12px;white-space:nowrap}.topActions>button{flex:0 0 auto}.roomStats span{justify-content:center;min-width:0}.phase-lobby .roomStats{grid-template-columns:repeat(2,minmax(0,1fr))}.phase-lobby .roomStats span{gap:4px;padding:0 6px;font-size:12px}.phase-lobby .roomStats span:nth-child(2){display:none}.phase-lobby .topbar{gap:8px;padding:10px 12px}.phase-lobby .topbar h1{display:none}.phase-lobby .topbar .eyebrow{margin:0;color:#eef2f8;font-size:15px;text-transform:none}.phase-lobby .topActions>button{min-height:36px}.topActions>.inviteButton{display:none}.takeoverButton{max-width:116px}.phaseScene{grid-template-columns:58px minmax(0,1fr) 54px;gap:8px;min-height:70px;padding:8px}.sceneArt{width:58px;height:54px}.sceneMeter{align-content:center;gap:1px;width:54px;height:54px;padding:6px 4px}.sceneMeter svg{display:none}.sceneMeter b{font-size:22px}.sceneMeter small{font-size:12px}.sceneTableTop{left:15px;top:15px;width:30px;height:24px}.sceneTableTop span{width:23px;height:23px}.sceneTableTop svg{width:18px;height:18px}.sceneSeats i{width:7px;height:10px}.sceneSeats i:nth-child(1){left:28px;top:7px}.sceneSeats i:nth-child(2){right:10px;top:12px}.sceneSeats i:nth-child(3){right:6px;top:27px}.sceneSeats i:nth-child(4){right:16px;bottom:6px}.sceneSeats i:nth-child(5){left:27px;bottom:5px}.sceneSeats i:nth-child(6){left:16px;bottom:6px}.sceneSeats i:nth-child(7){left:6px;top:27px}.sceneSeats i:nth-child(8){left:10px;top:12px}.sceneSeats i:nth-child(9){left:27px;top:24px}.sceneCopy{align-content:center}.sceneCopy span{font-size:11px}.sceneCopy h2{display:-webkit-box;overflow:hidden;font-size:17px;line-height:1.18;-webkit-box-orient:vertical;-webkit-line-clamp:2}.sceneCopy p{display:none}.mainGrid{min-height:0;height:100%;grid-template-columns:1fr;padding:8px;overflow:hidden}.phase-lobby .mainGrid{padding:8px 10px 10px}.stage,.sidebar,.chatPanel{display:none;min-height:0;height:100%;overflow:hidden}.stage{align-content:start;align-items:start}.mobile-board .stage,.mobile-chat .chatPanel,.mobile-players .sidebar{display:grid}.stage{min-width:0}.stage>.panel{min-height:0;max-height:100%;overflow:auto;padding:12px;-webkit-overflow-scrolling:touch}.boardPanel,.sidebar,.chatPanel{overflow:auto;padding:10px;-webkit-overflow-scrolling:touch}.boardPanel{align-self:start;align-content:start;gap:8px;max-height:100%;padding-bottom:10px}.chatPanel{grid-template-rows:auto minmax(0,1fr) auto auto;overflow:hidden}.chatPanel .feed{max-height:none;min-height:0}.composer{margin-top:10px}.composer textarea{min-height:76px}.wolfComposer{padding:10px}.personaPackGrid{gap:8px;margin-bottom:10px}.lobbyPanel{gap:12px}.lobbyPanel .personaPackGrid{margin-bottom:0}.personaPackButton{grid-template-columns:minmax(0,1fr);min-height:54px;padding:8px}.personaPackText small{display:none}.personaAvatars{justify-content:flex-end}.roleGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.stepper{gap:6px;font-size:12px}.stepper input{height:36px;padding:0 8px;font-size:15px}.presetRow{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin:10px 0}.presetRow button{min-width:0;min-height:36px;padding:0 8px}.phase-lobby .mobileNav{display:none}.sliderGrid{grid-template-columns:1fr;gap:10px}.sliderGrid label{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:5px}.sliderGrid label input{flex:0 0 100%;height:28px;padding:0}.phaseRail{grid-template-columns:repeat(5,minmax(0,1fr));gap:4px}.phaseStep{display:flex;align-items:center;justify-content:center;gap:4px;min-height:34px;padding:5px}.phaseStep span{width:17px;height:17px;font-size:10px}.phaseStep b{font-size:11px}.thinkingCard,.privateBox,.roleBrief,.identityBand{padding:7px 9px}.boardPanel>.panelTitle{display:none}.thinkingCard{gap:6px}.thinkingTrack{height:6px}.thinkingNote{display:none}.identityBand{grid-template-columns:auto 1fr auto;min-height:38px}.identityBand strong{font-size:19px}.roleBrief{display:none}.privateBox{gap:3px}.privateBox strong{font-size:13px}.privateBox p,.phaseHint{font-size:12px;line-height:1.35}.table{order:13;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.avatar{min-height:48px;padding:5px;gap:3px}.avatar span{width:22px;height:22px}.avatar span svg{width:14px;height:14px}.avatar strong{overflow:hidden;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.avatar small{font-size:11px}.avatar.speaking:after{top:4px;right:4px;padding:2px 5px;font-size:10px}.targetPreview{order:11;min-height:40px;padding:0 10px;font-size:13px}.actionLine{order:12;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;z-index:3;padding-top:0;background:none}.actionLine select{min-width:0}.actionLine button{min-width:88px}.actionChoices{grid-column:1 / -1;flex-direction:row;overflow-x:auto;scrollbar-width:none}.actionChoices::-webkit-scrollbar{display:none}.actionChoices button{flex:0 0 auto;min-width:92px}.seatList{grid-template-columns:1fr}.mobileNav{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:8px 12px calc(8px + env(safe-area-inset-bottom));border-top:1px solid color-mix(in srgb,var(--phase) 28%,#2a313d);background:#11141af5;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.mobileNav button{min-height:44px;border-color:#303947;background:#171b23;color:#aeb8c8}.mobileNav button.active{border-color:color-mix(in srgb,var(--phase) 68%,#eef2f8);background:color-mix(in srgb,var(--phase) 18%,#171b23);color:#eef2f8}.entryPanel h1{font-size:42px;line-height:1.05}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:1ms!important}}
