:root{--topbar-bg:#202020;--panel-bg:#202020;--bg0:#2d2d2d;--text:#eeeeee;--muted:#cccccc;--system:#88aaaa;--yellow:#f2c94c;--green:#3ddc97;--cyan:#4bc4ec;--border: rgba(255,255,255,.08);--shadow: rgba(0,0,0,.5);--font: "Varela Round", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;--bomb-size: 138px;--bomb-syllable-font: 24px}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:var(--font);color:var(--text);background:radial-gradient(1200px 800px at 50% 35%,#3a332d,#2d2d2d 60%);overflow:hidden}a{color:inherit;text-decoration:none}button,input{font-family:inherit}*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.22) rgba(0,0,0,.22)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:#00000038;border-left:1px solid rgba(255,255,255,.06)}*::-webkit-scrollbar-thumb{background:#ffffff2e;border:1px solid rgba(255,255,255,.08);border-radius:999px}*::-webkit-scrollbar-thumb:hover{background:#ffffff3d}.app{height:100vh;min-height:0;display:flex;flex-direction:column;overflow:hidden}.topbar{height:48px;display:flex;align-items:center;padding:0 12px;background:var(--topbar-bg);border-bottom:1px solid var(--border);gap:12px}.topbar .roomcode{font-weight:800;letter-spacing:.08em}.topbar .title{opacity:.95;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar .spacer{flex:1}.pill{border:1px solid var(--border);padding:6px 10px;border-radius:999px;background:#ffffff0a;display:flex;align-items:center;gap:8px}.timer{font-variant-numeric:tabular-nums;color:var(--yellow);font-weight:800}.layout{flex:1;display:grid;grid-template-columns:460px 1fr 360px;min-height:0;overflow:hidden}.layoutRoom{flex:1;display:grid;grid-template-columns:1fr;min-height:0;overflow:hidden}.panel{background:#202020e6;border-right:1px solid var(--border);min-height:0;display:flex;flex-direction:column;height:100%;overflow:hidden}.panel.right{border-right:none;border-left:1px solid var(--border)}.panelHeader{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.panelBody{padding:12px;overflow:auto;flex:1;min-height:0}.btn{border:1px solid var(--border);background:#ffffff0f;color:var(--text);padding:8px 10px;border-radius:10px;cursor:pointer}.btn:hover{background:#ffffff17}.btn.primary{background:#f2c94c29;border-color:#f2c94c66}.btn.primary:hover{background:#f2c94c38}.btn.good{background:#3ddc9729;border-color:#3ddc9766}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.label{color:var(--muted);font-size:12px}.input{width:100%;border:1px solid var(--border);background:#0003;color:var(--text);border-radius:10px;padding:10px;outline:none}.row{display:flex;gap:10px;align-items:center}.roomsList{display:flex;flex-direction:column;gap:8px}.roomCard{border:1px solid var(--border);background:#0000002e;border-radius:12px;padding:10px;display:flex;align-items:center;justify-content:space-between;gap:10px}.roomMeta{display:flex;flex-direction:column;gap:2px;min-width:0}.roomName{font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.roomSub{color:var(--muted);font-size:12px;display:flex;gap:8px}.arena{position:relative;min-height:0;background:transparent}.arena{overflow:hidden;display:flex;flex-direction:column;min-height:0}.arenaInner{height:100%;display:flex;flex-direction:column}.floatingPanel{position:absolute;z-index:50;border-radius:12px;border:1px solid var(--border);background:#202020eb;box-shadow:0 12px 40px var(--shadow);overflow:hidden;display:flex;flex-direction:column;min-width:240px;min-height:180px}.floatingPanelHeader{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;cursor:grab;user-select:none}.floatingPanelHeader:active{cursor:grabbing}.floatingPanelClose{padding:4px 8px;border-radius:10px}.floatingPanelBody{flex:1;min-height:0;overflow:hidden}.floatingPanelResize{position:absolute;right:0;bottom:0;width:16px;height:16px;cursor:nwse-resize;background:linear-gradient(135deg,transparent 0 55%,rgba(255,255,255,.18) 56% 58%,transparent 59%),linear-gradient(135deg,transparent 0 72%,rgba(255,255,255,.12) 73% 75%,transparent 76%);opacity:.9}.table{width:100%;border-collapse:collapse;font-size:12px}.table th,.table td{padding:6px 8px;border-bottom:1px solid rgba(255,255,255,.06);text-align:left;font-variant-numeric:tabular-nums}.table th{color:var(--muted);font-weight:700}.table td strong{font-weight:800}.arenaCenter{flex:1;display:flex;align-items:center;justify-content:center;position:relative;min-height:0}.arenaCenter{padding:12px;height:100%}.centerTarget{width:var(--bomb-size);height:var(--bomb-size);border-radius:999px;z-index:2;background:radial-gradient(closest-side,#ffffff0f,#00000040);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;position:relative;box-shadow:inset 0 0 50px #00000059}.centerTarget{backdrop-filter:blur(2px)}.syllable{font-weight:900;letter-spacing:.08em;font-size:var(--bomb-syllable-font);color:var(--text)}.arenaStage{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:1px;height:1px}.aimArrow{position:absolute;left:0;top:0;z-index:0;height:10px;width:190px;background:var(--yellow);border-radius:999px;transform-origin:0 50%;filter:drop-shadow(0 8px 18px rgba(0,0,0,.45));will-change:transform,width;transition:transform .18s ease,width .18s ease}.aimArrow:after{content:"";position:absolute;right:-12px;top:50%;transform:translateY(-50%);border-left:18px solid var(--yellow);border-top:10px solid transparent;border-bottom:10px solid transparent}.aimArrow--battle{left:50%;top:50%}@media(prefers-reduced-motion:reduce){.aimArrow{transition:none}}.battleStage{position:relative;width:var(--bomb-size);height:var(--bomb-size);flex-shrink:0}.bombCircle{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;width:var(--bomb-size);height:var(--bomb-size);border-radius:999px;background:radial-gradient(ellipse 85% 75% at 50% 42%,#6e523ef2,#34261efa),radial-gradient(closest-side at 35% 35%,rgba(255,255,255,.12),transparent 55%);border:3px solid rgba(95,72,58,.95);box-shadow:inset 0 -16px 36px #00000073,inset 0 10px 24px #ffffff0f,0 10px 28px #0000006b;display:flex;align-items:center;justify-content:center}.bombCircle .syllable{position:relative;z-index:1;color:#f7f7f7;text-shadow:0 2px 8px rgba(0,0,0,.55);font-size:var(--bomb-syllable-font)}.bombFuse{position:absolute;top:-5px;right:20%;width:17px;height:14px;background:linear-gradient(145deg,#c49a6c,#6b4a32);border-radius:50% 40% 0;transform:rotate(28deg);z-index:3;box-shadow:0 2px 4px #00000059}.bombFuse:after{content:"";position:absolute;top:-10px;right:-2px;width:11px;height:11px;background:radial-gradient(circle at 35% 35%,#fffef0,#f2c94c 55%,#b8891e);border-radius:50%}.arenaBattle{width:100%;max-width:760px;margin:0 auto;flex:1;display:flex;align-items:center;justify-content:center;min-height:0;padding:4px 8px}.arenaBattleSides{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;min-width:0}.battleColumn{flex:1;min-width:0;max-width:280px;display:flex;justify-content:center;align-items:center}.battleColumnSpacer{width:100%;max-width:280px;min-height:1px}.battleCenterWrap{flex:0 0 auto;display:flex;align-items:center;justify-content:center}.playerBattleCard{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%;max-width:260px;user-select:none}.playerBattleCard .pname{font-size:16px;font-weight:800;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playerBattleCard .pword{font-size:14px;text-align:center;max-width:100%;min-height:20px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playerBattleCard .avatar{width:76px;height:76px;border-radius:14px;font-size:22px}.lifeRow{display:flex;gap:4px;justify-content:center;align-items:center;min-height:14px}.playerBattleCard .lifeRow{gap:6px;min-height:18px}.lifeSquare{width:11px;height:11px;border-radius:2px;background:var(--green);flex-shrink:0;box-shadow:0 0 0 1px #00000040}.playerBattleCard .lifeSquare{width:15px;height:15px;border-radius:3px}.playerDot .lifeSquare{width:13px;height:13px}.typingFrag--outer{color:var(--text)}.typingFrag--hit{color:var(--cyan);font-weight:800}.playerDot{position:absolute;width:104px;display:flex;flex-direction:column;align-items:center;gap:8px;transform:translate(-50%,-50%);user-select:none}.avatar{width:52px;height:52px;border-radius:10px;border:1px solid var(--border);background:#ffffff0d;overflow:hidden;display:flex;align-items:center;justify-content:center;color:#fff6;font-weight:900}.avatar img{width:100%;height:100%;object-fit:cover}.playerDot .avatar{width:66px;height:66px;border-radius:12px;font-size:18px}.playerDot .pname{font-size:14px;font-weight:800;text-align:center;max-width:104px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playerDot .pword{font-size:12px;color:var(--cyan);text-align:center;max-width:104px;min-height:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.turnGlow .avatar,.playerBattleCard.turnGlow .avatar{border-color:#f2c94cb3;box-shadow:0 0 0 3px #f2c94c2e}.eliminated{opacity:.45;filter:grayscale(1)}.bottomBar{position:absolute;left:12px;right:12px;bottom:12px;height:44px;display:flex;align-items:center;padding:0 12px;gap:12px;color:#ffffffbf;border:1px solid var(--border);background:#202020d9;border-radius:12px;box-shadow:0 12px 40px #00000059}.status{flex:1;text-align:center;color:#ffffffbf}.chatInner{display:flex;flex-direction:column;height:100%;min-height:0}.chatList{flex:1;overflow:auto;min-height:0;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.wordLogRow{display:flex;gap:8px;align-items:center;font-size:13px;min-width:0}.wordLogName{font-weight:800;color:#ffffffd9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:44%}.wordLogArrow{color:#ffffff59}.wordLogWord{color:var(--cyan);font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.wordLogWord--ok{color:#3ddc97f2}.wordLogWord--bad{color:#ff7878eb}.wordLogFrag--outer{color:inherit}.wordLogFrag--hit{color:#3ddc97f2;font-weight:900}.chatMsg{display:flex;gap:8px}.chatMsg .meta{display:flex;flex-direction:column;gap:2px;min-width:0}.chatMsg .name{font-size:12px;font-weight:800}.chatMsg .text{font-size:13px;color:var(--muted);word-break:break-word}.chatInput{border-top:1px solid var(--border);padding:10px 12px;display:flex;gap:8px}.wordInputWrap{display:none}@media(max-width:1100px){.layout{grid-template-columns:1fr}.panel,.panel.right{display:none}.arenaTopLeft{position:static;width:auto;margin:12px}.wordInputWrap{position:static;transform:none;margin:0 12px 12px;width:auto}.arenaCenter{padding-bottom:0}}@media(max-width:1100px){.layoutRoom{grid-template-columns:1fr}}.modalBackdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{width:min(420px,100%);background:#202020f5;border:1px solid var(--border);border-radius:14px;box-shadow:0 24px 80px #0000008c;padding:16px 18px}.modal h3{margin:0 0 12px;font-size:16px}.modalRow{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06);font-size:14px}.modalRow:last-child{border-bottom:none}.modalSoundRow{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;padding:6px 0 10px;margin-left:0;border-bottom:1px solid rgba(255,255,255,.06);font-size:12px;color:var(--muted)}.modalSoundActions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.filePickBtn{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:#ffffff0f;color:var(--text);padding:6px 10px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600}.filePickBtn:hover{background:#ffffff17}label.filePickBtn:has(input:disabled){opacity:.45;pointer-events:none}.btnIcon{width:36px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:10px}.fileUploadInput{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.fileUploadLabel{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:#ffffff14;color:var(--text);padding:8px 14px;border-radius:10px;cursor:pointer;font-size:13px;font-weight:600;margin-top:8px;transition:background .15s ease}.fileUploadLabel:hover{background:#ffffff1f}
