*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;padding:0;overflow:hidden}#root{display:block}html.overlay-mode,html.overlay-mode body,.overlay-mode{background:transparent!important;background-color:transparent!important}.overlay-mode .board-section{background-color:transparent!important}:root{font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,Malgun Gothic,sans-serif;color:#fff;min-height:100vh;margin:0;padding:0}html:not(.overlay-mode){background:linear-gradient(135deg,#1a1a2e,#16213e)}.app{display:flex;flex-direction:column;min-height:100vh;height:100vh}.header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#0000004d;border-bottom:2px solid rgba(255,107,107,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100}.header h1{font-size:1.8rem;font-weight:700;margin:0;background:linear-gradient(90deg,#ff6b6b,#ff8e53);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-info{display:flex;gap:1rem}.badge{padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:600;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);display:inline-flex;align-items:center;gap:.5rem}.badge.direction.left{border-color:#3b82f680}.badge.direction.right{border-color:#ef444480}.badge.shield{border-color:#9333ea80}.main{flex:1;display:flex;justify-content:center;align-items:center;padding:1rem;overflow:hidden}.game-canvas{width:100%;height:100%;border-radius:12px;overflow:hidden;box-shadow:0 0 30px #0000004d}.hud{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;padding:1rem 2rem;background:#0006;border-top:2px solid rgba(255,107,107,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-height:35vh;overflow-y:auto}.hud-section{background:#ffffff0d;border-radius:8px;padding:1rem;border:1px solid rgba(255,255,255,.1)}.hud-section h3{margin:0 0 1rem;font-size:1.1rem;color:#ff6b6b;border-bottom:1px solid rgba(255,107,107,.3);padding-bottom:.5rem}.status-grid{display:grid;grid-template-columns:1fr;gap:.8rem}.status-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#0003;border-radius:6px;border-left:3px solid #ff6b6b}.status-item .label{font-size:.85rem;color:#a0a0a0}.status-item .value{font-weight:700;font-size:1rem;color:#fff}.messages-container{max-height:150px;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding-right:.5rem}.message-item{padding:.4rem .6rem;background:#ff6b6b1a;border-radius:4px;font-size:.85rem;line-height:1.4;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-30px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.no-messages{text-align:center;color:#666;font-style:italic;padding:2rem}.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.8rem;margin-bottom:1rem}.menu-btn{border:none;border-radius:8px;padding:.8rem .6rem;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-align:left;white-space:nowrap}.menu-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.menu-btn:active{transform:translateY(0)}.menu-btn.water{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.menu-btn.appetizer{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.menu-btn.shot{background:linear-gradient(135deg,#ff6b6b,#ee0979);color:#fff}.menu-btn.shield{background:linear-gradient(135deg,#9333ea,#a855f7);color:#fff}.menu-btn.world{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.menu-btn small{display:block;font-size:.7rem;margin-top:.3rem;opacity:.9}.info-box{background:#ff6b6b0d;border-radius:6px;padding:.8rem;font-size:.85rem;line-height:1.5}.info-box p{margin:.5rem 0}.info-box strong{color:#ff6b6b;font-weight:700}.messages-container::-webkit-scrollbar,.hud::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-track,.hud::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.messages-container::-webkit-scrollbar-thumb,.hud::-webkit-scrollbar-thumb{background:#ff6b6b4d;border-radius:3px}.rolling{animation:roll .5s ease-in-out infinite alternate}@keyframes roll{0%{transform:rotate(0) scale(1)}to{transform:rotate(5deg) scale(1.05)}}#phaser-container{width:100%;max-width:800px;height:auto;aspect-ratio:4 / 3}.app-root.has-bottom-bar .board-section{bottom:60px}@media (max-width: 900px){.app-root.has-bottom-bar .board-section{bottom:110px}}@media (max-width: 600px){.app-root.has-bottom-bar .board-section{bottom:180px}}.bottom-bar{display:flex;flex-wrap:wrap;gap:8px;padding:8px 12px;align-items:center;justify-content:center;min-height:50px;overflow-x:auto;overflow-y:hidden}.bottom-bar-status{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-right:8px}.bottom-bar-group{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.bottom-bar input[type=text]{min-width:80px;max-width:220px}.bottom-bar input[type=number]{width:56px}@media (max-width: 900px){.bottom-bar{min-height:auto;padding:6px 8px;gap:6px;justify-content:flex-start}.bottom-bar-status{font-size:11px;margin-right:4px}.bottom-bar-status span{white-space:nowrap}.bottom-bar input[type=text]{max-width:140px;font-size:11px;padding:4px 8px}.bottom-bar input[type=number]{width:48px;font-size:11px;padding:4px}.bottom-bar button{padding:4px 8px!important;font-size:11px!important;white-space:nowrap}}@media (max-width: 600px){.bottom-bar{flex-direction:column;align-items:stretch;padding:8px;max-height:50vh;overflow-y:auto}.bottom-bar-status{order:1;margin-right:0;padding-bottom:6px;border-bottom:1px solid rgba(0,0,0,.08)}.bottom-bar-group{order:2;justify-content:center}.bottom-bar input[type=text]{max-width:100%}}@media (max-width: 768px){.app-root .board-section{right:10px}}@media (max-width: 768px){.hud{grid-template-columns:1fr;max-height:50vh}.menu-grid{grid-template-columns:repeat(2,1fr)}.header{flex-direction:column;gap:.5rem;align-items:flex-start}.board-area{flex-direction:column}#phaser-container{height:60vh;max-height:400px}.footer-note{font-size:.8rem}}:root{--bg: #0b0b0f;--card: #f2f8ff}.app{min-height:100vh;display:flex;flex-direction:column;background:#111;color:#fff}.header{text-align:center;padding:16px;font-weight:700;font-size:1.8rem;background:linear-gradient(#4facfe,#3b82f6)}.content{flex:1;display:flex;justify-content:center;align-items:center;padding:20px}.board-area{display:flex;width:100%;gap:16px;padding:16px;align-items:flex-start}.board-wrapper{max-width:860px}.board-area{align-items:flex-start}.board-path{display:none}.board-area .side-panel{width:320px;color:#ddd}.game-canvas{width:100%;display:flex;justify-content:center}.game-board{width:100%;max-width:900px;background:#2c3e50;border-radius:12px;padding:16px;color:#fff}.board-visualization{display:flex;justify-content:center}.board-grid-simple{display:grid;grid-gap:12px;padding:8px;justify-content:center}.tile-simple{background:linear-gradient(#eef2f5,#dde5ec);color:#2c3e50;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:700}.board-path{padding:16px;align-content:start}.tile-path{width:40px;height:40px;border-radius:6px;background:linear-gradient(#eef4fb,#d6e3f5);display:flex;align-items:center;justify-content:center}.tile-path img{width:100%;height:100%;object-fit:cover;border-radius:6px}.tile-label{font-size:12px;color:#2c3e50}.game-stats{margin-top:12px;font-family:monospace}.hud{padding:8px;background:#111;border-top:1px solid #333;color:#ddd}
