:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#0d0d0d;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#c0392b;text-decoration:inherit}a:hover{color:#e74c3c}body{margin:0;min-width:320px;min-height:100vh}#root{max-width:800px;margin:0 auto}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#181818;color:#ffffffde;cursor:pointer;transition:border-color .25s}button:hover{border-color:#c0392b}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}hr{border:none;border-top:1px solid #222;margin:20px 0}html,body{overflow-x:hidden;width:100%}.auth-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}.auth-box{display:flex;flex-direction:column;align-items:center;gap:16px;width:min(92vw,420px);padding:20px;border:1px solid #2a2a2a;border-radius:12px;background:#141414}.auth-logo{width:160px;height:auto;border-radius:12px}.auth-prompt{color:#888;font-size:1em;margin:0}.auth-input{padding:10px 16px;border-radius:8px;border:1px solid #2a2a2a;background:#141414;color:#ccc;font-size:1em;text-align:center;outline:none;width:min(300px,85vw);transition:border-color .2s}.auth-input:focus{border-color:#c0392b}.auth-error{color:#c0392b;font-size:.85em;margin:0}.auth-submit{padding:10px 16px;width:min(300px,85vw)}.auth-submit.ghost{background:#2b2b2b}.auth-rules{width:100%;max-width:540px;margin:0 auto;box-sizing:border-box;text-align:left;color:#bbb}.auth-rules h3{margin:0 0 8px;color:#fff}.auth-rules p{margin:0 0 8px;line-height:1.35}.auth-switch-row{display:flex;gap:10px;margin-top:10px}.guest-prompt{margin:0 auto 12px;max-width:540px;padding:10px 12px;border:1px solid #4a3420;border-radius:10px;background:#1f1710;color:#f0b47a;font-size:.9em}.profile-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.profile-card{width:min(92vw,420px);background:#141414;border:1px solid #2a2a2a;border-radius:12px;padding:20px;text-align:center}.profile-card h2{margin-top:0}.lobby{padding:40px;text-align:center}.lobby-logo{width:180px;height:auto;margin-top:40px;margin-bottom:8px;border-radius:12px}.lobby .subtitle{color:#666;margin-bottom:24px;font-size:.95em}.reveal-config{margin:0 auto 16px;max-width:540px;padding:14px;background:#141414;border:1px solid #2a2a2a;border-radius:12px;text-align:left}.reveal-config h3{margin:0 0 6px;font-size:1em;color:#cfcfcf}.reveal-config p{margin:0 0 10px;color:#777;font-size:.9em}.reveal-config-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px}.reveal-role-item{display:flex;align-items:center;gap:8px;color:#bbb;font-size:.95em}.reveal-role-item input{accent-color:#c0392b}.lobby input{padding:.6em 1em;border-radius:8px;border:1px solid #2a2a2a;background:#141414;color:inherit;font-size:1em;margin-right:8px}.room-info{margin:16px 0;padding:16px;background:#141414;border-radius:12px;border:1px solid #2a2a2a;text-align:center}.room-info code{display:inline-block;margin-top:4px;padding:6px 12px;background:#0a0a0a;border-radius:6px;font-size:.9em;color:#c0392b}.share-hint{color:#666;font-size:.9em;margin-bottom:4px}.room-info code.copyable{cursor:pointer;transition:background .2s,color .2s;-webkit-user-select:all;user-select:all}.room-info code.copyable:hover{background:#1a1010;color:#e74c3c}.room-info code.copyable:active{background:#2a1515}.copy-toast{margin-top:8px;font-size:.85em;font-weight:600;color:#e74c3c}.game-container{padding:8px 16px;box-sizing:border-box;overflow-x:hidden}.battlefield-3d{position:relative;width:100%;height:380px;margin-bottom:12px;border:1px solid #2a2a2a;border-radius:12px;overflow:hidden;background:#0f0f0f}.battlefield-3d-settings{display:flex;flex-wrap:wrap;gap:10px 16px;margin:0 0 12px;padding:8px 10px;border:1px solid #2a2a2a;border-radius:10px;background:#141414;color:#999;font-size:.82em;font-family:monospace}.battlefield-3d-settings label{display:flex;align-items:center;gap:6px}.battlefield-3d-toggle{text-transform:uppercase;letter-spacing:.03em;color:#ddd}.battlefield-3d-settings input{width:78px;padding:3px 6px;border:1px solid #333;border-radius:6px;background:#0e0e0e;color:#ddd}.battlefield-3d-btn-row{display:flex;gap:8px}.battlefield-3d-btn-row button{padding:4px 10px;border:1px solid #3a3a3a;border-radius:6px;background:#202020;color:#ddd;cursor:pointer}.battlefield-3d-btn-row button:disabled{opacity:.4;cursor:default}.battlefield-3d-edit-controls{align-items:center}.game-top-bar{display:flex;align-items:center;justify-content:flex-start;gap:16px;margin-bottom:12px}.game-logo{height:56px;width:auto;border-radius:8px}.round-badge{background:#1a1a1a;color:#999;padding:4px 14px;border-radius:20px;font-size:.85em;font-weight:600;border:1px solid #2a2a2a}.exit-btn{margin-left:0;background:none;border:1px solid #333;color:#666;font-size:1.1em;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;transition:color .2s,border-color .2s}.exit-btn:hover{color:#c0392b;border-color:#c0392b}.waiting-banner{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px;margin-bottom:12px;background:#141414;border:1px solid #2a2a2a;border-radius:12px;color:#777;font-size:1em;font-weight:500}.waiting-spinner{width:18px;height:18px;border:2px solid #333;border-top-color:#c0392b;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.event-log{padding:16px 20px;margin-bottom:12px;background:#141414;border:1px solid #2a2a2a;border-radius:12px}.event-log h3{margin:0 0 10px;font-size:1.1em;color:#c0392b}.event-item{padding:5px 0;font-size:.9em;color:#aaa;border-bottom:1px solid #1e1e1e}.event-item:last-child{border-bottom:none}.event-log.previous-round{margin-top:16px;opacity:.7}.event-log.previous-round h3{color:#8b2020}.ready-section{display:flex;flex-direction:column;align-items:center;gap:10px;padding:16px;margin-bottom:12px;background:#141414;border:1px solid #2a2a2a;border-radius:12px}.ready-btn{padding:10px 32px;font-size:1em;font-weight:600;border-radius:10px;border:1px solid #c0392b;background:#1a0f0f;color:#e74c3c;cursor:pointer;transition:background .2s,transform .1s}.ready-btn:hover:not(:disabled){background:#2a1515;transform:translateY(-1px)}.ready-btn.confirmed{opacity:.5;cursor:default;border-color:#333;color:#666}.ready-btn:disabled{cursor:default}.ready-info{display:flex;align-items:center;gap:16px;font-size:.85em;color:#666}.ready-info .timer{font-family:monospace;font-size:1.1em;color:#888}.game-over-banner{text-align:center;padding:24px;margin-bottom:12px;border-radius:12px;border:1px solid #2a2a2a;background:#141414}.game-over-banner h2{margin:0 0 8px;font-size:1.8em}.game-over-banner p{margin:0 0 16px;color:#777;font-size:.95em}.game-over-banner.win{border-color:#2d6a4f}.game-over-banner.win h2{color:#4ade80}.game-over-banner.lose{border-color:#6b2121}.game-over-banner.lose h2{color:#e74c3c}.game-over-banner.draw{border-color:#333}.game-over-banner.draw h2{color:#999}.play-again-btn{padding:10px 32px;font-size:1em;font-weight:600;border-radius:10px;border:1px solid #c0392b;background:#1a0f0f;color:#e74c3c;cursor:pointer;transition:background .2s,transform .1s}.play-again-btn:hover:not(:disabled){background:#2a1515;transform:translateY(-1px)}.play-again-btn.confirmed{opacity:.5;cursor:default;border-color:#333;color:#666}.play-again-btn:disabled{cursor:default}.battlefield{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start}.army-column{min-width:0}.army-title{margin:0 0 8px;font-size:.8em;text-align:center;text-transform:uppercase;letter-spacing:.08em;font-weight:700}.ally-title{color:#ccc}.enemy-title{color:#c0392b}.army-list{display:flex;flex-direction:column;gap:4px}.soldier-card{display:flex;flex-direction:column;padding:8px 12px;border-radius:10px;border:1px solid #222;background:#161616;transition:transform .15s,box-shadow .15s}.soldier-header{display:flex;align-items:center;gap:6px}.soldier-card:hover{transform:translate(2px);box-shadow:0 2px 12px #0006}.soldier-card.ally{border-color:#2a2a2a}.soldier-card.enemy{border-color:#2a1515}.soldier-card.hidden-role{opacity:.65;border-style:dashed;border-color:#222}.soldier-card.dead{opacity:.4;border-color:#1a1a1a;background:#111}.soldier-card.dead:hover{transform:none;box-shadow:none}.soldier-icon{font-size:1.1em;flex-shrink:0}.soldier-label{font-size:.82em;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:#ccc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.soldier-label.role-unknown{color:#555;font-style:italic}.soldier-card.dead .soldier-label{text-decoration:line-through;color:#555}.soldier-dead-badge{margin-left:auto;font-size:.75em;font-weight:700;color:#c0392b}.action-selector{width:100%;margin-top:4px;padding-top:4px;border-top:1px solid #222;display:flex;flex-direction:column;gap:3px}.action-selector>label{font-size:.68em;color:#666;text-transform:uppercase;letter-spacing:.03em}.action-selector select{width:100%;padding:4px 6px;border-radius:6px;border:1px solid #2a2a2a;background:#0d0d0d;color:#bbb;font-size:.78em;cursor:pointer;outline:none;transition:border-color .2s}.action-selector select:focus{border-color:#c0392b}.action-selector select option:disabled{color:#444;font-style:italic}.action-selector.idle{color:#555;font-size:.72em;font-style:italic;text-align:center}.action-radios{display:flex;flex-direction:column;gap:3px}.action-radios label{display:flex;align-items:center;gap:4px;font-size:.72em;color:#888;cursor:pointer;padding:2px 4px;border-radius:6px;transition:background .15s,color .15s;text-transform:none;letter-spacing:normal}.action-radios label:hover{background:#1e1e1e}.action-radios label.active{background:#1a1010;color:#e74c3c}.action-radios label.blocked{opacity:.4;cursor:not-allowed;text-decoration:line-through}.action-radios input[type=radio]{accent-color:#c0392b;margin:0}.submit-section{text-align:center;margin-top:16px;padding:16px}.submit-btn{padding:12px 48px;font-size:1.1em;font-weight:700;border-radius:10px;border:1px solid #c0392b;background:#c0392b;color:#fff;cursor:pointer;transition:background .2s,transform .1s;text-transform:uppercase;letter-spacing:.04em}.submit-btn:hover:not(:disabled){background:#e74c3c;transform:translateY(-1px)}.submit-btn:disabled{opacity:.25;cursor:not-allowed;background:#333;border-color:#333;color:#666}@media(max-width:500px){.game-container{padding:6px}.battlefield-3d{height:250px;margin-bottom:8px}.game-top-bar{gap:8px;margin-bottom:8px}.game-logo{height:40px}.round-badge{font-size:.72em;padding:3px 10px}.battlefield{gap:6px}.army-title{font-size:.68em;margin-bottom:4px}.soldier-card{padding:4px 6px}.soldier-icon{font-size:.85em}.soldier-label{font-size:.65em}.action-selector{margin-top:3px;padding-top:3px}.action-selector select{font-size:.68em;padding:2px 3px}.action-selector>label{font-size:.6em}.action-radios label{font-size:.62em;padding:1px 2px;gap:2px}.event-log{padding:10px 12px}.event-log h3{font-size:.9em}.event-item{font-size:.78em}.submit-btn{padding:10px 24px;font-size:.95em}.lobby{padding:20px 12px}.lobby input{margin-bottom:12px}.lobby-logo{width:140px}}.popup-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.popup-box{background:#1a1a1a;border:1px solid #333;border-radius:12px;padding:28px 32px 20px;max-width:320px;width:90%;text-align:center}.popup-message{color:#eee;font-size:1.05em;margin:0 0 24px;line-height:1.4}.popup-buttons{display:flex;gap:12px;justify-content:center}.popup-btn{padding:10px 24px;border-radius:8px;border:none;font-size:.95em;font-weight:600;cursor:pointer;transition:opacity .15s}.popup-btn:hover{opacity:.85}.popup-cancel{background:#333;color:#ccc}.popup-confirm{background:#c0392b;color:#fff}.top-controls{position:fixed;top:12px;right:12px;z-index:900;display:flex;align-items:center;gap:8px}.lang-switcher{display:flex;gap:2px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:2px}.lang-switcher button{padding:4px 10px;border:none;border-radius:6px;background:transparent;color:#555;font-size:.75em;font-weight:700;cursor:pointer;transition:background .15s,color .15s;letter-spacing:.05em}.lang-switcher button:hover{color:#999}.lang-switcher button.active{background:#c0392b;color:#fff}.menu-trigger{height:30px;min-width:34px;display:flex;align-items:center;justify-content:center;line-height:1;border-radius:8px;border:1px solid #2a2a2a;background:#1a1a1a;color:#bbb;cursor:pointer}.menu-dropdown{position:absolute;top:38px;right:0;min-width:140px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:6px;display:flex;flex-direction:column;gap:4px}.menu-dropdown button{border:none;background:#222;color:#ddd;text-align:left;padding:8px 10px;border-radius:6px;cursor:pointer}.menu-dropdown button:hover{background:#2c2c2c}
