/* AgentVerse — page layout (theme tokens in theme.css) */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body,#app{min-height:100vh;min-height:100dvh}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Microsoft YaHei',sans-serif;
}

.page{min-height:100vh;padding:20px 16px;max-width:1280px;margin:0 auto;padding-bottom:calc(20px + var(--safe-bottom))}
.card-panel{
  background:var(--bg-panel);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid var(--border-gold);
  border-radius:var(--radius-lg);
  padding:20px 16px;
  box-shadow:var(--shadow-panel), var(--shadow-glow);
}

/* ---- Login / Lobby ---- */
.login-wrap{
  min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;
  padding:24px 16px;
}
.login-card{
  width:100%;max-width:420px;
  backdrop-filter:blur(20px);
  box-shadow:0 16px 48px rgba(0,0,0,.5), 0 0 40px rgba(124,106,247,.12);
}.brand{text-align:center;margin-bottom:28px}
.brand .moon{font-size:52px;filter:drop-shadow(0 0 12px rgba(167,139,250,.5))}
.brand h1{
  font-size:28px;font-weight:800;letter-spacing:.05em;
  background:linear-gradient(135deg,var(--accent-gold),var(--accent-purple));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.brand p{color:var(--text-muted);margin-top:8px;font-size:14px}
.header-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px}
.header-bar h2{text-shadow:0 0 20px rgba(167,139,250,.3)}
.header-bar h2,.card-panel h3{color:var(--text-primary)}
.card-panel h3{letter-spacing:.03em}
.panels-2{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:720px){.panels-2{grid-template-columns:1fr 1fr}}
.layout-room{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:720px){.layout-room{grid-template-columns:1fr 300px}}
.seat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.seat{
  border:1px dashed var(--border-gold);border-radius:var(--radius-md);padding:14px 10px;text-align:center;
  background:rgba(0,0,0,.3);backdrop-filter:blur(8px);
  transition:border-color .2s, box-shadow .2s;
}
.seat.filled{border-style:solid;border-color:var(--border-glow);background:rgba(124,106,247,.12);box-shadow:0 0 12px rgba(124,106,247,.1)}
.seat.isMe{border-color:#2ecc71;box-shadow:0 0 12px rgba(46,204,113,.2)}
.seat-num{font-size:20px;font-weight:800;color:var(--accent-purple)}
.seat-name{font-size:12px;margin:4px 0;color:#ccc}
.agent-item{
  display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;
  background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.06);margin-bottom:8px;
}
.agent-item-main{
  flex:1;display:flex;align-items:center;gap:8px;cursor:pointer;min-width:0;padding:2px 0;
}
.agent-item-main:hover .agent-name{color:var(--accent-purple)}
.agent-item:hover{border-color:var(--border-glow);background:rgba(124,106,247,.12)}
.agent-name{flex:1;font-weight:600;transition:color .15s}
.agent-add-icon{font-size:18px;color:var(--accent-gold);font-weight:700}

.agent-profile-overlay{
  position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;
  padding:20px;background:rgba(5,3,12,.82);backdrop-filter:blur(6px);
}
.agent-profile-card{
  position:relative;width:min(340px,92vw);padding:24px 20px 28px;border-radius:16px;text-align:center;
  background:linear-gradient(165deg,#1a1230 0%,#0d0818 100%);
  border:1px solid rgba(167,139,250,.35);box-shadow:0 0 40px rgba(124,106,247,.25);
}
.agent-profile-close{
  position:absolute;top:10px;right:12px;width:32px;height:32px;border:none;border-radius:8px;
  background:rgba(255,255,255,.08);color:#ccc;font-size:22px;line-height:1;cursor:pointer;
}
.agent-profile-close:hover{background:rgba(255,255,255,.15);color:#fff}
.agent-profile-photo{
  width:160px;height:160px;margin:0 auto 16px;border-radius:14px;overflow:hidden;
  border:2px solid rgba(245,158,11,.45);box-shadow:0 8px 24px rgba(0,0,0,.45);
}
.agent-profile-photo img{width:100%;height:100%;object-fit:cover;display:block}
.agent-profile-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-size:64px;background:linear-gradient(135deg,rgba(124,106,247,.25),rgba(245,158,11,.15));
}
.agent-profile-name{margin:0 0 10px;font-size:22px;color:#fff;letter-spacing:.04em}
.agent-profile-bio{
  margin:16px 0 0;font-size:14px;line-height:1.7;color:#ccc;text-align:left;
  padding:12px 14px;border-radius:10px;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.06);
}
.human-profile-stats{
  margin-top:16px;text-align:left;width:100%;font-size:14px;line-height:1.8;color:#ccc;
  padding:12px 14px;border-radius:10px;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.06);
}
.profile-seat-tag{
  margin-top:14px;font-size:12px;color:var(--accent-gold);letter-spacing:.08em;
}

.settings-page .settings-panel{max-width:480px;margin:0 auto}
.settings-avatar-block{text-align:center;margin-bottom:24px}
.settings-avatar-preview{
  width:120px;height:120px;margin:0 auto 16px;border-radius:50%;overflow:hidden;
  border:2px solid rgba(167,139,250,.4);background:rgba(0,0,0,.3);
  display:flex;align-items:center;justify-content:center;
}
.settings-avatar-preview img{width:100%;height:100%;object-fit:cover}
.settings-avatar-empty{font-size:48px;opacity:.6}
.settings-avatar-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.settings-hint{font-size:12px;color:#888;margin-top:12px;line-height:1.5}
.my-game-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.06);gap:12px;flex-wrap:wrap}
.my-game-item:last-child{border-bottom:none}
.role-config-box{padding:12px;border-radius:10px;background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.08)}
.role-config-grid{display:flex;flex-wrap:wrap;gap:8px}
.role-config-item{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:8px;background:rgba(0,0,0,.3);font-size:13px}
.rc-emoji{font-size:18px}
.invite-copy{cursor:pointer;user-select:none}
.seat .kick-btn{margin-top:4px;padding:0 4px;font-size:12px}
.hint{font-size:13px;color:var(--text-muted);margin-bottom:10px}
.section-title{font-size:12px;color:var(--accent-gold);margin-bottom:12px;letter-spacing:.08em;text-transform:uppercase}

/* ===== GAME PAGE (mobile-first table) ===== */
.game-page{
  display:flex;flex-direction:column;
  height:100vh;height:100dvh;
  max-width:100vw;overflow:hidden;
  background:transparent;
}
.game-page.phase-NIGHT{
  background:linear-gradient(180deg, rgba(5,5,8,.75) 0%, rgba(10,8,18,.88) 100%);
}
.game-page.phase-NIGHT::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse 80% 60% at 50% 0%, rgba(20,15,50,.45), transparent 70%);
}
.game-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}

/* Top bar */
.game-top{
  flex-shrink:0;display:flex;align-items:center;justify-content:space-between;
  padding:8px 10px;padding-top:max(8px, env(safe-area-inset-top));
  background:linear-gradient(180deg, rgba(10,8,18,.98), rgba(10,8,18,.85));
  border-bottom:1px solid var(--border-gold);
  z-index:10;
}
.game-top.dimmed{opacity:.4}
.game-top-btn{
  background:rgba(18,14,32,.75);border:1px solid rgba(212,175,90,.25);
  color:var(--text-muted);font-size:12px;padding:6px 10px;border-radius:var(--radius-sm);cursor:pointer;
  transition:all .2s;
}
.game-top-btn:hover{
  border-color:var(--border-glow);color:var(--accent-gold);
  box-shadow:0 0 12px rgba(124,106,247,.2);
}
.game-top-btn.accent{color:var(--accent-gold);border-color:var(--border-gold)}
.game-top-center{flex:1;text-align:center;padding:0 8px}
.game-phase-badge{
  font-size:15px;font-weight:700;color:#fff;
  text-shadow:0 0 16px rgba(167,139,250,.6);
}
.game-day-line{font-size:11px;color:var(--accent-gold);margin-top:2px;letter-spacing:.1em}
.game-progress-mini{display:flex;justify-content:center;gap:6px;margin-top:6px}
.mini-step{font-size:14px;opacity:.35;filter:grayscale(.8);transition:.2s}
.mini-step.active{opacity:1;filter:none;transform:scale(1.15)}
.mini-step.done{opacity:.65}
.game-top-role .role-chip{
  display:inline-block;font-size:13px;padding:4px 8px;border-radius:8px;
  border:1px solid rgba(255,255,255,.15);background:rgba(0,0,0,.4);
}
.role-chip.chip-werewolf{border-color:rgba(231,76,60,.5);color:#f5a5a0}
.game-top-spacer{width:44px}

.game-vote-banner{
  flex-shrink:0;display:flex;flex-wrap:wrap;gap:6px;padding:6px 10px;
  background:rgba(231,76,60,.08);border-bottom:1px solid rgba(231,76,60,.2);
  overflow-x:auto;
}
.vote-chip{font-size:11px;padding:3px 8px;border-radius:6px;background:rgba(0,0,0,.35);white-space:nowrap}
.vote-chip.highlight{color:#f5a5a0;border:1px solid rgba(231,76,60,.4)}

/* Arena: sides + center */
.game-arena{
  flex:1;min-height:0;display:flex;align-items:stretch;gap:4px;
  padding:6px 4px;position:relative;
}
.game-arena.frozen{pointer-events:none;opacity:.45;filter:grayscale(.15)}
.game-arena::before{
  content:'';position:absolute;inset:10% 22%;border-radius:50%;
  border:1px dashed rgba(212,175,90,.12);pointer-events:none;z-index:0;
}

.game-side{
  flex:0 0 68px;display:flex;flex-direction:column;justify-content:space-evenly;
  gap:6px;z-index:1;overflow-y:auto;max-height:100%;
}
@media(min-width:480px){.game-side{flex:0 0 80px}}

.seat-token{
  position:relative;display:flex;flex-direction:column;align-items:center;
  padding:6px 4px;border-radius:12px;cursor:pointer;
  border:2px solid transparent;background:rgba(0,0,0,.35);
  transition:transform .15s, border-color .15s, box-shadow .15s;
}
.seat-token:active{transform:scale(.96)}
.seat-token.me{border-color:rgba(46,204,113,.55);box-shadow:0 0 10px rgba(46,204,113,.2)}
.seat-token.selected{border-color:var(--accent-red);box-shadow:0 0 12px rgba(231,76,60,.35);background:rgba(231,76,60,.12)}
.seat-token.speaking{border-color:#f39c12;animation:pulse-speak 1.2s infinite}
.seat-token.dead{opacity:.45;filter:grayscale(.7)}
.token-avatar{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(145deg,#3d2a6e,#1a1230);
  border:2px solid var(--border-glow);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:15px;color:#fff;
  box-shadow:0 2px 8px rgba(0,0,0,.4);
}
.seat-token.dead .token-avatar{border-color:#555;background:#222}
.token-face{display:flex;flex-direction:column;align-items:center;cursor:pointer}
.token-face:active{transform:scale(.96)}
.token-avatar-img{
  width:44px;height:44px;border-radius:50%;object-fit:cover;display:block;
  border:2px solid var(--border-glow);box-shadow:0 2px 8px rgba(0,0,0,.4);
}
.token-avatar-fallback{font-size:18px}
.token-seat-num{
  font-weight:800;font-size:11px;color:var(--accent-gold);margin-top:4px;line-height:1;
  text-shadow:0 1px 4px rgba(0,0,0,.6);
}
.seat-token.dead .token-avatar-img{filter:grayscale(.8);opacity:.7}
.token-name{font-size:10px;color:#aaa;margin-top:4px;text-align:center;line-height:1.2;max-width:100%;overflow:hidden}
.token-badge{
  position:absolute;top:2px;right:2px;font-size:8px;padding:1px 4px;border-radius:4px;
  line-height:1.2;
}
.token-badge.ai{background:rgba(52,152,219,.5)}
.token-badge.wolf{background:rgba(231,76,60,.6)}
.token-dead-mark{position:absolute;top:-2px;left:-2px;font-size:12px}
.token-speaking{position:absolute;bottom:-2px;right:-2px;font-size:11px}

.game-center{
  flex:1;min-width:0;display:flex;flex-direction:column;gap:4px;z-index:1;
}
.center-panel{
  flex:1;min-height:0;display:flex;flex-direction:column;
  background:var(--bg-panel);
  backdrop-filter:blur(12px);
  border:1px solid var(--border-gold);
  border-radius:var(--radius-md);overflow:hidden;
  box-shadow:var(--shadow-panel), inset 0 0 30px rgba(0,0,0,.25);
}
.center-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.08)}
.center-tabs button{
  flex:1;padding:8px 4px;font-size:12px;background:transparent;border:none;
  color:var(--text-muted);cursor:pointer;
}
.center-tabs button.active{
  color:var(--accent-gold);background:rgba(212,175,90,.08);
  box-shadow:inset 0 -2px 0 var(--accent-gold);
}
.center-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px}
.center-empty{text-align:center;color:var(--text-muted);padding:24px 8px;font-size:13px}

.speech-bubble{
  margin-bottom:8px;padding:8px 10px;border-radius:10px;
  background:rgba(255,255,255,.04);border-left:3px solid var(--accent-purple);
}
.speech-bubble.mine{border-left-color:#2ecc71;background:rgba(46,204,113,.06)}
.speech-bubble.system-vote{border-left-color:#e74c3c;background:rgba(231,76,60,.08)}
.speech-bubble.system-night{border-left-color:#3498db;background:rgba(52,152,219,.08)}
.speech-bubble.system-vote .bubble-head,.speech-bubble.system-night .bubble-head{color:var(--accent-gold)}
.bubble-body.timeline-body{white-space:pre-line;font-size:12px;line-height:1.6}
.bubble-head{display:flex;justify-content:space-between;font-size:11px;color:var(--accent-purple);margin-bottom:4px;font-weight:700}
.bubble-day{color:var(--text-muted);font-weight:400}
.bubble-body{font-size:13px;line-height:1.5;color:#ddd;word-break:break-word}

.event-line{font-size:11px;padding:5px 6px;margin-bottom:4px;border-radius:6px;background:rgba(0,0,0,.25);line-height:1.4}
.event-time{color:var(--text-muted);margin-right:4px;font-size:10px}

.seer-strip{
  flex-shrink:0;display:flex;flex-wrap:wrap;gap:4px;padding:4px 6px;
  font-size:10px;color:var(--accent-purple);
  background:rgba(124,106,247,.1);border-radius:8px;border:1px solid rgba(124,106,247,.25);
}

/* Bottom dock */
.game-dock{
  flex-shrink:0;max-height:42vh;overflow-y:auto;
  padding:10px 12px;padding-bottom:calc(10px + var(--safe-bottom));
  background:linear-gradient(0deg, rgba(8,6,14,.98), rgba(12,10,20,.95));
  border-top:1px solid var(--border-gold);
  box-shadow:0 -8px 32px rgba(0,0,0,.5);
  z-index:20;
}
.game-dock.frozen{pointer-events:none;opacity:.5}
.dock-target{
  text-align:center;font-size:12px;color:var(--accent-gold);margin-bottom:8px;
  padding:4px 8px;background:rgba(212,175,90,.1);border-radius:6px;
}
.dock-title{font-size:13px;font-weight:600;color:#fff;margin-bottom:8px;text-align:center}
.dock-hint{font-size:12px;color:var(--text-muted);margin-bottom:8px;text-align:center;line-height:1.4}
.dock-hint.wolf{color:#f5a5a0}
.dock-hint.danger{color:#f5a5a0;background:rgba(231,76,60,.1);padding:6px;border-radius:6px}
.dock-btns{display:flex;gap:8px;justify-content:center;margin-top:8px}
.dock-btns.wrap{flex-wrap:wrap}
.dock-btns .el-button{flex:1;min-width:0}
.dock-wait{text-align:center;font-size:13px;color:var(--text-muted);padding:8px}
.dock-wait-bar{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 8px;font-size:13px;color:var(--text-muted);
}
.dock-wait-icon{font-size:20px}
.spectator-dock{
  display:flex;align-items:center;gap:14px;padding:12px 8px;
  background:rgba(99,102,241,.12);border:1px solid rgba(99,102,241,.25);border-radius:10px;
}
.spectator-dock-icon{font-size:28px}
.spectator-hint{
  font-size:13px;color:#a5b4fc;background:rgba(99,102,241,.12);
  border:1px solid rgba(99,102,241,.25);border-radius:8px;padding:10px 12px;margin-bottom:14px;
}
.stand-spectate-bar{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:16px;padding-top:14px;
  border-top:1px solid rgba(255,255,255,.08);
}
.stand-spectate-tip{font-size:12px;color:#888}
.spectator-bench{
  margin-top:18px;padding:14px;border-radius:10px;
  background:linear-gradient(135deg,rgba(30,20,50,.55),rgba(15,10,28,.65));
  border:1px solid rgba(124,106,247,.25);
  box-shadow:0 0 16px rgba(124,106,247,.12);
}
.spectator-empty{font-size:13px;color:#666;padding:8px 0}
.spectator-list{display:flex;flex-wrap:wrap;gap:8px}
.spectator-chip{
  display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;
  background:rgba(99,102,241,.15);border:1px solid rgba(99,102,241,.3);font-size:13px;color:#c4b5fd;
}
.spectator-chip.isMe{border-color:#a78bfa;background:rgba(167,139,250,.2);color:#e9d5ff}
.spectator-icon{font-size:14px}
.dock-input .el-textarea__inner{
  background:rgba(0,0,0,.35)!important;border-color:rgba(255,255,255,.12)!important;color:#eee!important;
}

/* Overlays */
.role-dealing-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9998;padding:16px}
.role-dealing-card{width:min(300px,88vw);padding:28px 20px;border-radius:18px;text-align:center;background:linear-gradient(145deg,#1e1838,#0d0b14);border:2px solid var(--border-gold);box-shadow:0 16px 48px rgba(0,0,0,.6);animation:floatCard .6s ease}
.role-dealing-icon{font-size:48px;margin-bottom:12px;animation:pulse-speak 1.5s infinite}
.role-dealing-card h3{font-size:18px;margin:0 0 8px;color:#fff}
.role-dealing-card p{font-size:13px;color:#aaa;margin:0}
.role-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .3s;padding:16px}
.win-rate-chip{display:inline-block;margin-left:10px;font-size:12px;padding:3px 10px;border-radius:999px;background:rgba(212,175,90,.12);border:1px solid rgba(212,175,90,.35);color:var(--accent-gold)}
.win-rate-chip.muted{color:#888;border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.04)}
.role-card-float{position:relative;width:min(280px,90vw);padding:32px 24px;border-radius:20px;text-align:center;animation:floatCard .6s ease;cursor:pointer;border:2px solid rgba(255,255,255,.2);box-shadow:0 20px 60px rgba(0,0,0,.6)}
.role-card-float.role-werewolf{background:linear-gradient(145deg,#3d1515,#1a0a0a);border-color:#e74c3c}
.role-card-float.role-seer{background:linear-gradient(145deg,#1a2a4a,#0d1520);border-color:#3498db}
.role-card-float.role-witch{background:linear-gradient(145deg,#2a1a4a,#150d20);border-color:#9b59b6}
.role-card-float.role-hunter{background:linear-gradient(145deg,#1a3a2a,#0d2015);border-color:#2ecc71}
.role-card-float.role-villager{background:linear-gradient(145deg,#2a2a3a,#151520);border-color:#95a5a6}
.role-card-shine{
  position:absolute;inset:0;border-radius:18px;pointer-events:none;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.08) 50%,transparent 60%);
  animation:shine 3s infinite;
}
@keyframes shine{0%,100%{opacity:0;transform:translateX(-100%)}50%{opacity:1;transform:translateX(100%)}}
.role-card-emoji{font-size:56px;margin-bottom:12px}
.role-card-title{font-size:12px;color:var(--text-muted);letter-spacing:.15em;margin-bottom:8px}
.role-card-name{font-size:24px;font-weight:700;margin-bottom:8px}
.role-card-seat{font-size:15px;color:var(--accent-purple);margin-bottom:12px}
.role-card-hint{font-size:11px;color:#666}

.phase-notice-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;padding:16px;z-index:9997;
}
.phase-notice-card{
  width:min(360px,92vw);padding:20px;border-radius:16px;text-align:center;
  background:linear-gradient(145deg,#1e1838,#0d0b14);
  border:1px solid var(--border-gold);box-shadow:0 16px 48px rgba(0,0,0,.6);
}
.phase-notice-icon{font-size:36px;margin-bottom:8px}
.phase-notice-card h3{font-size:17px;margin:0 0 8px}
.phase-notice-card p{font-size:14px;color:#aaa;margin:0 0 8px;line-height:1.5}
.phase-notice-dismiss{font-size:11px;color:#666;margin-top:12px!important}
.notice-detail-list{margin:10px 0;text-align:left;max-height:180px;overflow-y:auto}
.notice-detail-line{font-size:13px;padding:6px 8px;border-radius:6px;background:rgba(255,255,255,.05);margin-bottom:4px}
.notice-result{margin-top:10px;padding:8px 12px;border-radius:8px;background:rgba(167,139,250,.12);font-size:13px}
.seer-check-result{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:16px 12px;font-size:15px;
}
.seer-check-result.seer-wolf{background:rgba(231,76,60,.15);border:1px solid rgba(231,76,60,.35)}
.seer-check-result.seer-good{background:rgba(46,204,113,.12);border:1px solid rgba(46,204,113,.35)}
.seer-check-target{font-size:22px;font-weight:800;color:#fff}
.seer-check-label{font-size:18px;font-weight:700}
.seer-check-result.seer-wolf .seer-check-label{color:#f5a5a0}
.seer-check-result.seer-good .seer-check-label{color:#7dcea0}

.game-over-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9998;padding:16px}
.game-over-modal{width:min(440px,94vw);max-height:85vh;overflow-y:auto;padding:28px 20px;border-radius:18px;text-align:center;background:linear-gradient(145deg,#1a1530,#0a0812);border:2px solid var(--border-gold)}
.game-over-emoji{font-size:48px;margin-bottom:8px}
.game-over-modal h2{font-size:22px;margin-bottom:16px}
.game-over-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:12px}
.final-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:16px 0}
.final-item{padding:10px;background:rgba(0,0,0,.3);border-radius:8px;font-size:13px}

.wolf-coord-box{padding:10px;margin-bottom:10px;background:rgba(231,76,60,.08);border-radius:8px;border:1px solid rgba(231,76,60,.2)}
.witch-kill-info{padding:8px 10px;border-radius:8px;background:rgba(231,76,60,.12);color:#f5a5a0;font-size:13px;margin-bottom:6px}

/* Legacy (admin / desktop lists) */
.game-layout{display:grid;grid-template-columns:260px 1fr 200px;gap:16px}
.player-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid transparent;cursor:pointer;margin-bottom:8px}
.p-seat{width:32px;height:32px;border-radius:50%;background:rgba(124,106,247,.3);display:flex;align-items:center;justify-content:center;font-weight:700}
.speech-list{scroll-behavior:smooth}
.event-list{max-height:480px;overflow-y:auto}
.event-item{font-size:12px;padding:6px 8px;margin-bottom:4px;background:rgba(255,255,255,.03);border-radius:6px}
.game-progress{display:flex;align-items:center;gap:16px;margin-bottom:16px;padding:16px 20px}
.progress-day{font-size:13px;color:var(--accent-purple);font-weight:700}
.progress-steps{display:flex;flex:1;gap:8px;flex-wrap:wrap}
.progress-step{flex:1;min-width:70px;padding:8px;border-radius:10px;background:rgba(255,255,255,.04);text-align:center;opacity:.5}
.progress-step.active{border-color:var(--accent-purple);opacity:1}
.step-icon{font-size:16px;display:block}
.step-label{font-size:11px;color:#ccc}
.vote-panel{margin-bottom:16px}
.vote-line{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:14px}
.vote-from{color:var(--accent-purple);font-weight:600}
.vote-to{color:var(--accent-red);font-weight:600}

@keyframes floatCard{from{transform:translateY(24px) scale(.92);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse-speak{0%,100%{box-shadow:0 0 0 0 rgba(243,156,18,.4)}50%{box-shadow:0 0 12px 2px rgba(243,156,18,.25)}}

@media(min-width:960px){
  .game-side{flex:0 0 96px}
  .game-dock{max-height:36vh}
  .panels-2{grid-template-columns:1fr 1fr}
}
